【发布时间】:2015-06-01 08:07:15
【问题描述】:
我正在尝试让我的应用程序导出动画 gif,但是,一旦颜色超过 256,量化算法就会启动,事情就会出错。
这是我正在转换的文件,以及算法将其转换为什么:
我正在使用的量化算法is this, Quantize.java,它显然是 ImageMagick 中使用的量化的 Java 端口,所以我觉得它应该是可靠的?
我是这样使用的:
protected int[][] pixels; // 2D array of RGB pixels of image
protected byte[] indexedPixels;
// ...
/**
* Analyzes image colors and creates color map.
*/
protected void analyzePixels()
{
// Quantize the pixels, get reduced color map and indexed array.
// -------------------------------------------------------------
colorPalette = Quantize.quantizeImage(pixels, 256);
// Create indexed pixels array.
// ----------------------------
int i = 0;
for (int x = 0, xSize = pixels.length; x < xSize; ++x)
{
for (int y = 0, ySize = pixels[x].length; y < ySize; ++y)
indexedPixels[i++] = (byte) pixels[x][y];
}
}
注意 - 当我将 static final boolean QUICK 设置为 false 时,算法将其转换为以下内容:
看起来不一样,但还是不对。
我真的很想让这个算法发挥作用,因为它比替代方案 (NeuQuant) 速度快(呃)并且生成的文件更小。我做的一切都是正确的还是这就是算法的工作原理?
【问题讨论】:
-
您希望
indexedPixels[i++] = (byte) pixels[x][y];行做什么? -
@DouglasZare
colorPalette = Quantize.quantizeImage(pixels, 256);行将像素[][] 的内容转换为 colorMap[] 的索引,本质上将每个像素指向 colorMap[] 中的一种颜色。您引用的行我只是将它从 2D 数组清空到 1D 字节数组中,因为这是我正在使用的 LZWEncoder 所期望的。 -
哇,这是 quantizeImage 的副作用。通过colorMap [],您的意思是colorPalette?您是否确保撤消从 int 到 byte 的每个索引的转换,而不是简单地将其转换回 int?例如,颜色编号 200(作为 int)变为 -56(作为字节)。
-
@DouglasZare Man 这似乎是一个很好的答案。我刚刚尝试过(一起摆脱了字节,只使用整数),但结果完全相同。 indexedPixels[] 数组现在看起来更正确了,没有负数,内容从 0 到 255。
标签: java algorithm imagemagick gif quantization