mirror of
https://github.com/yuzu-emu/FasTC.git
synced 2025-01-09 01:35:38 +00:00
Fix some MSVC compiler snafus
This commit is contained in:
parent
c3cb8403b5
commit
baab69dc99
|
@ -1402,7 +1402,7 @@ double BC7CompressionMode::Compress(
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const bool rotated = bestAlphaIndices[anchorIdx] >> (nAlphaIndexBits - 1);
|
const bool rotated = (bestAlphaIndices[anchorIdx] >> (nAlphaIndexBits - 1)) > 0;
|
||||||
if(m_Attributes->hasRotation && rotated) {
|
if(m_Attributes->hasRotation && rotated) {
|
||||||
uint8 * bp1 = reinterpret_cast<uint8 *>(&pixel1[sidx]);
|
uint8 * bp1 = reinterpret_cast<uint8 *>(&pixel1[sidx]);
|
||||||
uint8 * bp2 = reinterpret_cast<uint8 *>(&pixel2[sidx]);
|
uint8 * bp2 = reinterpret_cast<uint8 *>(&pixel2[sidx]);
|
||||||
|
@ -1660,8 +1660,8 @@ namespace BC7C {
|
||||||
double gdiff = sad(unCompData[k+1], inBuf[k+1]);
|
double gdiff = sad(unCompData[k+1], inBuf[k+1]);
|
||||||
double bdiff = sad(unCompData[k+2], inBuf[k+2]);
|
double bdiff = sad(unCompData[k+2], inBuf[k+2]);
|
||||||
double adiff = sad(unCompData[k+3], inBuf[k+3]);
|
double adiff = sad(unCompData[k+3], inBuf[k+3]);
|
||||||
const float asrc = static_cast<double>(inBuf[k+3]);
|
const double asrc = static_cast<double>(inBuf[k+3]);
|
||||||
const float adst = static_cast<double>(unCompData[k+3]);
|
const double adst = static_cast<double>(unCompData[k+3]);
|
||||||
double avga = ((asrc + adst)*0.5)/255.0;
|
double avga = ((asrc + adst)*0.5)/255.0;
|
||||||
diffSum += (rdiff + gdiff + bdiff + adiff) * avga;
|
diffSum += (rdiff + gdiff + bdiff + adiff) * avga;
|
||||||
}
|
}
|
||||||
|
@ -2581,7 +2581,7 @@ namespace BC7C {
|
||||||
|
|
||||||
assert(idxMode < 2);
|
assert(idxMode < 2);
|
||||||
assert(rotMode < 4);
|
assert(rotMode < 4);
|
||||||
assert(shapeIdx < ((mode == 0)? 16 : 64));
|
assert(shapeIdx < ((mode == 0)? 16U : 64U));
|
||||||
|
|
||||||
uint32 cp = attrs->colorChannelPrecision;
|
uint32 cp = attrs->colorChannelPrecision;
|
||||||
const uint32 shift = 8 - cp;
|
const uint32 shift = 8 - cp;
|
||||||
|
|
|
@ -139,7 +139,7 @@ double Image::ComputePSNR(Image *other) {
|
||||||
const unsigned char *pixelDataRaw = ourData + i;
|
const unsigned char *pixelDataRaw = ourData + i;
|
||||||
const unsigned char *pixelDataUncomp = otherData + i;
|
const unsigned char *pixelDataUncomp = otherData + i;
|
||||||
|
|
||||||
float r[4], u[4];
|
double r[4], u[4];
|
||||||
for(uint32 c = 0; c < 4; c++) {
|
for(uint32 c = 0; c < 4; c++) {
|
||||||
if(c == 3) {
|
if(c == 3) {
|
||||||
r[c] = pixelDataRaw[c] / 255.0;
|
r[c] = pixelDataRaw[c] / 255.0;
|
||||||
|
|
|
@ -40,13 +40,18 @@
|
||||||
*
|
*
|
||||||
* <http://gamma.cs.unc.edu/FasTC/>
|
* <http://gamma.cs.unc.edu/FasTC/>
|
||||||
*/
|
*/
|
||||||
#include <stdlib.h>
|
|
||||||
#include <stdio.h>
|
#define _CRT_SECURE_NO_WARNINGS
|
||||||
#include <string.h>
|
|
||||||
|
#include <cstdlib>
|
||||||
|
#include <cstdio>
|
||||||
|
#include <cstring>
|
||||||
|
#include <fstream>
|
||||||
|
#include <iostream>
|
||||||
#include <SDKDDKVer.h>
|
#include <SDKDDKVer.h>
|
||||||
#include <Windows.h>
|
#include <Windows.h>
|
||||||
|
|
||||||
#include "BlockStats.h"
|
#include "ThreadSafeStreambuf.h"
|
||||||
#include "TexComp.h"
|
#include "TexComp.h"
|
||||||
#include "ImageFile.h"
|
#include "ImageFile.h"
|
||||||
#include "Image.h"
|
#include "Image.h"
|
||||||
|
@ -211,15 +216,18 @@ int _tmain(int argc, _TCHAR* argv[])
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
Image img (*file.GetImage())
|
Image img (*file.GetImage());
|
||||||
if(format == eCompressionFormat_PVRTC) {
|
if(format == eCompressionFormat_PVRTC) {
|
||||||
img.SetBlockStreamOrder(false);
|
img.SetBlockStreamOrder(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
int numBlocks = (img.GetWidth() * img.GetHeight())/16;
|
std::ofstream logFile;
|
||||||
BlockStatManager *statManager = NULL;
|
ThreadSafeStreambuf streamBuf(std::cout);
|
||||||
|
std::ostream logStream(&streamBuf);
|
||||||
if(bSaveLog) {
|
if(bSaveLog) {
|
||||||
statManager = new BlockStatManager(numBlocks);
|
char logname[256];
|
||||||
|
sprintf(logname, "%s.log", basename);
|
||||||
|
logFile.open(logname);
|
||||||
}
|
}
|
||||||
|
|
||||||
SCompressionSettings settings;
|
SCompressionSettings settings;
|
||||||
|
@ -230,15 +238,15 @@ int _tmain(int argc, _TCHAR* argv[])
|
||||||
settings.iQuality = quality;
|
settings.iQuality = quality;
|
||||||
settings.iNumCompressions = numCompressions;
|
settings.iNumCompressions = numCompressions;
|
||||||
settings.iJobSize = numJobs;
|
settings.iJobSize = numJobs;
|
||||||
settings.pStatManager = statManager;
|
settings.logStream = &logStream;
|
||||||
|
|
||||||
CompressedImage *ci = img->Compress(settings);
|
CompressedImage *ci = CompressImage(&img, settings);
|
||||||
if(NULL == ci) {
|
if(NULL == ci) {
|
||||||
fprintf(stderr, "Error compressing image!\n");
|
fprintf(stderr, "Error compressing image!\n");
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
double PSNR = img->ComputePSNR(*ci);
|
double PSNR = img.ComputePSNR(ci);
|
||||||
if(PSNR > 0.0) {
|
if(PSNR > 0.0) {
|
||||||
fprintf(stdout, "PSNR: %.3f\n", PSNR);
|
fprintf(stdout, "PSNR: %.3f\n", PSNR);
|
||||||
}
|
}
|
||||||
|
@ -246,12 +254,6 @@ int _tmain(int argc, _TCHAR* argv[])
|
||||||
fprintf(stderr, "Error computing PSNR\n");
|
fprintf(stderr, "Error computing PSNR\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
if(bSaveLog) {
|
|
||||||
strcat_s(basename, ".log");
|
|
||||||
statManager->ToFile(basename);
|
|
||||||
basename[strlen(basename) - 4] = '\0';
|
|
||||||
}
|
|
||||||
|
|
||||||
if(format == eCompressionFormat_BPTC) {
|
if(format == eCompressionFormat_BPTC) {
|
||||||
strcat_s(basename, "-bc7.png");
|
strcat_s(basename, "-bc7.png");
|
||||||
} else if(format == eCompressionFormat_PVRTC) {
|
} else if(format == eCompressionFormat_PVRTC) {
|
||||||
|
@ -263,8 +265,8 @@ int _tmain(int argc, _TCHAR* argv[])
|
||||||
|
|
||||||
// Cleanup
|
// Cleanup
|
||||||
delete ci;
|
delete ci;
|
||||||
if(statManager)
|
if(bSaveLog)
|
||||||
delete statManager;
|
logFile.close();
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
|
@ -134,7 +134,7 @@ bool ImageLoaderPNG::ReadData() {
|
||||||
}
|
}
|
||||||
|
|
||||||
const int numPixels = m_Width * m_Height;
|
const int numPixels = m_Width * m_Height;
|
||||||
png_uint_32 bpr = png_get_rowbytes(png_ptr, info_ptr);
|
png_size_t bpr = png_get_rowbytes(png_ptr, info_ptr);
|
||||||
png_bytep rowData = new png_byte[bpr];
|
png_bytep rowData = new png_byte[bpr];
|
||||||
|
|
||||||
switch(colorType) {
|
switch(colorType) {
|
||||||
|
|
|
@ -77,7 +77,7 @@ public:
|
||||||
unsigned char *stream = &(writer.m_RawFileData[writer.m_StreamPosition]);
|
unsigned char *stream = &(writer.m_RawFileData[writer.m_StreamPosition]);
|
||||||
memcpy(stream, outBytes, byteCountToWrite);
|
memcpy(stream, outBytes, byteCountToWrite);
|
||||||
|
|
||||||
writer.m_StreamPosition += byteCountToWrite;
|
writer.m_StreamPosition += static_cast<uint32>(byteCountToWrite);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void FlushStream(png_structp png_ptr) { /* Do nothing... */ }
|
static void FlushStream(png_structp png_ptr) { /* Do nothing... */ }
|
||||||
|
|
|
@ -50,6 +50,11 @@
|
||||||
* <http://gamma.cs.unc.edu/FasTC/>
|
* <http://gamma.cs.unc.edu/FasTC/>
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#if _MSC_VER
|
||||||
|
# define _CRT_SECURE_NO_WARNINGS
|
||||||
|
# define snprintf _snprintf
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "Image.h"
|
#include "Image.h"
|
||||||
|
|
||||||
#include <algorithm>
|
#include <algorithm>
|
||||||
|
@ -58,11 +63,6 @@
|
||||||
#include <cstdio>
|
#include <cstdio>
|
||||||
#include <cmath>
|
#include <cmath>
|
||||||
|
|
||||||
#if _MSC_VER
|
|
||||||
# define _CRT_SECURE_NO_WARNINGS
|
|
||||||
# define snprintf _snprintf
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include "Pixel.h"
|
#include "Pixel.h"
|
||||||
|
|
||||||
#include "../../Base/include/Image.h"
|
#include "../../Base/include/Image.h"
|
||||||
|
@ -287,7 +287,7 @@ void Image::ContentAwareDownscale(uint32 xtimes, uint32 ytimes,
|
||||||
float g = a * ConvertChannelToFloat(m_Pixels[i].G(), bitDepth[2]);
|
float g = a * ConvertChannelToFloat(m_Pixels[i].G(), bitDepth[2]);
|
||||||
float b = a * ConvertChannelToFloat(m_Pixels[i].B(), bitDepth[3]);
|
float b = a * ConvertChannelToFloat(m_Pixels[i].B(), bitDepth[3]);
|
||||||
|
|
||||||
I[i] = r * 0.21 + g * 0.71 + b * 0.07;
|
I[i] = r * 0.21f + g * 0.71f + b * 0.07f;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Use central differences to calculate Ix, Iy, Ixx, Iyy...
|
// Use central differences to calculate Ix, Iy, Ixx, Iyy...
|
||||||
|
|
|
@ -175,7 +175,7 @@ namespace PVRTCC {
|
||||||
uint16 v = static_cast<uint16>(val);
|
uint16 v = static_cast<uint16>(val);
|
||||||
v = (v + (1 << (bitsWasted - 1))) >> bitsWasted;
|
v = (v + (1 << (bitsWasted - 1))) >> bitsWasted;
|
||||||
v = ::std::min<uint16>(::std::max<uint16>(0, v), (1 << newDepth) - 1);
|
v = ::std::min<uint16>(::std::max<uint16>(0, v), (1 << newDepth) - 1);
|
||||||
return v;
|
return static_cast<uint8>(v);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue