More progress in DDS input support.

This commit is contained in:
castano 2007-05-18 08:42:23 +00:00
parent de94fce1ce
commit d0f711c0ae
7 changed files with 86 additions and 33 deletions

View File

@ -99,48 +99,40 @@ public:
} }
friend Stream & operator<<( Stream & s, uint16 & c ) { friend Stream & operator<<( Stream & s, uint16 & c ) {
nvStaticCheck(sizeof(uint16) == 2); nvStaticCheck(sizeof(uint16) == 2);
s.byteOrderSerialize( &c, 2 ); return s.byteOrderSerialize( &c, 2 );
return s;
} }
friend Stream & operator<<( Stream & s, int16 & c ) { friend Stream & operator<<( Stream & s, int16 & c ) {
nvStaticCheck(sizeof(int16) == 2); nvStaticCheck(sizeof(int16) == 2);
s.byteOrderSerialize( &c, 2 ); return s.byteOrderSerialize( &c, 2 );
return s;
} }
friend Stream & operator<<( Stream & s, uint32 & c ) { friend Stream & operator<<( Stream & s, uint32 & c ) {
nvStaticCheck(sizeof(uint32) == 4); nvStaticCheck(sizeof(uint32) == 4);
s.byteOrderSerialize( &c, 4 ); return s.byteOrderSerialize( &c, 4 );
return s;
} }
friend Stream & operator<<( Stream & s, int32 & c ) { friend Stream & operator<<( Stream & s, int32 & c ) {
nvStaticCheck(sizeof(int32) == 4); nvStaticCheck(sizeof(int32) == 4);
s.byteOrderSerialize( &c, 4 ); return s.byteOrderSerialize( &c, 4 );
return s;
} }
friend Stream & operator<<( Stream & s, uint64 & c ) { friend Stream & operator<<( Stream & s, uint64 & c ) {
nvStaticCheck(sizeof(uint64) == 8); nvStaticCheck(sizeof(uint64) == 8);
s.byteOrderSerialize( &c, 8 ); return s.byteOrderSerialize( &c, 8 );
return s;
} }
friend Stream & operator<<( Stream & s, int64 & c ) { friend Stream & operator<<( Stream & s, int64 & c ) {
nvStaticCheck(sizeof(int64) == 8); nvStaticCheck(sizeof(int64) == 8);
s.byteOrderSerialize( &c, 8 ); return s.byteOrderSerialize( &c, 8 );
return s;
} }
friend Stream & operator<<( Stream & s, float & c ) { friend Stream & operator<<( Stream & s, float & c ) {
nvStaticCheck(sizeof(float) == 4); nvStaticCheck(sizeof(float) == 4);
s.byteOrderSerialize( &c, 4 ); return s.byteOrderSerialize( &c, 4 );
return s;
} }
friend Stream & operator<<( Stream & s, double & c ) { friend Stream & operator<<( Stream & s, double & c ) {
nvStaticCheck(sizeof(double) == 8); nvStaticCheck(sizeof(double) == 8);
s.byteOrderSerialize( &c, 8 ); return s.byteOrderSerialize( &c, 8 );
return s;
} }
protected: protected:
/** Serialize in the stream byte order. */ /// Serialize in the stream byte order.
Stream & byteOrderSerialize( void * v, int len ) { Stream & byteOrderSerialize( void * v, int len ) {
if( m_byteOrder == getSystemByteOrder() ) { if( m_byteOrder == getSystemByteOrder() ) {
serialize( v, len ); serialize( v, len );

View File

@ -21,6 +21,8 @@
// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR // FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
// OTHER DEALINGS IN THE SOFTWARE. // OTHER DEALINGS IN THE SOFTWARE.
#include <nvcore/Stream.h>
#include "ColorBlock.h" #include "ColorBlock.h"
#include "BlockDXT.h" #include "BlockDXT.h"
@ -505,6 +507,37 @@ void Block3DC::flip2()
Stream & nv::operator<<(Stream & stream, BlockDXT1 & block)
{
return stream << block.col0.u << block.col1.u << block.indices;
}
Stream & nv::operator<<(Stream & stream, AlphaBlockDXT3 & block)
{
stream.serialize(&block, sizeof(block));
return stream;
}
Stream & nv::operator<<(Stream & stream, BlockDXT3 & block)
{
return stream << block.alpha << block.color;
}
Stream & nv::operator<<(Stream & stream, AlphaBlockDXT5 & block)
{
stream.serialize(&block, sizeof(block));
return stream;
}
Stream & nv::operator<<(Stream & stream, BlockDXT5 & block)
{
return stream << block.alpha << block.color;
}
Stream & nv::operator<<(Stream & stream, Block3DC & block)
{
return stream << block.x << block.y;
}

View File

@ -26,9 +26,12 @@
#include <nvmath/Color.h> #include <nvmath/Color.h>
#include <nvimage.h>
namespace nv namespace nv
{ {
struct ColorBlock; struct ColorBlock;
class Stream;
/// DXT1 block. /// DXT1 block.
struct BlockDXT1 struct BlockDXT1
@ -62,8 +65,6 @@ namespace nv
} }
/// DXT3 alpha block with explicit alpha. /// DXT3 alpha block with explicit alpha.
struct AlphaBlockDXT3 struct AlphaBlockDXT3
{ {
@ -150,6 +151,7 @@ namespace nv
void flip2(); void flip2();
}; };
/// DXT5 block. /// DXT5 block.
struct BlockDXT5 struct BlockDXT5
{ {
@ -162,6 +164,7 @@ namespace nv
void flip2(); void flip2();
}; };
/// 3DC block. /// 3DC block.
struct Block3DC struct Block3DC
{ {
@ -174,6 +177,14 @@ namespace nv
void flip2(); void flip2();
}; };
// Serialization functions.
NVIMAGE_API Stream & operator<<(Stream & stream, BlockDXT1 & block);
NVIMAGE_API Stream & operator<<(Stream & stream, AlphaBlockDXT3 & block);
NVIMAGE_API Stream & operator<<(Stream & stream, BlockDXT3 & block);
NVIMAGE_API Stream & operator<<(Stream & stream, AlphaBlockDXT5 & block);
NVIMAGE_API Stream & operator<<(Stream & stream, BlockDXT5 & block);
NVIMAGE_API Stream & operator<<(Stream & stream, Block3DC & block);
} // nv namespace } // nv namespace
#endif // NV_IMAGE_BLOCKDXT_H #endif // NV_IMAGE_BLOCKDXT_H

View File

@ -76,10 +76,18 @@ namespace
static const uint DDSCAPS2_CUBEMAP_NEGATIVEZ = 0x00008000U; static const uint DDSCAPS2_CUBEMAP_NEGATIVEZ = 0x00008000U;
static const uint DDSCAPS2_CUBEMAP_ALL_FACES = 0x0000FC00U; static const uint DDSCAPS2_CUBEMAP_ALL_FACES = 0x0000FC00U;
static const uint DDPF_RGB = 0x00000040U;
static const uint DDPF_FOURCC = 0x00000004U;
static const uint DDPF_ALPHAPIXELS = 0x00000001U; static const uint DDPF_ALPHAPIXELS = 0x00000001U;
static const uint DDPF_NORMAL = 0x80000000U; // @@ Custom flag. static const uint DDPF_ALPHA = 0x00000002U;
static const uint DDPF_FOURCC = 0x00000004U;
static const uint DDPF_RGB = 0x00000040U;
static const uint DDPF_PALETTEINDEXED1 = 0x00000800U;
static const uint DDPF_PALETTEINDEXED2 = 0x00001000U;
static const uint DDPF_PALETTEINDEXED4 = 0x00000008U;
static const uint DDPF_PALETTEINDEXED8 = 0x00000020U;
static const uint DDPF_ALPHAPREMULT = 0x00008000U;
static const uint DDPF_NORMAL = 0x80000000U; // @@ Custom nv flag.
} // namespace } // namespace
@ -523,7 +531,7 @@ void DirectDrawSurface::readBlock(ColorBlock * rgba)
nvDebugCheck(stream != NULL); nvDebugCheck(stream != NULL);
nvDebugCheck(rgba != NULL); nvDebugCheck(rgba != NULL);
/*if (header.pf.fourcc == FOURCC_DXT1) if (header.pf.fourcc == FOURCC_DXT1)
{ {
BlockDXT1 block; BlockDXT1 block;
*stream << block; *stream << block;
@ -565,7 +573,7 @@ void DirectDrawSurface::readBlock(ColorBlock * rgba)
for (int i = 0; i < 16; i++) for (int i = 0; i < 16; i++)
{ {
Color32 & c = rgba->color(i); Color32 & c = rgba->color(i);
c.r = c.a; c.r = c.g = c.b = c.a;
c.a = 255; c.a = 255;
} }
} }
@ -588,10 +596,12 @@ void DirectDrawSurface::readBlock(ColorBlock * rgba)
{ {
Color32 & c = rgba->color(i); Color32 & c = rgba->color(i);
c.g = c.a; c.g = c.a;
c.b = 0;
c.a = 255;
}
} }
}*/
// If normal map flag set, conver to normal. // @@ If normal map flag set, convert to normal.
} }
@ -706,6 +716,12 @@ void DirectDrawSurface::printInfo() const
if (header.pf.flags & DDPF_RGB) printf("\t\tDDPF_RGB\n"); if (header.pf.flags & DDPF_RGB) printf("\t\tDDPF_RGB\n");
if (header.pf.flags & DDPF_FOURCC) printf("\t\tDDPF_FOURCC\n"); if (header.pf.flags & DDPF_FOURCC) printf("\t\tDDPF_FOURCC\n");
if (header.pf.flags & DDPF_ALPHAPIXELS) printf("\t\tDDPF_ALPHAPIXELS\n"); if (header.pf.flags & DDPF_ALPHAPIXELS) printf("\t\tDDPF_ALPHAPIXELS\n");
if (header.pf.flags & DDPF_ALPHA) printf("\t\tDDPF_ALPHA\n");
if (header.pf.flags & DDPF_PALETTEINDEXED1) printf("\t\tDDPF_PALETTEINDEXED1\n");
if (header.pf.flags & DDPF_PALETTEINDEXED2) printf("\t\tDDPF_PALETTEINDEXED2\n");
if (header.pf.flags & DDPF_PALETTEINDEXED4) printf("\t\tDDPF_PALETTEINDEXED4\n");
if (header.pf.flags & DDPF_PALETTEINDEXED8) printf("\t\tDDPF_PALETTEINDEXED8\n");
if (header.pf.flags & DDPF_ALPHAPREMULT) printf("\t\tDDPF_ALPHAPREMULT\n");
if (header.pf.flags & DDPF_NORMAL) printf("\t\tDDPF_NORMAL\n"); if (header.pf.flags & DDPF_NORMAL) printf("\t\tDDPF_NORMAL\n");
printf("\tFourCC: '%c%c%c%c'\n", ((header.pf.fourcc >> 0) & 0xFF), ((header.pf.fourcc >> 8) & 0xFF), ((header.pf.fourcc >> 16) & 0xFF), ((header.pf.fourcc >> 24) & 0xFF)); printf("\tFourCC: '%c%c%c%c'\n", ((header.pf.fourcc >> 0) & 0xFF), ((header.pf.fourcc >> 8) & 0xFF), ((header.pf.fourcc >> 16) & 0xFF), ((header.pf.fourcc >> 24) & 0xFF));

