位置: 编程技术 - 正文

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

  • 企业所得税的征税对象包括
  • 政府补助属于不征收收入汇算清缴怎么填写
  • 现金流量表填报说明
  • 分公司是否需要刻章
  • 水利建设基金的计税依据
  • 企业资产重组是不定期清查吗
  • 固定资产报废的会计科目
  • 年度利润总额的12%
  • 负债必须通过转让来清偿
  • 保障房异地建设费缴纳契税吗?
  • 代扣代缴附加税怎么做账
  • 支付股权投资的会计科目
  • 公司收到法院的欠款起诉书,应该怎么办
  • 提前退休获得一次性补贴要交个人所得税吗?
  • 一般纳税人的主表
  • 福利费开成增值税专用发票怎么办
  • 勒索病毒文件怎么恢复
  • 利润的计算公式excel
  • 农业生产用水水资源税
  • windows 11截图
  • php-msf
  • 未开票的销售收入分录
  • linux怎样安装
  • 持有至到期投资减值准备
  • 如何选购餐桌椅
  • 路由器重启以后wifi不见了
  • 百度地图经纬度导航
  • php imagecopymerge
  • 准备金要求定义
  • ant design pro项目构建纯净版
  • 表格uplook
  • php的strcmp
  • 资产证券化 会计处理
  • 计提折旧事考虑了残值净值怎么算
  • php实现文件上传需要使用哪个全局变量
  • 登录页面的实现方式
  • 人工智能机器人
  • 无形资产法
  • 爬虫失败的原因
  • 已勾选确认的发票忘记填写怎么办
  • phpcms手机端
  • 直播服务费的开票大类
  • 预收账款的账务处理摘要
  • 年度一次性奖励扣税
  • 保单的增值税发票能抵税吗
  • 劳务公司包工包料工程如何账务处理
  • sqlserver附加数据库语句
  • 服务器配置mysql
  • 纳税调整调减有哪些
  • 收到销售方负数发票可以次月入账吗
  • 施工单位代建收费合理吗
  • 实收资本未实缴是否罚款
  • 应交增值税明细表公式
  • 代理记账公司能赚钱吗
  • 个体工商户建账流程
  • 原始凭证的主要内容包括
  • sqlserver批量备份数据库
  • SQL Server 2012 sa用户登录错误18456的解决方法
  • mdf文件在哪
  • mysql查询id最大的记录
  • 数据库left joins
  • centos7.2安装
  • windows怎么安装apk
  • centos 6.5网络设置
  • quicktimeplayer.exe - quicktimeplayer是什么进程 有什么用
  • win8 网络连接
  • 收不到windows的验证码
  • win7的收藏夹在哪里
  • 如何将win7系统装进移动硬盘
  • linux系统的服务器,重启之后运算速度变慢
  • windows8装windows10,文件会丢失吗
  • perl常用函数
  • js按下键盘事件
  • python引用方法
  • c# 查找字符串
  • vue实现淘宝布局
  • nodejs实例教程
  • javascript 二维数组搜索
  • 查税务在哪里查
  • 资源税的作用是什么?
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设