位置: 编程技术 - 正文

在OpenGL中给场景添加光照(opengl sphere)

编辑:rootadmin
在OpenGL中给场景添加光照 为了在OpenGL中使用光照计算,我们需要调用glEnable方法,并用GL_LIGHTING作为参数。这个调用告诉OpenGL在确定场景中每个顶点的颜色时使用光照参数和材料属性。当然,如果我们没有指定任何光照参数和材料属性,那么物体仍将会保持为黑暗的无光照状态。 // 启用光照 glEnable(GL_LIGHTING); 一、设置环境光 OpenGL提供了一个全局光源,它只发射环境光。这种光源很有用,它可以照射没有被其它光源直接照射的物体的背面,并且如果场景看上去太暗,可以调节这种全局环境光,以达到自己所需要的亮度。设置全局环境光的代码如下所示: // 指定环境光的RGBA强度&#; GLfloat ambientLight[] = {1.0f, 1.0f, 1.0f, 1.0f}; // 设置光照模型,将ambientLight所指定的RGBA强度&#;应用到环境光 glLightModelfv(GL_LIGHT_MODEL_AMBIENT, ambientLight); glLightModel方法使用指定的参数来设置光照模型。它的第一个参数是需要设置的光照模型,在这里我们指定的是环境光(ambient);接下来的一个参数包含了组成光源的RGBA强度&#;,也就是我们设置的ambientLight。 全局环境光的默认RGBA&#;是(0.2, 0.2, 0.2, 1.0),这是一种较暗的光。其它光照模型参数允许我们指定多边形是正面还是背面被照射,或者是两面都被照射,以及指定如何计算镜面光的角度等。 二、设置材料属性 当有了环境光源之后,我们还需要设置材料属性,只有设置了材料属性,我们的多边形才可以反射光线。 设置材料属性可以使用两种方法,第一种是在指定每个多边形或每组多边形之前使用glMaterial方法。代码如下所示: GLfloat gray[] = {0.f, 0.f, 0.f, 1.0f}; glMaterialfv(GL_FRONT, GL_AMBIENT_AND_DIFFUSE, gray); glBegin(GL_TRIANGLES); ... glEnd(); glMaterial方法的第一个参数指定了材料属性是作用于正面、背面还是双面(GL_FRONT、GL_BACK、GL_FRONT_AND_BACK);第二个参数指定将要设置环境光和散射光的反射率,在这里它们被设置为相同的&#;;最后一个参数是数组,包含了构成材料属性的RGBA&#;。在大多数情况下,环境光和散射光成分是相同的。 第二种设置材料属性的方法,称为颜色追踪。使用颜色追踪,可以告诉OpenGL仅仅通过调用glColor方法来设置材料属性。依旧使用glEnable方法来启用颜色追踪: // 启用颜色追踪 glEnable(GL_COLOR_MATERIAL); // 设置多边形正面的环境光和散射光属性,追踪glColor方法所设置的颜色 glColorMaterial(GL_FRONT, GL_AMBIENT_AND_DIFFUSE); glColor(0.f, 0.f, 0.f); glBegin(GL_TRIANGLES); ... glEnd(); 接着,glColorMaterial函数根据glColor所设置的颜色&#;来指定材料参数。这里有很重要的一点,那就是物体材料的颜色成分实际上决定了入射光的反射比例,正是这一点确保了颜色追踪的可行性。设置完整渲染状态的代码如下所示: void SetupRC() { glEnable(GL_DEPTH_TEST); glFrontFace(GL_CCW); glEnable(GL_CULL_FACE); // 启用光照计算 glEnable(GL_LIGHTING); // 指定环境光强度(RGBA) GLfloat ambientLight[] = {1.0f, 1.0f, 1.0f, 1.0f}; // 设置光照模型,将ambientLight所指定的RGBA强度&#;应用到环境光 glLightModelfv(GL_LIGHT_MODEL_AMBIENT, ambientLight); // 启用颜色追踪 glEnable(GL_COLOR_MATERIAL); // 设置多边形正面的环境光和散射光材料属性,追踪glColor glColorMaterial(GL_FRONT, GL_AMBIENT_AND_DIFFUSE); glClearColor(0.0f, 0.0f, 0.5f, 1.0f); } 这一部分的示例程序完整代码已经放到了GitHub上,有需要的朋友可以参考一下( 本文出自杜晓萌的博客,请勿用于任何商业用途,转载请保持完整性并标明出处:

