139 lines
3.6 KiB
RPMSpec
139 lines
3.6 KiB
RPMSpec
|
Name
|
||
|
|
||
|
MESA_pack_invert
|
||
|
|
||
|
Name Strings
|
||
|
|
||
|
GL_MESA_pack_invert
|
||
|
|
||
|
Contact
|
||
|
|
||
|
Brian Paul, Tungsten Graphics, Inc. (brian.paul 'at' tungstengraphics.com)
|
||
|
Keith Whitwell, Tungsten Graphics, Inc. (keith 'at' tungstengraphics.com)
|
||
|
|
||
|
Status
|
||
|
|
||
|
Shipping (Mesa 4.0.4 and later)
|
||
|
|
||
|
Version
|
||
|
|
||
|
1.0
|
||
|
|
||
|
Number
|
||
|
|
||
|
TBD
|
||
|
|
||
|
Dependencies
|
||
|
|
||
|
OpenGL 1.0 or later is required
|
||
|
This extensions is written against the OpenGL 1.4 Specification.
|
||
|
|
||
|
Overview
|
||
|
|
||
|
This extension adds a new pixel storage parameter to indicate that
|
||
|
images are to be packed in top-to-bottom order instead of OpenGL's
|
||
|
conventional bottom-to-top order. Only pixel packing can be
|
||
|
inverted (i.e. for glReadPixels, glGetTexImage, glGetConvolutionFilter,
|
||
|
etc).
|
||
|
|
||
|
Almost all known image file formats store images in top-to-bottom
|
||
|
order. As it is, OpenGL reads images from the frame buffer in
|
||
|
bottom-to-top order. Thus, images usually have to be inverted before
|
||
|
writing them to a file with image I/O libraries. This extension
|
||
|
allows images to be read such that inverting isn't needed.
|
||
|
|
||
|
IP Status
|
||
|
|
||
|
None
|
||
|
|
||
|
Issues
|
||
|
|
||
|
1. Should we also define UNPACK_INVERT_MESA for glDrawPixels, etc?
|
||
|
|
||
|
Resolved: No, we're only concerned with pixel packing. There are other
|
||
|
solutions for inverting images when using glDrawPixels (negative Y pixel
|
||
|
zoom) or glTexImage (invert the vertex T coordinates). It would be easy
|
||
|
enough to define a complementary extension for pixel packing in the
|
||
|
future if needed.
|
||
|
|
||
|
New Procedures and Functions
|
||
|
|
||
|
None
|
||
|
|
||
|
New Tokens
|
||
|
|
||
|
Accepted by the <pname> parameter of PixelStorei and PixelStoref
|
||
|
and the <pname> parameter of GetIntegerv, GetFloatv, GetDoublev
|
||
|
and GetBooleanv:
|
||
|
|
||
|
PACK_INVERT_MESA 0x8758
|
||
|
|
||
|
Additions to Chapter 2 of the OpenGL 1.4 Specification (OpenGL Operation)
|
||
|
|
||
|
None
|
||
|
|
||
|
Additions to Chapter 3 of the OpenGL 1.4 Specification (Rasterization)
|
||
|
|
||
|
None
|
||
|
|
||
|
Additions to Chapter 4 of the OpenGL 1.4 Specification (Per-Fragment
|
||
|
Operations and the Frame Buffer)
|
||
|
|
||
|
Add the following entry to table 4.4 (PixelStore parameters) on page 182:
|
||
|
|
||
|
Parameter Name Type Initial Value Valid Range
|
||
|
---------------------------------------------------------
|
||
|
PACK_INVERT_MESA boolean FALSE TRUE/FALSE
|
||
|
|
||
|
In the section labeled "Placement in Client Memory" on page 184
|
||
|
insert the following text into the paragraph before the sentence
|
||
|
that starts with "If the format is RED, GREEN, BLUE...":
|
||
|
|
||
|
"The parameter PACK_INVERT_MESA controls whether the image is packed
|
||
|
in bottom-to-top order (the default) or top-to-bottom order. Equation
|
||
|
3.8 is modified as follows:
|
||
|
|
||
|
... the first element of the Nth row is indicated by
|
||
|
|
||
|
p + Nk, if PACK_INVERT_MESA is false
|
||
|
p + k * (H - 1) - Nk, if PACK_INVERT_MESA is true, where H is the
|
||
|
image height
|
||
|
"
|
||
|
|
||
|
Additions to Chapter 5 of the OpenGL 1.4 Specification (Special Functions)
|
||
|
|
||
|
None
|
||
|
|
||
|
Additions to Chapter 6 of the OpenGL 1.4 Specification (State and
|
||
|
State Requests)
|
||
|
|
||
|
None
|
||
|
|
||
|
Additions to Appendix A of the OpenGL 1.4 Specification (Invariance)
|
||
|
|
||
|
None
|
||
|
|
||
|
Additions to the AGL/GLX/WGL Specifications
|
||
|
|
||
|
None
|
||
|
|
||
|
GLX Protocol
|
||
|
|
||
|
None
|
||
|
|
||
|
Errors
|
||
|
|
||
|
None
|
||
|
|
||
|
New State
|
||
|
|
||
|
Add the following entry to table 6.20 (Pixels) on page 235:
|
||
|
|
||
|
Get Value Type Get Cmd Initial Value Description Sec Attribute
|
||
|
--------------------------------------------------------------------------------------------------
|
||
|
PACK_INVERT_MESA boolean GetBoolean FALSE Value of PACK_INVERT_MESA 4.3.2 pixel-store
|
||
|
|
||
|
Revision History
|
||
|
|
||
|
21 September 2002 - Initial draft
|