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

你可能感兴趣的:(OpenGL)