推荐整理分享在OpenGL中给场景添加光照(opengl sphere),希望有所帮助,仅作参考,欢迎阅读内容。

在OpenGL中给场景添加光照(opengl sphere)

文章相关热门搜索词:opengl简单场景,opengl sphere,opengl做界面,opengl做界面,opengl示例,opengl场景建模,opengl 实现,opengl场景建模,内容如对您有帮助,希望把文章链接给更多的朋友!

搭建Qt下的OpenGL编程框架 转载:

opengl GLSL 学习 随笔三 1、类型修饰符const表示该变量为常量,只读;in表示该变量是一个输入在当下的shaderstage;out表示该变量是一个输出在当下的shaderstage;uniform表示该变量

opengl GLSL基本语法 学习 随笔二 1、首先介绍一下GLSL的数据类型,如果你学过c,那么一定不会陌生。floatdoubleintuintbool型几个数据类型;基本上从字面上就能理解这几个数据类型的含义。

标签: opengl sphere

本文链接地址:https://www.jiuchutong.com/biancheng/373171.html 转载请保留说明!

上一篇:openGL ES 2.0 初始化(I)(opengl es3.0)

下一篇:搭建Qt下的OpenGL编程框架(qt配置opengl)

  • 2023增值税最新税率
  • 缴纳印花税的会计凭证
  • 实收资本在报表中怎么看
  • 附加税扣款比例
  • 需要冲红的普通发票无法收回怎么办
  • 季度申报残保金怎么填写
  • 分包部分也享受价格优惠
  • 研发费用在企业所得税中怎么扣除
  • 制造企业发出材料成本的计价方法
  • 财务报表有哪些局限性
  • 劳务发票属地原则
  • 营改增后加工行业的税率是多少?
  • 前期差错更正中所得税的会计处理
  • 收到测试费几分钱如何做账
  • 成本/利润
  • 跨年度的费用发票怎么做账
  • 投资利税率计算器在线计算
  • 可持续增长率计算例题
  • 财务报表批准日是哪一天
  • 计算消费税要价税分离吗
  • 小规模纳税人会计核算健全,能够提供准确
  • 销售退货怎么开红字
  • 怎么计算房地产成本单价
  • 库存商品过期报损
  • 出口0税率是免抵退还是免税
  • 汇丰银行账户管理费
  • win11如何多窗口
  • win11粘滞键怎么关闭 重启后又有
  • windows11如何进入启动设置
  • 支付汽车耗材费怎么入账
  • 事业单位工会会员费如何计算
  • 对于接受捐赠的固定资产,其成本应当依次按照
  • dae是什么文件
  • 属于资本的是
  • 外贸企业申报出口退税的期限
  • async/await原理
  • laravel datatable
  • 公司购垃圾袋怎么做账
  • vue自定义dialog
  • 前端跨域解决方案设计
  • vue定时调用方法
  • ChatGPT中国电话不能注册
  • 工会组织机构需要备案吗
  • 发票抬头为个人的纳税人识别号
  • sQlite常用语句以及sQlite developer的使用与注册
  • 深入解读何暮楚
  • 社保代扣代缴的办理流程
  • 购房补贴退契税3个月没到账
  • 资本公积形成的原因有哪些
  • 暂估入库结转成本后如何冲红
  • 房租收入税费
  • 一般纳税人税种核定表
  • 债权投资减值准备是什么科目
  • 销售单位收入和税收
  • 小规模纳税人是开专票还是普票
  • 会计中结转属于什么科目
  • mysql拆表迁移数据
  • 透明数据网
  • win10如何连接远程电脑
  • mac 显示器
  • freebsd 安装
  • 联想lenovo thinkpad c13 yoga
  • centos7配置vncserver
  • 只需2招 让Win10运行速度更加迅速
  • cocos 2d x
  • js原生实现ajax
  • vue导航组件
  • Python的flask框架教程
  • jquery实现输入框自限制
  • Express + Session 实现登录验证功能
  • vr project
  • javascript规范
  • js创建对象的方法有哪些
  • jquery页面关闭事件
  • 税务局稽查科是干什么的工作
  • 贸易公司税收政策
  • 四川省地税局地址
  • 如何证明发货前货物完好
  • 小孩一卡通丢了去哪里补办,需要什么证件
  • 潍坊特殊工种退休公示名单九月
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设