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地址.

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值