位置: 编程技术 - 正文

OpenGL super bible(5th) 学习笔记 -- 像素缓冲区对象(PBO)

编辑:rootadmin

推荐整理分享OpenGL super bible(5th) 学习笔记 -- 像素缓冲区对象(PBO),希望有所帮助,仅作参考,欢迎阅读内容。

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

在存储像素、纹理方面,像素缓冲区对象和纹理缓冲区对象非常相&#;。和所有缓冲区对象一样,它们都存储在GPU内存中,我们可以访问和填充像素缓冲区对象(PBO)。实际上,只有在绑定到一个像素缓冲区对象绑定点时,一个缓冲区才真正成为一个像素缓冲区对象。

第一个像素缓冲区对象绑定点时GL_PIXEL_PACK_BUFFER。当一个像素缓冲区对象被绑定到这个目标上时,任何读取像素的OpenGL操作都会从像素缓冲区对象中获得它们的数据。这些操作包括glReadPixels、glGetTexImage、glGetCompressedTexlmage。

第二个像素缓冲区对象绑定点是GL_PIXEL_UNPACK_BUFFER。当一个像素缓冲区对象被绑定到这个目标时,任何绘制像素的OpenGL操作都会向一个绑定的像素缓冲区对象中放入它们的数据。这些操作包括glTexImage*D、glTexSubImage*D、glCompressedTexImage*D 和glCompressedTexSubImage*D。

像素缓冲区对象是一个很好的容器,可以暂时存储GPU本地像素数据,但是要注意的是,在使用它们之前需要为他们分配存储空间。和其他所有缓冲区对象一样,要调用哪个glBufferData为这个缓冲区分配内存空间并用数据填充。

具体的使用缓冲区的步骤可以参考前一篇 OpenGL super bible(5th) 学习笔记 -- 缓冲区。

对于glBufferData(GL_PIXEL_PACK_BUFFER, pixelDataSize, pixelData, GL_DYNAMIC_COPY)需要补充的是关于它的的第二个参数:像素缓冲区对象经常用来存储来自一个渲染目次奥的2D图像、纹理和其他数据源。但是缓冲区对象本身是一维的,它们本质上没有宽度和高度。在为2D图像分配空间时,我们可以只是将宽度和高度相乘,再与像素大小相乘。即pixelDataSize = screenWidth * screenHeight * sizeof(unsigned int)

从缓冲区中读取像素数据

OpenGL super bible(5th) 学习笔记 -- 像素缓冲区对象(PBO)

当绘制内容在屏幕上进行显示时, 我们可能会需要在这些像素彻底消失之前再次取回。这样做的原因之一是检查实际的渲染情况,以便确定接下来在屏幕上如何进行渲染,另外一个原因则是在应用到后续帧的效果中使用前面帧的像素。无论什么原因,glReadPixes函数都能发挥作用。

void glReadPixels(GLint x, GLint y, GLsizei width, GLsizei height, GLenum format, GLenum type, GLvoid * data);

根据这个函数的data参数的不同,这个函数可以发挥两种截然不同的作用:

(1)当data不为NULL时,这个函数表示从当前启用的读取缓冲区的特定位置读取像素,然后将他们复制到CPU内存中。(不使用PBO)

这里是将读取的像素复制到CPU内存中是因为pixelData是在内存中分配的空间。

当我们想客户端内存进行写入时, 整个管线经常需要被清空, 以保证所有会影响我们将要进行读取的绘制工作能够完成,这对于应用程序性能可能会有很大的冲击。所以我们就有了使用缓冲区对象来克服这种性能问题。也就是下面一种高效的方法。

(2)当data为NULL是,能够将屏幕的像素重定向到GPU中的一个缓冲区中,即从屏幕像素的缓冲区到我们绑定的像素缓冲区,实现了只在GPU之间移动数据,避免了复制到客户端内存上可能带来的性能问题。(使用PBO)

在下面的使用像素缓冲区的示例应用程序中,我们将展示这两种方法的使用。

使用PBO的示例程序 -- 运动模糊

运动模糊(Motion blur)是一种特效,它有助于显示出一个场景中哪些对象是运动的,以及他们运动得有多快。这里我们使用一种简单的方法,将前面的帧的结果进行存储并与当前帧的结果混合到一起(这里就算是上面从缓冲区中读取像素数据的第二个原因:在应用到后续帧的效果中使用前面帧的像素)。

