VC ++ 2010,OpenGL,GLSL,SDL
所以我遇到两个主要问题。我希望主要解决第一个问题:我正在使用的法线贴图不适用于指向正x方向或正x方向的法线。 z和y似乎工作正常(测试立方体上的纹理和法线)。
编辑:它在x方向上似乎不是法线,因为当我旋转几何体时,前面四边形仍然有效。所以看起来面对x不起作用的最初是什么。
这是一些简单的测试几何:
glBegin(GL_QUADS);
glNormal3f(0.0f, 0.0f, 1.0f);
glTexCoord2f(0.0, 0.0); glVertex3f(-1.0f, 0.0f, 1.0f);
glTexCoord2f(0.0, 1.0); glVertex3f(-1.0f, 2.0f, 1.0f);
glTexCoord2f(1.0, 1.0); glVertex3f(1.0f, 2.0f, 1.0f);
glTexCoord2f(1.0, 0.0); glVertex3f(1.0f, 0.0f, 1.0f);
glEnd();
glBegin(GL_QUADS);
glNormal3f(-1.0f, 0.0f, 0.0f);
glTexCoord2f(0.0, 0.0); glVertex3f(-1.0f, 0.0f, 1.0f);
glTexCoord2f(0.0, 1.0); glVertex3f(-1.0f, 2.0f, 1.0f);
glTexCoord2f(1.0, 1.0); glVertex3f(-1.0f, 2.0f, -1.0f);
glTexCoord2f(1.0, 0.0); glVertex3f(-1.0f, 0.0f, -1.0f);
glEnd();
顶点着色器
#define MAX_LIGHTS 8
#define NUM_LIGHTS 1
varying vec3 lightVec[MAX_LIGHTS];
varying vec3 viewVec;
attribute vec4 glTangent4f;
void main(void)
{
gl_Position = ftransform();
gl_TexCoord[0] = gl_MultiTexCoord0;
vec3 n = normalize(gl_NormalMatrix * gl_Normal);
vec3 t = normalize(gl_NormalMatrix * glTangent4f.xyz);
vec3 b = cross(n, t);
vec3 v;
vec3 vVertex = vec3(gl_ModelViewMatrix * gl_Vertex);
int i;
for (i=0; i<NUM_LIGHTS; ++i)
{
vec3 lVec = gl_LightSource[i].position.xyz - vVertex;
v.x = dot(lVec, t);
v.y = dot(lVec, b);
v.z = dot(lVec, n);
lightVec[i] = v;
}
vec3 vVec = -vVertex;
v.x = dot(vVec, t);
v.y = dot(vVec, b);
v.z = dot(vVec, n);
viewVec = v;
}
片段着色器
#define MAX_LIGHTS 8
#define NUM_LIGHTS 1
varying vec3 lightVec[MAX_LIGHTS];
varying vec3 viewVec;
uniform sampler2D colorMap;
uniform sampler2D normalMap;
void main (void)
{
vec2 uv = gl_TexCoord[0].st * 4.0;
vec4 base = texture2D(colorMap, uv);
vec4 final_color = vec4(0.2, 0.2, 0.2, 1.0) * base;
vec3 vVec = normalize(viewVec);
vec3 bump = normalize(texture2D(normalMap, uv).xyz * 2.0 - 1.0);
vec3 R = reflect(-vVec, bump);
int i;
for (i=0; i<NUM_LIGHTS; ++i)
{
vec3 lVec = normalize(lightVec[i]);
float diffuse = max(dot(lVec, bump), 0.0);
vec4 vDiffuse = gl_FrontLightProduct[i].diffuse * diffuse * base;
final_color += vDiffuse;
float specular = pow(clamp(dot(R, lVec), 0.0, 1.0), gl_FrontMaterial.shininess);
vec4 vSpecular = gl_FrontLightProduct[i].specular * specular * diffuse;
final_color += vSpecular;
}
gl_FragColor = final_color;
}
另一个问题(我不一定需要在这一刻解决)是定向灯的镜面似乎跟着相机
答案 0 :(得分:2)
attribute vec4 glTangent4f;
你实际上提供这个值在哪里?它是一个顶点属性,但你的渲染代码似乎没有提供任何东西。
答案 1 :(得分:0)
“我如何将此曲面传递给程序?”
您是否计算过对象的切线基础?我记得波前对象通常不包括顶点切线数据,在这种情况下,您需要在解析波前数据后计算切线基础。 根据代码的外观,您似乎根本没有相切数据。
您可以在顶点着色器中进行切线近似,也可以使用法线。
我实际上并不知道如何将切线数据传递给程序,因为您没有使用VBO。
编辑:
我现在看到我做了一个愚蠢的假设,你是从3d文件格式加载你的数据,你不是,但你仍然需要在某处计算切线。