位置: 编程技术 - 正文

The graphics pipeline ,Open GL 渲染管线

编辑:rootadmin

推荐整理分享The graphics pipeline ,Open GL 渲染管线,希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

来源: Ever since the early days of real-time 3d, the triangle has been the paintbrush with which scenes have been drawn. Although modern GPUs can perform all sorts of flashy effects to cover up this dirty secret, underneath all the shading, triangles are still the medium in which they work. The graphics pipeline that OpenGL implements reflects this: the host program fills OpenGL-managed memory buffers with arrays of vertices; these vertices are projected into screen space, assembled into triangles, and rasterized into pixel-sized fragments; finally, the fragments are assigned color values and drawn to the framebuffer. Modern GPUs get their flexibility by delegating the “project into screen space” and “assign color values” stages to uploadable programs called shaders. Let’s look at each stage in more detail:

The vertex and element arrays A rendering job starts its journey through the pipeline in a set of one or more vertex buffers, which are filled with arrays of vertex attributes. These attributes are used as inputs to the vertex shader. Common vertex attributes include the location of the vertex in 3d space, and one or more sets of texture coordinates that map the vertex to a sample point on one or more textures. The set of vertex buffers supplying data to a rendering job are collectively called the vertex array. When a render job is submitted, we supply an additional element array, an array of indexes into the vertex array that select which vertices get fed into the pipeline. The order of the indexes also controls how the vertices get assembled into triangles later on.

Uniform state and textures A rendering job also has uniform state, which provides a set of shared, read-only values to the shaders at each programmable stage of the pipeline. This allows the shader program to take parameters that don’t change between vertices or fragments. The uniform state includes textures, which are one-, two-, or three-dimensional arrays that can be sampled by shaders. As their name implies, textures are commonly used to map texture images onto surfaces. They can also be used as lookup tables for precalculated functions or as datasets for various kinds of effects.

The vertex shader The GPU begins by reading each selected vertex out of the vertex array and running it through the vertex shader, a program that takes a set of vertex attributes as inputs and outputs a new set of attributes, referred to as varying values, that get fed to the rasterizer. At a minimum, the vertex shader calculates the projected position of the vertex in screen space. The vertex shader can also generate other varying outputs, such as a color or texture coordinates, for the rasterizer to blend across the surface of the triangles connecting the vertex.

Triangle assembly

The graphics pipeline ,Open GL 渲染管线

The GPU then connects the projected vertices to form triangles. It does this by taking the vertices in the order specified by the element array and grouping them into sets of three. The vertices can be grouped in a few different ways:

Take every three elements as an independent triangle Make a triangle strip, reusing the last two vertices of each triangle as the first two vertices of the next Make a triangle fan, connecting the first element to every subsequent pair of elements The diagram shows how the three different modes behave. Strips and fans both require only one new index per triangle in the element array after the initial three, trading the flexibility of independent triangles for extra memory efficiency in the element array.

Rasterization

The rasterizer takes each triangle, clips it and discards parts that are outside of the screen, and breaks the remaining visible parts into pixel-sized fragments. As mentioned above, the vertex shader’s varying outputs are also interpolated across the rasterized surface of each triangle, assigning a smooth gradient of values to each fragment. For example, if the vertex shader assigns a color value to each vertex, the rasterizer will blend those colors across the pixelated surface as shown in the diagram.

The fragment shader The generated fragments then pass through another program called the fragment shader. The fragment shader receives the varying values output by the vertex shader and interpolated by the rasterizer as inputs. It outputs color and depth values that then get drawn into the framebuffer. Common fragment shader operations include texture mapping and lighting. Since the fragment shader runs independently for every pixel drawn, it can perform the most sophisticated special effects; however, it is also the most performance-sensitive part of the graphics pipeline.

Framebuffers, testing, and blending A framebuffer is the final destination for the rendering job’s output. In addition to the default framebuffer OpenGL gives you to draw to the screen, most modern OpenGL implementations let you make framebuffer objects that draw into offscreen renderbuffers or into textures. Those textures can then be used as inputs to other rendering jobs. A framebuffer is more than a single 2d image; in addition to one or more color buffers, a framebuffer can have a depth buffer and/or stencil buffer, both of which optionally filter fragments before they are drawn to the framebuffer: Depth testing discards fragments from objects that are behind the ones already drawn, and stencil testing uses shapes drawn into the stencil buffer to constrain the drawable part of the framebuffer, “stencilling” the rendering job. Fragments that survive these two gauntlets have their color value alpha blended with the color value they’re overwriting, and the final color, depth, and stencil values are drawn into the corresponding buffers.

