转载请注明出处:http://blog.csdn.net/tianhai110

点光源光照模型:

公式:

I = Icolor*attenuation;                        attenuation表示衰减值

Attenuation = 1-d*d;                                       d为光源到该点的距离

通常我们用一个r来做点光源的衰减范围

及 attenuation = 1 - mul(Light/r, Light/r);

对Phong光照的例子进行修改

  1. vecLightDir 改名为 vecLightPos 表示光源位置,而不是光的方向; 设置其值如下:

  

  2. 修改vertex shader;

  1. float4x4 matViewProjection;
  2. float4x4 matWorld;
  3. float4   vecLightPos;
  4. float4   vecEye;
  5. struct VS_INPUT
  6. {
  7. float4 Position : POSITION0;
  8. float3 Normal   : NORMAL0;
  9. float2 Texcoord : TEXCOORD0;
  10. };
  11. struct VS_OUTPUT
  12. {
  13. float4 Position : POSITION0;
  14. float2 Texc     : TEXCOORD0;
  15. float3 Light    : TEXCOORD1;
  16. float3 Norm     : TEXCOORD2;
  17. float3 View     : TEXCOORD3;
  18. };
  19. VS_OUTPUT vs_main( VS_INPUT Input )
  20. {
  21. VS_OUTPUT Output;
  22. Output.Position = mul( Input.Position, matViewProjection );
  23. float3 posWorld = normalize(mul(Input.Position, matWorld));
  24. Output.Light = vecLightPos - posWorld;
  25. Output.View = vecEye - posWorld;
  26. Output.Norm = mul(Input.Normal, matWorld);
  27. Output.Texc = Input.Texcoord;
  28. return( Output );
  29. }

主要就是 把outPut.Light 由原来直接传个方向,变成每次都要计算该点到光源的向量;

  3. 修改 pixel shader;

  1. sampler2D baseMap;
  2. float4 ps_main( float2 Texc:TEXCOORD0, float3 Light:TEXCOORD1,
  3. float3 Norm:TEXCOORD2, float3 View:TEXCOORD3) : COLOR0
  4. {
  5. float4 ambient = { 0.3686f, 0.3686f, 0.3686f, 1.0f};
  6. float4 diffuse = { 0.88f, 0.88f, 0.88f, 1.0f};
  7. float3 Normal = normalize( Norm);
  8. float3 LightDir = normalize( Light);
  9. float3 ViewDir = normalize( View);
  10. float4 diff = saturate( dot( Normal, LightDir));
  11. float3 Reflect = normalize( 2 * diff * Normal - LightDir);
  12. float4 shadow = saturate(4*diff);
  13. float4 fvBaseColor      = tex2D( baseMap, Texc );
  14. float4 specular = pow(saturate(dot(Reflect, ViewDir)), 25);
  15. float4 color = fvBaseColor * (shadow * diff + ambient) + shadow * specular;
  16. float4 attenuation = mul(Light/64.0, Light/64.0);
  17. return color*(1-attenuation);
  18. }

主要是 加入衰减值 float4 attenuation = mul(Light/64.0, Light/64.0);

  4. 运行效果如下:

  

