Fix loading of dds normal maps.

Fix computation of angular deviation.
This commit is contained in:
castano 2007-10-15 10:36:49 +00:00
parent fbfc9c2bc1
commit 6cee7e2892
2 changed files with 17 additions and 11 deletions

View File

@ -834,10 +834,10 @@ void DirectDrawSurface::readBlockImage(Image * img)
static Color32 buildNormal(uint8 x, uint8 y) static Color32 buildNormal(uint8 x, uint8 y)
{ {
float nx = 2 * (x / 255) - 1; float nx = 2 * (x / 255.0f) - 1;
float ny = 2 * (x / 255) - 1; float ny = 2 * (x / 255.0f) - 1;
float nz = sqrtf(1 - nx*nx - ny*ny); float nz = sqrtf(1 - nx*nx - ny*ny);
uint8 z = clamp(int(255 * (nz + 1) / 2), 0, 255); uint8 z = clamp(int(255.0f * (nz + 1) / 2.0f), 0, 255);
return Color32(x, y, z); return Color32(x, y, z);
} }

View File

@ -29,6 +29,7 @@
#include <nvimage/DirectDrawSurface.h> #include <nvimage/DirectDrawSurface.h>
#include <nvmath/Color.h> #include <nvmath/Color.h>
#include <nvmath/Vector.h>
#include <math.h> #include <math.h>
@ -113,13 +114,14 @@ struct NormalError
void addSample(nv::Color32 o, nv::Color32 c) void addSample(nv::Color32 o, nv::Color32 c)
{ {
float xo = o.r / 255.0f; nv::Vector3 vo = nv::Vector3(o.r, o.g, o.b);
float yo = o.g / 255.0f; nv::Vector3 vc = nv::Vector3(c.r, c.g, c.b);
float zo = o.b / 255.0f;
float xc = c.r / 255.0f; vo = nv::normalize(2 * (vo / 255.0f) - 1);
float yc = c.g / 255.0f; vc = nv::normalize(2 * (vc / 255.0f) - 1);
float zc = c.b / 255.0f;
ade += acosf(xo * xc + yo * yc + zo * zc); ade += acosf(nv::clamp(dot(vo, vc), -1.0f, 1.0f));
samples++; samples++;
} }
@ -252,7 +254,6 @@ int main(int argc, char *argv[])
error_normal.done(); error_normal.done();
printf("Image size compared: %dx%d\n", w, h); printf("Image size compared: %dx%d\n", w, h);
if (w != w0 || w != w1 || h != h0 || h != h1) { if (w != w0 || w != w1 || h != h0 || h != h1) {
printf("--- NOTE: only the overlap between the 2 images (%d,%d) and (%d,%d) was compared\n", w0, h0, w1, h1); printf("--- NOTE: only the overlap between the 2 images (%d,%d) and (%d,%d) was compared\n", w0, h0, w1, h1);
@ -262,6 +263,11 @@ int main(int argc, char *argv[])
printf("Color:\n"); printf("Color:\n");
error_total.print(); error_total.print();
if (compareNormal)
{
error_normal.print();
}
if (compareAlpha) if (compareAlpha)
{ {
printf("Alpha:\n"); printf("Alpha:\n");