OpenGL学习二十五:像素存储模式

内存对齐:
字长32位的计算机上,如果数据在内存中按照32位的边界对齐(地址为4字节的倍数),那么硬件提取数据的速度就会快得多,类似的在64位计算机上,如数据地址按照8字节对齐,他对数据存取效率会非常高

举例:图像每行按照4字节方式进行存储,如果图像宽度是5个像素。RGB各占一个字节,那么每行=5*3=15个字节,按照4字节方式存储每行会浪费一个自己的存储空间

如果每行按照1字节方式存储,每一行的数据都是从下一个可用的字节开始存储,这样虽然不会浪费内存空间,但是性能不能4字节的好,同理2字节方式数据的起始地址是2的倍数


举例2:如果每个像素保存1位数据,行长度是75,如果对齐值是4,那么最小4的倍数且大于75/8的12 也就是说每行需要12个字节。如果对齐值是1 那么最小4的倍数且大于75/8的10 也就是说每行需要10个字节

glPixelStore{if}(Glenum pname,TYPE param)


glPixelStore参数
GL_UNPACK_SWAP_BYTES,GL_PACK_SWAP_BYTES如果为TRUE 字节翻转存储
GL_UNPACK_LSB_FIRST,GL_PACK_LSB_FIRST如果为FALSE 字节从最高有效位存储0x31为{0,0,1,1,0,0,0,1}
如果为true 字节从最高有效位存储0x31为{1,0,0,0,1,1,0,0}
GL_UNPACK_ROW_LENGTH,GL_PACK_ROW_LENGTH当从内存读取矩形的图像数据小于内存图像数据矩形实际长度,需要设置这个值进行指定,如果这个值为0,使用glDrawPixels,glCopyPixels,glReadPiexls所指定的宽度值
GL_UNPACK_SHIP_ROWS,GL_PACK_SHIP_ROWS如果从内存读取的子矩形图形数据并不是从0,0开始作为起点,使用这个进行设置起始点(ROW)
GL_UNPACK_SHIP_PIXELS,GL_PACK_SHIP_PIXELS如果从内存读取的子矩形图形数据并不是从0,0开始作为起点,使用这个进行设置起始点(COL)
GL_UNPACK_ALIGNMENT,GL_PACK_ALIGNMENT设置内存对其方式
GL_UNPACK_IMAGE_HEIGHT,GL_PACK_IMAGE_HEIGHT
GL_UNPACK_SKIP_IMAGE,GL_UNPACK_SKIP_IMAGE

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

寻找幸存者

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值