glCopyTexImage1D 函数

glCopyTexImage1D 函数将帧缓冲区中的像素复制到一维纹理图像中。

语法

void WINAPI glCopyTexImage1D(
   GLenum  target,
   GLint   level,
   GLenum  internalFormat,
   GLint   x,
   GLint   y,
   GLsizei width,
   GLint   border
);

parameters

目标

将为其更改图像数据的目标。 必须具有值GL_TEXTURE_1D。

level

详细级别编号。 级别 0 是基本映像。 级别 n第 n 个 mipmap 缩减图像。

internalFormat

纹理数据的内部格式和分辨率。 此参数必须是以下符号值之一。

一直 R 位 G 位 B 位 L 位 I 位
GL_ALPHA
GL_ALPHA4 4
GL_ALPHA8 8
GL_ALPHA12 12
GL_ALPHA16 16
GL_LUMINANCE
GL_LUMINANCE4 4
GL_LUMINANCE8 8
GL_LUMINANCE12 12
GL_LUMINANCE16 16
GL_LUMINANCE_ALPHA
GL_LUMINANCE4_ALPHA4 4 4
GL_LUMINANCE6_ALPHA2 2 6
GL_LUMINANCE8_ALPHA8 8 8
GL_LUMINANCE12_ALPHA4 4 12
GL_LUMINANCE12_ALPHA12 12 12
GL_LUMINANCE16_ALPHA16 16 16
GL_INTENSITY
GL_INTENSITY4 4
GL_INTENSITY8 8
GL_INTENSITY12 12
GL_INTENSITY16 16
GL_RGB
GL_R3_G3_B2 3 3 2
GL_RGB4 4 4 4
GL_RGB5 5 5 5
GL_RGB8 8 8 8
GL_RGB10 10 10 10
GL_RGB12 12 12 12
GL_RGB16 16 16 16
GL_RGBA
GL_RGBA2 2 2 2 2
GL_RGBA4 4 4 4 4
GL_RGB5_A1 5 5 5 1
GL_RGBA8 8 8 8 8
GL_RGB10_A2 10 10 10 2
GL_RGBA12 12 12 12 12
GL_RGBA16 16 16 16 16

x

要复制的像素行左下角的窗口 x 平面坐标。

y

要复制的像素行左下角的窗口 y 平面坐标。

width

纹理图像的宽度。 对于某些整数 n,必须为零或 2n + 2 (边框) 。 纹理图像的高度为 1。

边境

边框的宽度。 必须为零或 1。

返回值

此函数不返回值。

错误代码

glGetError 函数可以检索以下错误代码。

名称 含义
GL_INVALID_ENUM
target 不是接受的值。
GL_INVALID_VALUE
级别 小于零或大于 log2 max,其中 max 是返回GL_MAX_TEXTURE_SIZE的值。
GL_INVALID_VALUE
边框 不是零或 1。
GL_INVALID_VALUE
宽度 小于零,大于 2 + GL_MAX_TEXTURE_SIZE ,或者不能 将宽度表示为 2n + (边框) 某些整数 n
GL_INVALID_OPERATION
在对 glBegin 的调用和 对 glEnd 的相应调用之间调用了该函数。

注解

glCopyTexImage1D 函数使用当前帧缓冲区中的像素(而不是主内存)定义一维纹理图像,就像 glTexImage1D 一样。

使用 通过级别指定的 mipmap 级别,纹理数组定义为一个像素行,该行与 xy 指定的坐标处的窗口左下角对齐,长度等于 宽度 + 2 * 边框。 纹理数组的内部格式是使用 internalFormat 参数指定的。

glCopyTexImage1D 函数以与 glCopyPixels 相同的方式处理行中的像素,除了像素的最终转换之前,所有像素组件值都固定到范围 [0,1] 并转换为纹理的内部格式,以便在纹理数组中存储。 像素排序是使用与较低纹理坐标对应的 下 x 坐标确定的。 如果当前帧缓冲区的指定行中的任何像素位于与当前呈现上下文关联的窗口之外,则其值是未定义的。

不能在显示列表中包括对 glCopyTexImage1D 的调用。

注意

glCopyTexImage1D 函数仅在 OpenGL 1.1 或更高版本中可用。

着色模式在颜色索引模式下不起作用。 glPixelStoreglPixelTransfer 函数会按照它们影响 glDrawPixels 的方式影响纹理图像。

以下函数检索与 glCopyTexImage1D 相关的信息:

带参数GL_TEXTURE_1D的 glIsEnabled

要求

要求
最低受支持的客户端
Windows 2000 Professional [仅限桌面应用]
最低受支持的服务器
Windows 2000 Server [仅限桌面应用]
标头
Gl.h

Opengl32.lib
DLL
Opengl32.dll

另请参阅

glCopyPixels

glCopyTexImage2D

glDrawPixels

glFog

glPixelStore

glPixelTransfer

glTexEnv

glTexGen

glTexImage1D

glTexImage2D

glTexParameter