OpenGL光线五 opengl投光物Light Casters (平行光、点光源、聚光灯)

一、平行光
LightDirectional::LightDirectional(glm::vec3 _position, glm::vec3 _angles, glm::vec3 _color):
postion(_position),
angles(_angles),
color(_color)
{
UpdateDirection();
}

void LightDirectional::UpdateDirection()
{
direction = glm::vec3(0, 0, 1.0f);
direction = glm::rotateZ(direction, angles.z);
direction = glm::rotateX(direction, angles.x);
direction = glm::rotateY(direction, angles.y);
direction *= -1.0f;
}
二、点光源
LightPoint::LightPoint(glm::vec3 _position, glm::vec3 _angles, glm::vec3 _color):
postion(_position),
angles(_angles),
color(_color)
{
constant = 1.0f;
linear = 0.09f;
quadratic = 0.032f;
}
三、聚光灯
LightSpot::LightSpot(glm::vec3 _position, glm::vec3 _angles, glm::vec3 _color):
postion(_position),
angles(_angles),
color(_color)
{
UpdateDirection();
}

void LightSpot::UpdateDirection()
{
direction = glm::vec3(0, 0, 1.0f);
direction = glm::rotateZ(direction, angles.z);
direction = glm::rotateX(direction, angles.x);
direction = glm::rotateY(direction, angles.y);
direction *= -1.0f;
}

四、在fragmentShader中计算光源
vec3 lightColorReal;
vec3 lightDirReal;
//1、LightDirection 平行光
//lightDirReal = lightDirUniform;
//lightColorReal = lightColor;

//2、LightPoint 点光源

// lightDirReal = normalize(lightPos - FragPos);
// float dist = length(lightPos - FragPos);
// float attenuation = 1.0 / (lightP.constant + lightP.linear * dist +
// lightP.quadratic * (dist * dist));
// lightColorReal = lightColor*attenuation;

//3、LightSpot 聚光灯
lightDirReal = normalize(lightPos - FragPos);
float cosTheta = dot(normalize(FragPos - lightPos),-1*lightDirUniform);
float spotRatio = (cosTheta-lightS.cosPhyOutter)/(lightS.cosPhyInner-lightS.cosPhyOutter);
if(cosTheta>lightS.cosPhyInner){
	//inside
	lightColorReal = lightColor;
}else if(cosTheta>lightS.cosPhyOutter){
	//middle
	lightColorReal = lightColor*spotRatio;
}else{
	//outside
	lightColorReal = lightColor*0.0f;
}

//////////////光照模型//////////////////////
vec3 reflectVec =reflect(lightDirReal,Normal);
vec3 cameraVec = normalize(cameraPos - FragPos);
//specular
float specularAmount = pow(max(dot(reflectVec,cameraVec),0.0f),material.shininess);
vec3 specular = texture(material.specular,TextCoord).rgb*specularAmount*lightColorReal;

//deffuse
//vec3 diffuse =material.diffuse * max(dot(lightDir,Normal),0.0f)*lightColor;
vec3 diffuse = texture(material.diffuse,TextCoord).rgb* max(dot(lightDirReal,Normal),0.0f)*lightColorReal;

//ambient
vec3 ambient = texture(material.diffuse,TextCoord).rgb*ambientColor;

//emission
vec3 emission = texture(material.emission,TextCoord).rgb;

//FragColor = vec4((ambient+diffuse+specular)*objColor,1.0f)+vec4(emission,1.0f);
FragColor = vec4((ambient+diffuse+specular)*objColor,1.0f);

代码Git地址.

你可能感兴趣的:(opengl)