Inconsistent behavior for -type, -depth and -colors
Posted: 2010-10-21T11:42:46-07:00
Hi,
I needed a simple thing, to rotate and write some png file in 1-bit depth, it didn't matter what format (gif, png, you name it). As it turned out, it's quite a problem in IM. My first approach was (<input> is 1-bit colormap PNG if it matters):
as PNG nicely support palette-based format. No luck, stored as 8-bit. Second try:
and
Still 8-bit. Desperate try:
Success! After some tests it seems PNG can be stored only as GrayScale when one wants 1-bit depth. Why? Palette-based format is perfectly valid => BUG here!
Another strange behavior:
stores 8-bit as I write above. But
stores 1-bit! Not only it's strange, it's also confusing! Aren't colors and depth redundant parameters? This "trick" seems to work for GIF, too but unfortunately, not for PNG data:image/s3,"s3://crabby-images/51e79/51e7935f2fd4eb0015e402355f035a43c0fe6a4a" alt="Sad :("
My version of IM is 6.6.4-10 2010-10-10 Q16 ...
I'd love to see I did something wrong... I tried also +antialias and +dither but no luck either.
I needed a simple thing, to rotate and write some png file in 1-bit depth, it didn't matter what format (gif, png, you name it). As it turned out, it's quite a problem in IM. My first approach was (<input> is 1-bit colormap PNG if it matters):
Code: Select all
convert <input> -type Palette -depth 1 output.png
Code: Select all
convert <input> -type Palette -depth 1 output.gif
Code: Select all
convert <input> -type Palette -depth 1 output.bmp
Code: Select all
convert <input> -type GrayScale -depth 1 output.png
Another strange behavior:
Code: Select all
convert <input> -type Palette -depth 1 output.bmp
Code: Select all
convert <input> -type Palette -depth 1 -colors 2 output.bmp
data:image/s3,"s3://crabby-images/51e79/51e7935f2fd4eb0015e402355f035a43c0fe6a4a" alt="Sad :("
My version of IM is 6.6.4-10 2010-10-10 Q16 ...
I'd love to see I did something wrong... I tried also +antialias and +dither but no luck either.