为了创建可视的运动模糊,这个程序将会存储最后的5帧图像。这个程序既可以使用老式的方式将数据复制到CPU中再复制出来,也可以使用更快的PBO方式(既上面的glReadPixels函数中参数data的不同赋&#;)。

Lane-学习OpenGL(1)-七个简单例子 在看了许多实例之后,准备沿着OpenGL编程指南(第七版)学习OpenGL.运行环境:(1)Windows7(2)CodeBlocks(3)GLUT(4)Author:Lane--.黑色背景加白色矩形核心函数:glOrtho.

openGL ES 2.0 3维物体的平移(II) 好了、ok、这两天学习了OpenGLes2.0之中的3D物体的平移、旋转、缩放大小等等,其实吧、个人感觉D3D和OpenGLES2.0就目前学习到的这些知识来讲,还是相差不

openGL ES 2.0 点与点之间的绘制方式(III) ShaderUtil.java文件:packagecom.example.sample_5_5_mine;importjava.io.ByteArrayOutputStream;importjava.io.InputStream;importandroid.content.res.Resources;importandroid.opengl.GLES;importandroid.u

标签: OpenGL super bible(5th) 学习笔记 -- 像素缓冲区对象(PBO)

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

上一篇:OpenGl学习之坐标变换(上)(opengl绘制坐标轴)

下一篇:Lane-学习OpenGL(1)-七个简单例子(opengles入门)

  • 代扣代缴个人所得税手续费返还 增值税
  • 买赠怎么做会计分录
  • 个体户需要做利润分析吗
  • 外币实收资本入账汇率
  • 出口退税是按照出口金额吗
  • 汽车租赁服务开发票税率
  • 集团内部资产无偿划转是否纳税增值税
  • 发票查询发票代码有误
  • 全年累积盈利交所得税吗?
  • 充值给予的优惠怎么用
  • 年末转出未交增值税的视频
  • 生产共同费用每个月都有摊销吗?
  • 购买股权支付的相关税费怎么处理
  • 个人所得税减半征收
  • 母子公司可以汇资金吗
  • 应交税金增值税明细账怎么登记
  • 两个立项可以并在一起招标吗
  • 非金融机构有
  • 应收账款账龄分析简单例题
  • 增资印花税税目
  • 计提应收票据利息怎么算
  • 单位预算支出包括哪些
  • 新会计准则下建筑业会计科目设置
  • tplink路由器手机怎么设置
  • 利润表中哪些属于营业外收入
  • 母公司投资子公司怎么做账
  • php中数组的常用函数及用法
  • php支付接口开发
  • 跨年会计科目用什么软件
  • schost.exe - schost是什么进程 有什么用
  • php curl_multi_init
  • kernel32在哪个文件夹
  • repair.exe是什么软件
  • 财务人员如何审核招待费报销单
  • 期票是不是承兑汇票
  • 二级路由器怎么配置
  • 安格雷尔
  • php进程数设置
  • 工程分包合同
  • php中的九大缓存技术
  • 气象数据32766
  • 先发货再开票
  • 反斜杠python
  • 建行e信通怎么提现怎么操作
  • css实现文字颜色渐变
  • nodejs写后端接口
  • 成本票不够怎么交税
  • 印花税申报成功后在哪缴税
  • 电子承兑利息
  • 预提费用待摊费用改为什么科目
  • 小规模季度必须报税吗
  • 织梦怎么建站
  • 印花税核定征收比例取消了吗
  • 企业所得税成本核定
  • 经济利益的总流入
  • sql server如何进行安全设置
  • 劳保用品费用计入什么科目
  • 销项100万进项80万交多少税
  • 金蝶利息收入的正确分录
  • 年金现值系数和复利现值系数的公式
  • 水果店的账务处理
  • 小微企业未开票收入怎么申报
  • 私人公司盈利怎么把钱拿出来
  • fedora iso
  • bios中英文对照表图新版
  • iexplores.exe是什么病毒
  • win7禁用administrator登录
  • win10磁盘占用100%卡死
  • Linux下使用quota命令管理磁盘空间的实例教程
  • linux w
  • w10安装软件提示
  • opengl怎么学
  • js写贪吃蛇什么水平
  • android广播接收器数量达到1000
  • 关于javascript的说法
  • node cd
  • python读写docx
  • jquery js区别
  • 使用粗盐热敷十大危害
  • 江苏国家电子税务局新版本怎么申领发票
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设