Conclusion That’s the process, from vertex buffers to framebuffer, that your data goes through when you make a single “draw” call in OpenGL. Rendering a scene usually involves multiple draw jobs, switching out textures, other uniform state, or shaders between passes and using the framebuffer’s depth and stencil buffers to combine the results of each pass. Now that we’ve covered the general dataflow of 3d rendering, we can write a simple program to see how OpenGL makes it all happen. Throughout the course of this tutorial, I’d love to get your feedback—let me know if it’s helping you or if anything doesn’t make sense.

Following the pipeline 1.PassingDatatotheVertexShaderThevertexshaderisthefirstprogrammablestageintheOpenGLpipelineandhasthedistinctionofbeingtheonlymandatorystageinthepipeline.VertexAttributesInGLSL,themechanismforgettingda

Tutorial 4: Shaders 本文源自:

FreeGLUT Tips: 详解 glutInit 的入口参数 问题前文我们遇到的问题是,如何正确地给glutInit()这个函数传递一个正确的入口参数,使它能够正确地初始化OpenGL环境。假设大家都在使用VisualC++。当

标签: The graphics pipeline ,Open GL 渲染管线

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

上一篇:openGL4.X 深度测试(depth testing) framebuffer中(opengl 4.2)

下一篇:Following the pipeline

  • 已缴纳车船税的车船在同一年度
  • 5月份企业所得税
  • 企业所得税法
  • 所有者权益分配流程
  • 合同资产和合同负债属于什么科目
  • 差额征税小规模免征增值税
  • 资产负债表怎么看营业收入
  • 本期缴纳上期应纳税额是自动生成的吗?
  • 工会经费计税依据是应发还是实发
  • 个税缴款三方协议
  • 个人资金借给企业
  • 多开的增值税发票交多少税
  • 主营业务收入包括哪些内容
  • 企业收回报废产品合法吗
  • 发票已开款项未入账有什么影响?
  • 简易计税项目是所有发票都是普票吗
  • 清单申报和专项申报的区别
  • 营改增后增值税专用发票抵扣规定
  • 纳税人为风险纳税人
  • 认证的增值税发票怎么做成账本格式
  • 电子发票详见清单怎么开
  • 个人所得税中薪资与实际工资有什么差别
  • 简易计税方法适用范围
  • 房屋装修费用计算器
  • 加工费计入什么费用
  • 视同销售收入和成本如何确认
  • 上年销项税额录错了,怎么调整
  • qqprotect.exe是什么进程?怎么结束此进程?
  • 负债类科目的分类
  • 在win7系统中怎样为另外一块硬盘安装系统
  • 企业长期借款的利息,有可能计入的科目有( )
  • win10 1909无法连接到这个网络
  • 谷歌浏览器插件中心
  • 个人出租有形动产怎么交税
  • 与取得收入无关的成语
  • 威斯康星州1976
  • ssm算前后端分离吗
  • 期初未缴纳税额怎么计算
  • redirect_uri参数错误的解决方法(必看)
  • 利得是什么举个例子
  • vue组件通信方法
  • 可行性研究报告合同属于什么合同
  • 个人所得税换了电脑后,重新录入,离职的人也要录入吗
  • python的series
  • 帝国cms灵动标签下拉框
  • 织梦可以放两套模板吗
  • 现金流量表利息支出
  • 损益类科目有哪些借贷方向
  • 收款人是否应当承担还款责任
  • 产品成本计算中最基本的方法是
  • 什么是雇主责任险保单
  • 营改增政策解答
  • 发生的费用
  • 代扣代缴的个人所得税在现金流量表
  • 什么叫短期投资
  • 初次建账应准备哪几种会计本
  • sql server的实例
  • myeclipse连接mysql失败
  • Windows10安装包下载
  • Linux安装MySQL教程(二进制分发版)
  • win7每次开机选系统
  • win8激活失败
  • ubuntu唤醒快捷键
  • centos怎么样
  • linux里chmod
  • win7电脑dpi怎么设置800
  • win8 蓝牙
  • win7笔记本触摸板怎么开启
  • Android游戏开发pdf
  • javascript HTML5 Canvas实现圆盘抽奖功能
  • nodejs 文件操作
  • 自定义仪表盘的价值
  • 数据库的基本操作实验报告
  • mongoose操作
  • Vuforia How To Use Android Plugins in Unity Apps
  • php curl获取cookie
  • python saga
  • python多进程多线程协程
  • 基于javascript创建导航页面
  • 进出口贸易产品种类
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设