Difference between revisions of "GPU (API)"

From ComputerCraft Wiki
Jump to: navigation, search
(API Methods)
(Render Methods)
Line 34: Line 34:
 
|-
 
|-
 
|gpuClearBuffer()
 
|gpuClearBuffer()
|Coming soon
+
|Clear the currently bound buffer.
 
|-
 
|-
 
|gpuBindBuffer(id)
 
|gpuBindBuffer(id)
|Coming soon
+
|coming soon
 
|-
 
|-
 
|gpuBindOutputBuffer(id)
 
|gpuBindOutputBuffer(id)
|Coming soon
+
|Start drawing to a different buffer. (Set this to a certain monitor ID to draw to it.)
 
|-
 
|-
 
|gpuGetOutputResolution(id)
 
|gpuGetOutputResolution(id)

Revision as of 01:22, 18 March 2012

The GPU api provides interaction with and is part of the CCGPU peripheral.
Arguments surrounded with square brackets are optional.

API Methods

These methods can be used in any ComputerCraft program if the CCGPU api is installed.

Method name Description
gpu.getID([side]) Returns the ID of the GPU on the given side.
gpu.setRenderCode([side], renderCode) Sets the gpu rendering code, this code is ran every frame.

@param side the side the gpu is connected to
@param renderCode the code as a string
@return nil

gpu.setVar([side], name, value) coming soon
gpu.getLatestError([side]) Returns the last error that has been thrown by Lua in your render code.

Render Methods

These methods can be used in render code when set using gpu.setRenderCode.

Method name Description
gpuCreateBuffer(width, height) Coming soon
gpuClearBuffer() Clear the currently bound buffer.
gpuBindBuffer(id) coming soon
gpuBindOutputBuffer(id) Start drawing to a different buffer. (Set this to a certain monitor ID to draw to it.)
gpuGetOutputResolution(id) Coming soon

OpenGL Methods

These methods are part of OpenGL and can only be used in render code when set using gpu.setRenderCode.

Method name Description
glBegin(mode) Begins drawing something. mode should be a constant like GL_QUADS or GL_TRIANGLES. You must invoke this function before setting vertices for the shape.
glEnd() Invoke this when you've set all your vertices.
glBindTexture(id) Coming soon
glTexCoord2f(x, y) Coming soon
glVertex2f(x, y) Use this between glBegin(mode) and glEnd() to set a 2D vertex.
glVertex3f(x, y, z) Use this between glBegin(mode) and glEnd() to set a 3D vertex.
glColor3f(red, green, blue) Use this between glBegin(mode) and glEnd() to set the color.
glColor4f(red, green, blue, alpha) Use this between glBegin(mode) and glEnd() to set the color with alpha (opacity).

OpenGL Constants

These constants are part of OpenGL and can only be used in render code when set using gpu.setRenderCode.

Constant name Description
GL_QUADS Constant for drawing a quadrilateral.
GL_TRIANGLES Constant for drawing a triangle.
GL_POINTS Constant for drawing a pixel at each vertex given.