位置: 编程技术 - 正文

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

  • 实收资本增加印花税怎么算
  • 什么是应交增值税
  • 小规模暂估入库的账务处理
  • 银行提供资金
  • 最新增值税申报表及附表下载
  • 银行回单手续费分录
  • 转让实物资产税务处理
  • 新个税年终奖怎么申报
  • 资产减值准备怎么转回
  • 资本公积是啥
  • 宜宾劳务公司有哪些
  • 出租车发票有出租车信息吗
  • 小规模纳税人代理销售税率是多少
  • 生产销售部门职责
  • 支付短期借款利息
  • 退税收入要不要交所得税?
  • 华为nova9值得买吗知乎
  • 中秋佳节发放职工福利的话语
  • 什么是冻结账户的情形
  • php类的作用
  • 佛洛勒斯岛在哪里
  • php字段
  • 企业重组的特殊性税务处理 税屋
  • jquery版本
  • 即征即退增值税属于政府补助吗
  • php技术和mysql怎么结合
  • php读取php文件内容
  • 小程序微信认证
  • 企业购买机器设备没有发票怎么办
  • 融资租赁的残值归出租人所有,为啥要减去租金限值
  • 个体工商户注册资本是多少
  • 个人出租非住房房产税
  • sql中drop的用法
  • 固定资产转在建工程
  • 劳务分包的三种形式
  • 是不是所有的发票都是一样的
  • MongoDB中MapReduce编程模型使用实例
  • 销售送客户礼物
  • 股东垫付的钱可以作为实收资本吗
  • 发票上的折扣是什么意思
  • 冲销以前月份的凭证
  • 公司借钱不还怎么办
  • 股权支付会计处理
  • 挂靠公司收的税费计入什么科目?
  • 办理股权转让需要多久时间
  • 税控设备全额抵减
  • 合同分三次付款怎么写
  • 公司销售部门购买产品
  • 小规模如何申报1个点
  • 固定资产清理账户借方
  • 地税报表如何填写
  • 工程施工中购入固定资产
  • 办公用品的发票可以抵扣吗
  • 公司固定资产如何核算
  • 销售废旧物资是否缴税 如何账务处理
  • 企业增资的流程
  • 建账的基本流程图
  • MySQL之Field‘***’doesn’t have a default value错误解决办法
  • sql servers
  • linux下mysql5.7.17最新稳定版本安装教程
  • xp电脑如何在网页打开
  • 电脑预读文件
  • linux中tailf命令
  • win8.1无法安装
  • Windows XP英文版序列号
  • 进程出现很多regsvr32
  • windows 自启动
  • linux病毒排查
  • win8文件夹选项在哪
  • 只用html和css
  • javascript如何学
  • vue3目录解析
  • 怎样用python
  • python错误代码
  • JavaScript中Object.prototype.toString方法的原理
  • 如何用nodejs搭建服务端
  • unity3ds
  • 苏州峰谷电怎么申请
  • 杭州市国税稽查三科科长
  • 土地要钻几回才能挖
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设