View File

@ -48,7 +48,11 @@ TARGET_LINK_LIBRARIES(nvcompress nvcore nvmath nvimage nvtt)
INSTALL(TARGETS nvcompress DESTINATION bin) INSTALL(TARGETS nvcompress DESTINATION bin)
#ADD_EXECUTABLE(nvtextool nvdxt.cpp configdialog.cpp) ADD_EXECUTABLE(nvddsinfo tools/ddsinfo.cpp)
TARGET_LINK_LIBRARIES(nvddsinfo nvcore nvmath nvimage)
INSTALL(TARGETS nvcompress nvddsinfo DESTINATION bin)

View File

@ -356,8 +356,7 @@ void nv::compressBC4(const Image * image, const nvtt::OutputOptions & outputOpti
// 128: 4.67 - 0.79 // 128: 4.67 - 0.79
// 256: 4.92 - 0.20 // 256: 4.92 - 0.20
// inf: 4.98 - 0.09 // inf: 4.98 - 0.09
//printf("Alpha error: %f\n", float(totalError) / (w*h));
printf("Alpha error: %f\n", float(totalError) / (w*h));
} }

View File

@ -274,8 +274,6 @@ int main(int argc, char *argv[])
if (nv::strCaseCmp(input.extension(), ".dds") == 0) if (nv::strCaseCmp(input.extension(), ".dds") == 0)
{ {
// Load surface. // Load surface.
printf("The file '%s' is not a supported image type.\n", input.str());
nv::DirectDrawSurface dds(input); nv::DirectDrawSurface dds(input);
if (!dds.isValid()) if (!dds.isValid())
{ {