一步一步学RenderMonkey(4)--点光源光照模型 【转】的更多相关文章

  1. 一步一步学ROP之linux_x64篇

    一步一步学ROP之linux_x64篇 一.序 **ROP的全称为Return-oriented programming(返回导向编程),这是一种高级的内存攻击技术可以用来绕过现代操作系统的各种通用防 ...

  2. 一步一步学ROP之linux_x86篇

    一步一步学ROP之linux_x86篇 作者:蒸米@阿里聚安全 ​ 一.序 ROP的全称为Return-oriented programming(返回导向编程),这是一种高级的内存攻击技术可以用来绕过 ...

  3. (转载)一步一步学Linq to sql系列文章

    现在Linq to sql的资料还不是很多,本人水平有限,如果有错或者误导请指出,谢谢. 一步一步学Linq to sql(一):预备知识 一步一步学Linq to sql(二):DataContex ...

  4. 一步一步学ZedBoard & Zynq(四):基于AXI Lite 总线的从设备IP设计

    本帖最后由 xinxincaijq 于 2013-1-9 10:27 编辑 一步一步学ZedBoard & Zynq(四):基于AXI Lite 总线的从设备IP设计 转自博客:http:// ...

  5. 一步一步学android控件(之十五) —— DegitalClock & AnalogClock

    原本计划DigitalClock和AnalogClock单独各一篇来写,但是想想,两个控件的作用都一样,就和在一起写一篇了. DegitalClock和AnalogClock控件主要用于显示当前时间信 ...

  6. 一步一步学Remoting系列文章

    转自:http://www.cnblogs.com/lovecherry/archive/2005/05/24/161437.html (原创)一步一步学Remoting之一:从简单开始(原创)一步一 ...

  7. 一步一步学android控件(之十六)—— CheckBox

    根据使用场景不同,有时候使用系统默认的CheckBox样式就可以了,但是有时候就需要自定义CheckBox的样式.今天主要学习如何自定义CheckBox样式.在CheckBox状态改变时有时需要做一些 ...

  8. 一步一步学Python(2) 连接多台主机执行脚本

    最近在客户现场,每日都需要巡检大量主机系统的备库信息.如果一台台执行,时间浪费的就太冤枉了. 参考同事之前写的一个python脚本,配合各主机上写好的shell检查脚本,实现一次操作得到所有巡检结果. ...

  9. 【DG】[三思笔记]一步一步学DataGuard

    [DG][三思笔记]一步一步学DataGuard 它有无数个名字,有人叫它dg,有人叫它数据卫士,有人叫它data guard,在oracle的各项特性中它有着举足轻理的地位,它就是(掌声)..... ...

随机推荐

  1. 一个大div里面包裹一个小div,里面的小div的点击事件不触发外面的这个大div的点击事件

    一开始上html代码 <div id="div1" style="background: blue;width: 100px; height: 100px;&quo ...

  2. 辨析各类web服务器:Apache/Tomcat/Jboss/Nginx/等,还有Nodejs

    先说一下各类服务器能干啥,特点是啥,然后在区分他们的类别. (1)Apache: Apache是指Apache软件基金会的Apache HTTP Server, 它能够接收http请求,然后返回各类资 ...

  3. Apache配置基于端口号的虚拟主机 Apache virtual host configuration is based on the port

    有可能只有一个ip出口,但却有多个项目,那么就需要基于端口号架设虚拟主机. Step 1: 检查是否开启 httpd-vhosts.conf apache/conf/httpd.conf文件 # Vi ...

  4. POJ 2777 Count Color(线段树 + 染色问题)

    传送门:Count Color Description Chosen Problem Solving and Program design as an optional course, you are ...

  5. LOJ #6279. 数列分块入门 3-分块(区间加法、查询区间内小于某个值x的前驱(比其小的最大元素))

    #6279. 数列分块入门 3 内存限制:256 MiB时间限制:1500 ms标准输入输出 题目类型:传统评测方式:文本比较 上传者: hzwer 提交提交记录统计测试数据讨论 3   题目描述 给 ...

  6. SQL练习总结

    [SQL语句练习] 1. 表1: Person +-------------+---------+ | 列名 | 类型 | +-------------+---------+ | PersonId | ...

  7. 大数据技术之_11_HBase学习_02_HBase API 操作 + HBase 与 Hive 集成 + HBase 优化

    第6章 HBase API 操作6.1 环境准备6.2 HBase API6.2.1 判断表是否存在6.2.2 抽取获取 Configuration.Connection.Admin 对象的方法以及关 ...

  8. Mysql远程连接报错:SQL Error (1130): Host '192.168.6.128' is not allowed to connect to this MySQL server

    通过SQLyog连接linux中的MySQL报错问题:SQL Error (1130): Host '192.168.6.128' is not allowed to connect to this ...

  9. 更改Xamarin Android App名称

    更改Xamarin Android App名称   Xamarin Android生成的App名称默认和项目名一致.修改该名称有两种方式.   第一种方式:右击Android项目,选择“属性”命令,然 ...

  10. 背包问题(dp基础)

    题目描述: 在N件物品取出若干件放在容量为W的背包里,每件物品的体积为W1,W2……Wn(Wi为整数),与之相对应的价值为P1,P2……Pn(Pi为整数).求背包能够容纳的最大价值. Input 第1 ...