位置: 编程技术 - 正文

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

  • 资产负债表不平衡如何查找
  • 个人所得税汇缴报告
  • 借款利息收入要开票吗
  • 对公账户可以支付给个人吗
  • 当月开票当月收款
  • 行政单位预算资金拨付流程
  • 应计利息会计分录处理
  • 广告公司可以开维修费吗
  • 销售产生的增值税
  • 一般纳税人的含税收入怎么算
  • 建筑企业小规模纳税标准
  • 小微企业享受优惠
  • 公司的钱怎么提现
  • 个体工商户经营所得税怎么申报
  • 有合同未收到租金税务如何处理?
  • 其他业务收入怎么填纳税申报表
  • 公司充加油卡发票税额为0 怎么入账
  • 一般进口货物的完税价格
  • 出口退税的计算题
  • 新公司第一年
  • 计提社保公司承担部分的会计分录
  • 深度操作系统的窗口管理器
  • 房产契税征收率
  • 增值税税率调整差额怎么计算
  • 餐饮的成本核算表格模板
  • 没有劳动合同不给工资怎么办
  • win10哪个版本流畅兼容性好
  • PHP:Memcached::addByKey()的用法_Memcached类
  • php://filter协议
  • 支付投资款怎么做账
  • 不确认收入的是
  • 自查补缴增值税如何申报
  • 公司当月申报的是下个月社保么
  • 外出经营活动税收管理
  • uniapp零基础小白到项目实战
  • 比特币形式投资是否诈骗
  • 企业用户怎么在电脑登录
  • 增值税在纳税申报表中怎么得出
  • 开了红字发票申请还要做进项税转出吗
  • 生产车间的辅助记录
  • mysql 数据库
  • sql server数字类型
  • 研发人员具备的条件
  • 小微企业所得税税率
  • 房地产企业收到定金是否要预缴税款
  • 代理记账的业务规范
  • 劳务费个人所得税怎么查
  • 补缴的土地价款怎么算费用
  • 差额征收的会计分录
  • 员工报销医药费怎么做会计分录
  • 营业执照已办理,公司章程在哪里找
  • 给客户优惠货款怎么写
  • 卖二手车怎么做账务处理
  • 员工外出培训报告范文
  • 收到其他企业投资是属于其他业务收入吗
  • 新准则印花税计提会计分录
  • 在建工程的进项税额不再分2年抵扣
  • 公司房租收据可以入账吗
  • 仓库货架应该计入什么科目
  • sql server数据库查询语句
  • windows vista界面
  • 通过zeno实现加速屏幕显示操作教程
  • 安装fedora33
  • ssh进入
  • centos安装编译环境
  • centos7安装软件包命令
  • fsc文件用什么软件打开
  • centos ssh升级
  • web标准化
  • opengl gpu编程
  • [置顶]电影名字《收件人不详》
  • uleb128、sleb128和uleb128p1编码格式介绍
  • javascript总结笔记
  • 带领大家学习javascript基础篇(一)之基本概念
  • flexable.js
  • 广西增值税发票查询平台
  • 广西职称申报系统入口220
  • 某地区土拍的楼盘有哪些
  • 什么情况下要交印花税
  • 年报汇算清缴怎么做
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设