Get Context Info

From OpenGL.org
Revision as of 11:55, 14 June 2011 by Zyx 2000 (Talk | contribs) (glGetString(GL_EXTENSIONS))

Jump to: navigation, search

glGetString(GL_VERSION)

This returns a string which may look something like "2.0.6914 WinXP SSE/SSE2/SSE3/3DNow!"

2.0 is the actual version number of GL supported. All the rest depends on what information the IHV wants to convey and is not part of the GL standard. 6914 would be the driver version. WinXP is the OS. SSE/SSE2/SSE3/3DNow! are CPU features that the driver can use in case it runs in software mode.

Also note that at times glGetString(GL_VERSION) returns also the bus type used such as AGP or PCI or PCIEx.

glGetString(GL_VENDOR)

This returns the company name of whoever wrote the GL driver. It could be "ATI Technologies", "NVIDIA", "INTEL" and so on.

On Windows, if it says "Microsoft" then you are using the Windows software renderer or the Windows Direct3D wrapper. You probably haven't installed the graphics drivers yet.

glGetString(GL_RENDERER)

This returns the name of the renderer, which would be the name of the GPU. In the case of Mesa, the software renderer, it would be "Mesa" or "MESA". It might even say "Direct3D" if the Windows Direct3D wrapper is being used.

glGetString(GL_EXTENSIONS)

This function was used to retrieve the list of extensions. This is a space-separated list of extension names. This was problematic because of poor parsing behavior. Some programs searched this string for the name of the extension. It is not the correct way to find if an extension is supported, as the name of an extension can be a substring of another extension name. For example, if the extension GL_EXT_pixel_transform_color_table is listed, doing a simple search for GL_EXT_pixel_transform will return a positive whether or not it is defined.

glGetStringi(GL_EXTENSIONS, i)

This function retrieves the null-terminated string of the 'i'th extension. An implementation exposes a number of extensions equal to glGetInteger(GL_NUM_EXTENSIONS). The argument 'i' must be between 0 and this value - 1.

This entrypoint is supported only in GL 3.0 and above.