Cleanup 4 means compressor.
This commit is contained in:
parent
a4f56b65b8
commit
1ec115c7ec
@ -181,7 +181,7 @@ inline static float evaluatePaletteError4(const Vector3 block[16], Vector3::Arg
|
|||||||
float d2 = colorDistance(palette[2], block[i]);
|
float d2 = colorDistance(palette[2], block[i]);
|
||||||
float d3 = colorDistance(palette[3], block[i]);
|
float d3 = colorDistance(palette[3], block[i]);
|
||||||
|
|
||||||
total += min(min(d0, d1), min(d2, d3));
|
total += min(min(d0, d1), min(d2, d3));
|
||||||
}
|
}
|
||||||
|
|
||||||
return total;
|
return total;
|
||||||
@ -489,61 +489,24 @@ void QuickCompress::compressDXT1(const ColorBlock & rgba, BlockDXT1 * dxtBlock)
|
|||||||
Vector3 cluster[4];
|
Vector3 cluster[4];
|
||||||
int count = Compute4Means(16, block, weights, Vector3(1, 1, 1), cluster);
|
int count = Compute4Means(16, block, weights, Vector3(1, 1, 1), cluster);
|
||||||
|
|
||||||
Vector3 maxColor = cluster[0];
|
Vector3 maxColor, minColor;
|
||||||
Vector3 minColor = cluster[0];
|
float bestError = FLT_MAX;
|
||||||
|
|
||||||
float bestError = evaluatePaletteError4(block, maxColor, minColor);
|
for (int i = 1; i < 4; i++)
|
||||||
|
{
|
||||||
|
for (int j = 0; j < i; j++)
|
||||||
|
{
|
||||||
|
uint16 color0 = roundAndExpand(&cluster[i]);
|
||||||
|
uint16 color1 = roundAndExpand(&cluster[j]);
|
||||||
|
|
||||||
if (count >= 2)
|
float error = evaluatePaletteError4(block, cluster[i], cluster[j]);
|
||||||
{
|
if (error < bestError) {
|
||||||
float error = evaluatePaletteError4(block, cluster[0], cluster[1]);
|
bestError = error;
|
||||||
if (error < bestError) {
|
maxColor = cluster[i];
|
||||||
bestError = error;
|
minColor = cluster[j];
|
||||||
maxColor = cluster[0];
|
}
|
||||||
minColor = cluster[1];
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (count >= 3)
|
|
||||||
{
|
|
||||||
error = evaluatePaletteError4(block, cluster[0], cluster[2]);
|
|
||||||
if (error < bestError) {
|
|
||||||
bestError = error;
|
|
||||||
maxColor = cluster[0];
|
|
||||||
minColor = cluster[2];
|
|
||||||
}
|
|
||||||
|
|
||||||
error = evaluatePaletteError4(block, cluster[1], cluster[2]);
|
|
||||||
if (error < bestError) {
|
|
||||||
bestError = error;
|
|
||||||
maxColor = cluster[1];
|
|
||||||
minColor = cluster[2];
|
|
||||||
}
|
|
||||||
|
|
||||||
if (count >= 4)
|
|
||||||
{
|
|
||||||
error = evaluatePaletteError4(block, cluster[0], cluster[3]);
|
|
||||||
if (error < bestError) {
|
|
||||||
bestError = error;
|
|
||||||
maxColor = cluster[0];
|
|
||||||
minColor = cluster[3];
|
|
||||||
}
|
|
||||||
|
|
||||||
error = evaluatePaletteError4(block, cluster[1], cluster[3]);
|
|
||||||
if (error < bestError) {
|
|
||||||
bestError = error;
|
|
||||||
maxColor = cluster[1];
|
|
||||||
minColor = cluster[3];
|
|
||||||
}
|
|
||||||
|
|
||||||
error = evaluatePaletteError4(block, cluster[2], cluster[3]);
|
|
||||||
if (error < bestError) {
|
|
||||||
bestError = error;
|
|
||||||
maxColor = cluster[2];
|
|
||||||
minColor = cluster[3];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
uint16 color0 = roundAndExpand(&maxColor);
|
uint16 color0 = roundAndExpand(&maxColor);
|
||||||
|
Loading…
Reference in New Issue
Block a user