mirror of
https://github.com/yuzu-emu/FasTC.git
synced 2025-01-07 01:55:37 +00:00
Add some better comments
This commit is contained in:
parent
599152575b
commit
13d8407163
|
@ -127,11 +127,11 @@ namespace BPTCC {
|
||||||
// between zero and sixty-four that corresponds to one of the available
|
// between zero and sixty-four that corresponds to one of the available
|
||||||
// partitioning schemes defined by the BPTC format.
|
// partitioning schemes defined by the BPTC format.
|
||||||
struct ShapeSelection {
|
struct ShapeSelection {
|
||||||
// This is the number of indices from which to select the appropriate
|
// This is the number of valid shapes in m_Shapes
|
||||||
// shapes. I.e. the compressor will try the first m_NumIndices shapes
|
uint32 m_NumShapesToSearch;
|
||||||
uint32 m_NumIndices;
|
|
||||||
|
|
||||||
// These are the shape indices to use when evaluating two-partition shapes.
|
// These are the shape indices to use when evaluating shapes.
|
||||||
|
// I.e. the shapes that the compressor will try to optimize.
|
||||||
Shape m_Shapes[10];
|
Shape m_Shapes[10];
|
||||||
|
|
||||||
// This is the additional mask to prevent modes once shape selection
|
// This is the additional mask to prevent modes once shape selection
|
||||||
|
@ -141,7 +141,7 @@ namespace BPTCC {
|
||||||
|
|
||||||
// Defaults
|
// Defaults
|
||||||
ShapeSelection()
|
ShapeSelection()
|
||||||
: m_NumIndices(0)
|
: m_NumShapesToSearch(0)
|
||||||
, m_SelectedModes(static_cast<EBlockMode>(0xFF))
|
, m_SelectedModes(static_cast<EBlockMode>(0xFF))
|
||||||
{ }
|
{ }
|
||||||
};
|
};
|
||||||
|
|
|
@ -1722,7 +1722,7 @@ static ShapeSelection BoxSelection(
|
||||||
|
|
||||||
RGBACluster cluster(pixels);
|
RGBACluster cluster(pixels);
|
||||||
|
|
||||||
result.m_NumIndices = 1;
|
result.m_NumShapesToSearch = 1;
|
||||||
for(unsigned int i = 0; i < kNumShapes2; i++) {
|
for(unsigned int i = 0; i < kNumShapes2; i++) {
|
||||||
cluster.SetShapeIndex(i, 2);
|
cluster.SetShapeIndex(i, 2);
|
||||||
|
|
||||||
|
@ -1758,7 +1758,7 @@ static ShapeSelection BoxSelection(
|
||||||
~(static_cast<uint32>(eBlockMode_Four) |
|
~(static_cast<uint32>(eBlockMode_Four) |
|
||||||
static_cast<uint32>(eBlockMode_Five));
|
static_cast<uint32>(eBlockMode_Five));
|
||||||
|
|
||||||
result.m_NumIndices++;
|
result.m_NumShapesToSearch++;
|
||||||
for(unsigned int i = 0; i < kNumShapes3; i++) {
|
for(unsigned int i = 0; i < kNumShapes3; i++) {
|
||||||
cluster.SetShapeIndex(i, 3);
|
cluster.SetShapeIndex(i, 3);
|
||||||
|
|
||||||
|
@ -1794,7 +1794,7 @@ static void CompressClusters(const ShapeSelection &selection, const uint32 pixel
|
||||||
CompressionMode::Params bestParams;
|
CompressionMode::Params bestParams;
|
||||||
|
|
||||||
uint32 selectedModes = selection.m_SelectedModes;
|
uint32 selectedModes = selection.m_SelectedModes;
|
||||||
uint32 numShapeIndices = std::min<uint32>(5, selection.m_NumIndices);
|
uint32 numShapeIndices = std::min<uint32>(5, selection.m_NumShapesToSearch);
|
||||||
|
|
||||||
// If we don't have any indices, turn off two and three partition modes,
|
// If we don't have any indices, turn off two and three partition modes,
|
||||||
// since the compressor will simply ignore the shapeIndex variable afterwards...
|
// since the compressor will simply ignore the shapeIndex variable afterwards...
|
||||||
|
@ -2102,7 +2102,7 @@ static void CompressBC7Block(
|
||||||
ShapeSelection selection;
|
ShapeSelection selection;
|
||||||
uint32 path = 0;
|
uint32 path = 0;
|
||||||
|
|
||||||
selection.m_NumIndices = 1;
|
selection.m_NumShapesToSearch = 1;
|
||||||
for(unsigned int i = 0; i < kNumShapes2; i++) {
|
for(unsigned int i = 0; i < kNumShapes2; i++) {
|
||||||
blockCluster.SetShapeIndex(i, 2);
|
blockCluster.SetShapeIndex(i, 2);
|
||||||
|
|
||||||
|
@ -2156,7 +2156,7 @@ static void CompressBC7Block(
|
||||||
// There are not 3 subset blocks that support alpha, so only check these
|
// There are not 3 subset blocks that support alpha, so only check these
|
||||||
// if the entire block is opaque.
|
// if the entire block is opaque.
|
||||||
if(opaque) {
|
if(opaque) {
|
||||||
selection.m_NumIndices++;
|
selection.m_NumShapesToSearch++;
|
||||||
for(unsigned int i = 0; i < kNumShapes3; i++) {
|
for(unsigned int i = 0; i < kNumShapes3; i++) {
|
||||||
blockCluster.SetShapeIndex(i, 3);
|
blockCluster.SetShapeIndex(i, 3);
|
||||||
|
|
||||||
|
|
|
@ -61,6 +61,10 @@
|
||||||
namespace DXTC
|
namespace DXTC
|
||||||
{
|
{
|
||||||
void DecompressDXT1Block(const uint8 *block, uint32 *outBuf) {
|
void DecompressDXT1Block(const uint8 *block, uint32 *outBuf) {
|
||||||
|
// When we call FasTC::Pixel::FromBits, we expect the bits
|
||||||
|
// to be read out of memory in LSB (byte) order first. Hence,
|
||||||
|
// we can't read the blocks directly as uint16 values out of
|
||||||
|
// the DXT buffer and we have to swap the bytes before hand.
|
||||||
uint16 colorA = block[0];
|
uint16 colorA = block[0];
|
||||||
colorA <<= 8;
|
colorA <<= 8;
|
||||||
colorA |= block[1];
|
colorA |= block[1];
|
||||||
|
|
Loading…
Reference in a new issue