mirror of
https://github.com/Ryujinx/Opentk.git
synced 2025-01-13 12:25:33 +00:00
183 lines
9.1 KiB
XML
183 lines
9.1 KiB
XML
|
<?xml version="1.0" encoding="UTF-8"?>
|
||
|
<!DOCTYPE book PUBLIC "-//OASIS//DTD DocBook MathML Module V1.1b1//EN"
|
||
|
"http://www.oasis-open.org/docbook/xml/mathml/1.1CR1/dbmathml.dtd">
|
||
|
<refentry id="glFramebufferTexture2D">
|
||
|
<refmeta>
|
||
|
<refentrytitle>glFramebufferTexture2D</refentrytitle>
|
||
|
<manvolnum>3G</manvolnum>
|
||
|
</refmeta>
|
||
|
<refnamediv>
|
||
|
<refname>glFramebufferTexture2D</refname>
|
||
|
<refpurpose>attach a texture image to a framebuffer object</refpurpose>
|
||
|
</refnamediv>
|
||
|
<refsynopsisdiv><title>C Specification</title>
|
||
|
<funcsynopsis>
|
||
|
<funcprototype>
|
||
|
<funcdef>void <function>glFramebufferTexture2D</function></funcdef>
|
||
|
<paramdef>GLenum <parameter>target</parameter></paramdef>
|
||
|
<paramdef>GLenum <parameter>attachment</parameter></paramdef>
|
||
|
<paramdef>GLenum <parameter>textarget</parameter></paramdef>
|
||
|
<paramdef>GLuint <parameter>texture</parameter></paramdef>
|
||
|
<paramdef>GLint <parameter>level</parameter></paramdef>
|
||
|
</funcprototype>
|
||
|
</funcsynopsis>
|
||
|
</refsynopsisdiv>
|
||
|
<refsect1 id="parameters"><title>Parameters</title>
|
||
|
<variablelist>
|
||
|
<varlistentry>
|
||
|
<term><parameter>target</parameter></term>
|
||
|
<listitem>
|
||
|
<para>Specifies the framebuffer target. The symbolic constant must be
|
||
|
<constant>GL_FRAMEBUFFER</constant>.</para>
|
||
|
</listitem>
|
||
|
</varlistentry>
|
||
|
<varlistentry>
|
||
|
<term><parameter>attachment</parameter></term>
|
||
|
<listitem>
|
||
|
<para>Specifies the attachment point to which an image from
|
||
|
<parameter>texture</parameter> should be attached. Must be one of the
|
||
|
following symbolic constants:
|
||
|
<constant>GL_COLOR_ATTACHMENT0</constant>,
|
||
|
<constant>GL_DEPTH_ATTACHMENT</constant>, or
|
||
|
<constant>GL_STENCIL_ATTACHMENT</constant>.</para>
|
||
|
</listitem>
|
||
|
</varlistentry>
|
||
|
<varlistentry>
|
||
|
<term><parameter>textarget</parameter></term>
|
||
|
<listitem>
|
||
|
<para>Specifies the texture target. Must be one of the
|
||
|
following symbolic constants:
|
||
|
<constant>GL_TEXTURE_2D</constant>,
|
||
|
<constant>GL_TEXTURE_CUBE_MAP_POSITIVE_X</constant>,
|
||
|
<constant>GL_TEXTURE_CUBE_MAP_NEGATIVE_X</constant>,
|
||
|
<constant>GL_TEXTURE_CUBE_MAP_POSITIVE_Y</constant>,
|
||
|
<constant>GL_TEXTURE_CUBE_MAP_NEGATIVE_Y</constant>,
|
||
|
<constant>GL_TEXTURE_CUBE_MAP_POSITIVE_Z</constant>, or
|
||
|
<constant>GL_TEXTURE_CUBE_MAP_NEGATIVE_Z</constant>.</para>
|
||
|
</listitem>
|
||
|
</varlistentry>
|
||
|
<varlistentry>
|
||
|
<term><parameter>texture</parameter></term>
|
||
|
<listitem>
|
||
|
<para>Specifies the texture object whose image is to be attached.</para>
|
||
|
</listitem>
|
||
|
</varlistentry>
|
||
|
<varlistentry>
|
||
|
<term><parameter>level</parameter></term>
|
||
|
<listitem>
|
||
|
<para>Specifies the mipmap level of the texture image to be attached,
|
||
|
which must be 0.</para>
|
||
|
</listitem>
|
||
|
</varlistentry>
|
||
|
</variablelist>
|
||
|
</refsect1>
|
||
|
<refsect1 id="description"><title>Description</title>
|
||
|
<para><function>glFramebufferTexture2D</function> attaches the
|
||
|
texture image specified by <parameter>texture</parameter> and
|
||
|
<parameter>level</parameter> as
|
||
|
one of the logical buffers of the currently bound framebuffer object.
|
||
|
<parameter>attachment</parameter> specifies whether the texture image
|
||
|
should be attached to the framebuffer object's color, depth, or
|
||
|
stencil buffer. A texture image may not be attached to the default
|
||
|
framebuffer object name 0.</para>
|
||
|
|
||
|
<para>If <parameter>texture</parameter> is not 0, the value of
|
||
|
<constant>GL_FRAMEBUFFER_ATTACHMENT_OBJECT_TYPE</constant> for the
|
||
|
specified attachment point is set to <constant>GL_TEXTURE</constant>,
|
||
|
the value of <constant>GL_FRAMEBUFFER_ATTACHMENT_OBJECT_NAME</constant>
|
||
|
is set to <parameter>texture</parameter>, and the value of
|
||
|
<constant>GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_LEVEL</constant> is set to
|
||
|
<parameter>level</parameter>. If <parameter>texture</parameter> is a cube map
|
||
|
texture, the value of <constant>GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_CUBE_MAP_FACE</constant>
|
||
|
is set to <parameter>textarget</parameter>; otherwise it is set to the default value
|
||
|
<constant>GL_TEXTURE_CUBE_MAP_POSITIVE_X</constant>. Any previous attachment to the
|
||
|
<parameter>attachment</parameter> logical buffer of the currently bound framebuffer
|
||
|
object is broken.</para>
|
||
|
|
||
|
<para>If <parameter>texture</parameter> is 0, the current image, if any, attached to
|
||
|
the <parameter>attachment</parameter> logical buffer of the currently bound
|
||
|
framebuffer object is detached. The value of
|
||
|
<constant>GL_FRAMEBUFFER_ATTACHMENT_OBJECT_TYPE</constant> is set to
|
||
|
<constant>GL_NONE</constant>. The value of
|
||
|
<constant>GL_FRAMEBUFFER_ATTACHMENT_OBJECT_NAME</constant> is set to 0.
|
||
|
<constant>GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_LEVEL</constant> and
|
||
|
<constant>GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_CUBE_MAP_FACE</constant> are
|
||
|
set to the default values 0 and <constant>GL_TEXTURE_CUBE_MAP_POSITIVE_X</constant>,
|
||
|
respectively.</para>
|
||
|
</refsect1>
|
||
|
<refsect1 id="notes"><title>Notes</title>
|
||
|
<para>
|
||
|
Special precautions need to be taken to avoid attaching a texture image to the
|
||
|
currently bound framebuffer while the texture object is currently bound and
|
||
|
potentially sampled by the current vertex or fragment shader. Doing so could lead to
|
||
|
the creation of a "feedback loop" between the writing of pixels by rendering operations
|
||
|
and the simultaneous reading of those same pixels when used as texels in the
|
||
|
currently bound texture. In this scenario, the framebuffer will be considered
|
||
|
framebuffer complete, but the values of fragments rendered while in this state will
|
||
|
be undefined. The values of texture samples may be undefined as well.
|
||
|
</para>
|
||
|
|
||
|
<para>
|
||
|
If a texture object is deleted while its image is attached to the currently
|
||
|
bound framebuffer, then it is as if <function>glFramebufferTexture2D</function>
|
||
|
had been called with a <parameter>texture</parameter> of 0 for the attachment
|
||
|
point to which this image was attached in the currently bound framebuffer object.
|
||
|
In other words, the texture image is detached from the currently bound
|
||
|
framebuffer. Note that the texture image is specifically <emphasis>not</emphasis>
|
||
|
detached from any non-bound framebuffers. Detaching the image from any non-bound
|
||
|
framebuffers is the responsibility of the application.
|
||
|
</para>
|
||
|
</refsect1>
|
||
|
<refsect1 id="errors"><title>Errors</title>
|
||
|
<para><constant>GL_INVALID_ENUM</constant> is generated if
|
||
|
<parameter>target</parameter> is not <constant>GL_FRAMEBUFFER</constant>.</para>
|
||
|
|
||
|
<para><constant>GL_INVALID_ENUM</constant> is generated if
|
||
|
<parameter>textarget</parameter> is not an accepted texture target and
|
||
|
<parameter>texture</parameter> is not 0.</para>
|
||
|
|
||
|
<para><constant>GL_INVALID_ENUM</constant> is generated if
|
||
|
<parameter>attachment</parameter> is not an accepted attachment point.</para>
|
||
|
|
||
|
<para><constant>GL_INVALID_VALUE</constant> is generated if
|
||
|
<parameter>level</parameter> is not 0 and
|
||
|
<parameter>texture</parameter> is not 0.</para>
|
||
|
|
||
|
<para><constant>GL_INVALID_OPERATION</constant> is generated if
|
||
|
the default framebuffer object name 0 is bound.</para>
|
||
|
|
||
|
<para><constant>GL_INVALID_OPERATION</constant> is generated if
|
||
|
<parameter>texture</parameter> is neither 0 nor the name of an existing
|
||
|
texture object.</para>
|
||
|
|
||
|
<para><constant>GL_INVALID_OPERATION</constant> is generated if
|
||
|
<parameter>texture</parameter> is the name of an existing two-dimensional
|
||
|
texture object but <parameter>textarget</parameter> is not
|
||
|
<constant>GL_TEXTURE_2D</constant> or if <parameter>texture</parameter> is
|
||
|
the name of an existing cube map texture object but <parameter>textarget</parameter>
|
||
|
is <constant>GL_TEXTURE_2D</constant>.</para>
|
||
|
</refsect1>
|
||
|
<refsect1 id="associatedgets"><title>Associated Gets</title>
|
||
|
<para><citerefentry><refentrytitle>glGetFramebufferAttachmentParameteriv</refentrytitle></citerefentry></para>
|
||
|
</refsect1>
|
||
|
<refsect1 id="seealso"><title>See Also</title>
|
||
|
<para><citerefentry><refentrytitle>glBindFramebuffer</refentrytitle></citerefentry>,
|
||
|
<citerefentry><refentrytitle>glBindTexture</refentrytitle></citerefentry>,
|
||
|
<citerefentry><refentrytitle>glCheckFramebufferStatus</refentrytitle></citerefentry>,
|
||
|
<citerefentry><refentrytitle>glDeleteFramebuffers</refentrytitle></citerefentry>,
|
||
|
<citerefentry><refentrytitle>glDeleteTextures</refentrytitle></citerefentry>,
|
||
|
<citerefentry><refentrytitle>glFramebufferRenderbuffer</refentrytitle></citerefentry>,
|
||
|
<citerefentry><refentrytitle>glGenerateMipmap</refentrytitle></citerefentry>,
|
||
|
<citerefentry><refentrytitle>glGetFramebufferAttachmentParameteriv</refentrytitle></citerefentry>,
|
||
|
<citerefentry><refentrytitle>glTexImage2D</refentrytitle></citerefentry></para>
|
||
|
</refsect1>
|
||
|
<refsect1 id="copyright"><title>Copyright</title>
|
||
|
<para>
|
||
|
Copyright <trademark class="copyright"></trademark> 2008 Khronos Group.
|
||
|
This material may be distributed subject to the terms and conditions set forth in
|
||
|
the Open Publication License, v 1.0, 8 June 1999.
|
||
|
<ulink url="http://opencontent.org/openpub/">http://opencontent.org/openpub/</ulink>.
|
||
|
</para>
|
||
|
</refsect1>
|
||
|
</refentry>
|