Convert image to 256 colors palette
Posted: 2016-04-15T03:22:15-07:00
Hi. In order to display images from the web on a pebble smartwatch I want to reduce their colors on my server before displaying them.
In order to do that I'm using -remap with the 64 colors palette that is provided from the pebble documentation:
For testing I used this image / palette:
data:image/s3,"s3://crabby-images/c9d9e/c9d9eeebb5177a530c86a4f4fdd7e3c43681145d" alt="Image"
The processed one looks like this
data:image/s3,"s3://crabby-images/b50bb/b50bb14fcbde07cb2aaba158ecddd0b460477859" alt="Image"
But when I try displaying this image on the pebble, it ends up like this (ignore borders):
data:image/s3,"s3://crabby-images/1945b/1945b2050ce4808714fe37427fec1e26e850172d" alt="Image"
If I instead use GIMP to reduce the colors, the image looks the same, but works correctly on the pebble.
I tried using the identify command on both images and this was the result:
Working image: http://pastebin.com/raw/wGYb0NT1
Broken image: http://pastebin.com/raw/YUHjZnDn
The only difference I could find was the color palette, which was padded to 256 colors with black in the working image.
I also noticed that I get the same broken image with gimp, if I tell it to remove unused colors from the image palette.
Is there any way to achieve the same result with imagemagick as I did with gimp?
I'm using ImageMagick version 6.8.9-9
In order to do that I'm using -remap with the 64 colors palette that is provided from the pebble documentation:
Code: Select all
convert in.ong -dither FloydSteinberg -remap palette.gif png8:out.png
data:image/s3,"s3://crabby-images/69432/69432f2542191e9f7f52f2eb611e0c922ca9c90a" alt="Image"
data:image/s3,"s3://crabby-images/c9d9e/c9d9eeebb5177a530c86a4f4fdd7e3c43681145d" alt="Image"
The processed one looks like this
data:image/s3,"s3://crabby-images/b50bb/b50bb14fcbde07cb2aaba158ecddd0b460477859" alt="Image"
But when I try displaying this image on the pebble, it ends up like this (ignore borders):
data:image/s3,"s3://crabby-images/1945b/1945b2050ce4808714fe37427fec1e26e850172d" alt="Image"
If I instead use GIMP to reduce the colors, the image looks the same, but works correctly on the pebble.
I tried using the identify command on both images and this was the result:
Working image: http://pastebin.com/raw/wGYb0NT1
Broken image: http://pastebin.com/raw/YUHjZnDn
The only difference I could find was the color palette, which was padded to 256 colors with black in the working image.
I also noticed that I get the same broken image with gimp, if I tell it to remove unused colors from the image palette.
Is there any way to achieve the same result with imagemagick as I did with gimp?
I'm using ImageMagick version 6.8.9-9