| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889 |
- // Copyright 2014 The Go Authors. All rights reserved.
- // Use of this source code is governed by a BSD-style
- // license that can be found in the LICENSE file.
- package gl
- // Context is an OpenGL ES context.
- //
- // A Context has a method for every GL function supported by ES 2 or later.
- // In a program compiled with ES 3 support, a Context is also a Context3.
- // For example, a program can:
- //
- // func f(glctx gl.Context) {
- // glctx.(gl.Context3).BlitFramebuffer(...)
- // }
- //
- // Calls are not safe for concurrent use. However calls can be made from
- // any goroutine, the gl package removes the notion of thread-local
- // context.
- //
- // Contexts are independent. Two contexts can be used concurrently.
- type Context interface {
- // ActiveTexture sets the active texture unit.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glActiveTexture.xhtml
- ActiveTexture(texture Enum)
- // AttachShader attaches a shader to a program.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glAttachShader.xhtml
- AttachShader(p Program, s Shader)
- // BindAttribLocation binds a vertex attribute index with a named
- // variable.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glBindAttribLocation.xhtml
- BindAttribLocation(p Program, a Attrib, name string)
- // BindBuffer binds a buffer.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glBindBuffer.xhtml
- BindBuffer(target Enum, b Buffer)
- // BindFramebuffer binds a framebuffer.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glBindFramebuffer.xhtml
- BindFramebuffer(target Enum, fb Framebuffer)
- // BindRenderbuffer binds a render buffer.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glBindRenderbuffer.xhtml
- BindRenderbuffer(target Enum, rb Renderbuffer)
- // BindTexture binds a texture.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glBindTexture.xhtml
- BindTexture(target Enum, t Texture)
- // BindVertexArray binds a vertex array.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glBindVertexArray.xhtml
- BindVertexArray(rb VertexArray)
- // BlendColor sets the blend color.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glBlendColor.xhtml
- BlendColor(red, green, blue, alpha float32)
- // BlendEquation sets both RGB and alpha blend equations.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glBlendEquation.xhtml
- BlendEquation(mode Enum)
- // BlendEquationSeparate sets RGB and alpha blend equations separately.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glBlendEquationSeparate.xhtml
- BlendEquationSeparate(modeRGB, modeAlpha Enum)
- // BlendFunc sets the pixel blending factors.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glBlendFunc.xhtml
- BlendFunc(sfactor, dfactor Enum)
- // BlendFunc sets the pixel RGB and alpha blending factors separately.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glBlendFuncSeparate.xhtml
- BlendFuncSeparate(sfactorRGB, dfactorRGB, sfactorAlpha, dfactorAlpha Enum)
- // BufferData creates a new data store for the bound buffer object.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glBufferData.xhtml
- BufferData(target Enum, src []byte, usage Enum)
- // BufferInit creates a new uninitialized data store for the bound buffer object.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glBufferData.xhtml
- BufferInit(target Enum, size int, usage Enum)
- // BufferSubData sets some of data in the bound buffer object.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glBufferSubData.xhtml
- BufferSubData(target Enum, offset int, data []byte)
- // CheckFramebufferStatus reports the completeness status of the
- // active framebuffer.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glCheckFramebufferStatus.xhtml
- CheckFramebufferStatus(target Enum) Enum
- // Clear clears the window.
- //
- // The behavior of Clear is influenced by the pixel ownership test,
- // the scissor test, dithering, and the buffer writemasks.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glClear.xhtml
- Clear(mask Enum)
- // ClearColor specifies the RGBA values used to clear color buffers.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glClearColor.xhtml
- ClearColor(red, green, blue, alpha float32)
- // ClearDepthf sets the depth value used to clear the depth buffer.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glClearDepthf.xhtml
- ClearDepthf(d float32)
- // ClearStencil sets the index used to clear the stencil buffer.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glClearStencil.xhtml
- ClearStencil(s int)
- // ColorMask specifies whether color components in the framebuffer
- // can be written.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glColorMask.xhtml
- ColorMask(red, green, blue, alpha bool)
- // CompileShader compiles the source code of s.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glCompileShader.xhtml
- CompileShader(s Shader)
- // CompressedTexImage2D writes a compressed 2D texture.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glCompressedTexImage2D.xhtml
- CompressedTexImage2D(target Enum, level int, internalformat Enum, width, height, border int, data []byte)
- // CompressedTexSubImage2D writes a subregion of a compressed 2D texture.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glCompressedTexSubImage2D.xhtml
- CompressedTexSubImage2D(target Enum, level, xoffset, yoffset, width, height int, format Enum, data []byte)
- // CopyTexImage2D writes a 2D texture from the current framebuffer.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glCopyTexImage2D.xhtml
- CopyTexImage2D(target Enum, level int, internalformat Enum, x, y, width, height, border int)
- // CopyTexSubImage2D writes a 2D texture subregion from the
- // current framebuffer.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glCopyTexSubImage2D.xhtml
- CopyTexSubImage2D(target Enum, level, xoffset, yoffset, x, y, width, height int)
- // CreateBuffer creates a buffer object.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glGenBuffers.xhtml
- CreateBuffer() Buffer
- // CreateFramebuffer creates a framebuffer object.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glGenFramebuffers.xhtml
- CreateFramebuffer() Framebuffer
- // CreateProgram creates a new empty program object.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glCreateProgram.xhtml
- CreateProgram() Program
- // CreateRenderbuffer create a renderbuffer object.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glGenRenderbuffers.xhtml
- CreateRenderbuffer() Renderbuffer
- // CreateShader creates a new empty shader object.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glCreateShader.xhtml
- CreateShader(ty Enum) Shader
- // CreateTexture creates a texture object.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glGenTextures.xhtml
- CreateTexture() Texture
- // CreateTVertexArray creates a vertex array.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glGenVertexArrays.xhtml
- CreateVertexArray() VertexArray
- // CullFace specifies which polygons are candidates for culling.
- //
- // Valid modes: FRONT, BACK, FRONT_AND_BACK.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glCullFace.xhtml
- CullFace(mode Enum)
- // DeleteBuffer deletes the given buffer object.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glDeleteBuffers.xhtml
- DeleteBuffer(v Buffer)
- // DeleteFramebuffer deletes the given framebuffer object.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glDeleteFramebuffers.xhtml
- DeleteFramebuffer(v Framebuffer)
- // DeleteProgram deletes the given program object.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glDeleteProgram.xhtml
- DeleteProgram(p Program)
- // DeleteRenderbuffer deletes the given render buffer object.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glDeleteRenderbuffers.xhtml
- DeleteRenderbuffer(v Renderbuffer)
- // DeleteShader deletes shader s.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glDeleteShader.xhtml
- DeleteShader(s Shader)
- // DeleteTexture deletes the given texture object.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glDeleteTextures.xhtml
- DeleteTexture(v Texture)
- // DeleteVertexArray deletes the given render buffer object.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glDeleteVertexArrays.xhtml
- DeleteVertexArray(v VertexArray)
- // DepthFunc sets the function used for depth buffer comparisons.
- //
- // Valid fn values:
- // NEVER
- // LESS
- // EQUAL
- // LEQUAL
- // GREATER
- // NOTEQUAL
- // GEQUAL
- // ALWAYS
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glDepthFunc.xhtml
- DepthFunc(fn Enum)
- // DepthMask sets the depth buffer enabled for writing.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glDepthMask.xhtml
- DepthMask(flag bool)
- // DepthRangef sets the mapping from normalized device coordinates to
- // window coordinates.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glDepthRangef.xhtml
- DepthRangef(n, f float32)
- // DetachShader detaches the shader s from the program p.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glDetachShader.xhtml
- DetachShader(p Program, s Shader)
- // Disable disables various GL capabilities.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glDisable.xhtml
- Disable(cap Enum)
- // DisableVertexAttribArray disables a vertex attribute array.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glDisableVertexAttribArray.xhtml
- DisableVertexAttribArray(a Attrib)
- // DrawArrays renders geometric primitives from the bound data.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glDrawArrays.xhtml
- DrawArrays(mode Enum, first, count int)
- // DrawElements renders primitives from a bound buffer.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glDrawElements.xhtml
- DrawElements(mode Enum, count int, ty Enum, offset int)
- // TODO(crawshaw): consider DrawElements8 / DrawElements16 / DrawElements32
- // Enable enables various GL capabilities.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glEnable.xhtml
- Enable(cap Enum)
- // EnableVertexAttribArray enables a vertex attribute array.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glEnableVertexAttribArray.xhtml
- EnableVertexAttribArray(a Attrib)
- // Finish blocks until the effects of all previously called GL
- // commands are complete.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glFinish.xhtml
- Finish()
- // Flush empties all buffers. It does not block.
- //
- // An OpenGL implementation may buffer network communication,
- // the command stream, or data inside the graphics accelerator.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glFlush.xhtml
- Flush()
- // FramebufferRenderbuffer attaches rb to the current frame buffer.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glFramebufferRenderbuffer.xhtml
- FramebufferRenderbuffer(target, attachment, rbTarget Enum, rb Renderbuffer)
- // FramebufferTexture2D attaches the t to the current frame buffer.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glFramebufferTexture2D.xhtml
- FramebufferTexture2D(target, attachment, texTarget Enum, t Texture, level int)
- // FrontFace defines which polygons are front-facing.
- //
- // Valid modes: CW, CCW.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glFrontFace.xhtml
- FrontFace(mode Enum)
- // GenerateMipmap generates mipmaps for the current texture.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glGenerateMipmap.xhtml
- GenerateMipmap(target Enum)
- // GetActiveAttrib returns details about an active attribute variable.
- // A value of 0 for index selects the first active attribute variable.
- // Permissible values for index range from 0 to the number of active
- // attribute variables minus 1.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glGetActiveAttrib.xhtml
- GetActiveAttrib(p Program, index uint32) (name string, size int, ty Enum)
- // GetActiveUniform returns details about an active uniform variable.
- // A value of 0 for index selects the first active uniform variable.
- // Permissible values for index range from 0 to the number of active
- // uniform variables minus 1.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glGetActiveUniform.xhtml
- GetActiveUniform(p Program, index uint32) (name string, size int, ty Enum)
- // GetAttachedShaders returns the shader objects attached to program p.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glGetAttachedShaders.xhtml
- GetAttachedShaders(p Program) []Shader
- // GetAttribLocation returns the location of an attribute variable.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glGetAttribLocation.xhtml
- GetAttribLocation(p Program, name string) Attrib
- // GetBooleanv returns the boolean values of parameter pname.
- //
- // Many boolean parameters can be queried more easily using IsEnabled.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glGet.xhtml
- GetBooleanv(dst []bool, pname Enum)
- // GetFloatv returns the float values of parameter pname.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glGet.xhtml
- GetFloatv(dst []float32, pname Enum)
- // GetIntegerv returns the int values of parameter pname.
- //
- // Single values may be queried more easily using GetInteger.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glGet.xhtml
- GetIntegerv(dst []int32, pname Enum)
- // GetInteger returns the int value of parameter pname.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glGet.xhtml
- GetInteger(pname Enum) int
- // GetBufferParameteri returns a parameter for the active buffer.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glGetBufferParameter.xhtml
- GetBufferParameteri(target, value Enum) int
- // GetError returns the next error.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glGetError.xhtml
- GetError() Enum
- // GetFramebufferAttachmentParameteri returns attachment parameters
- // for the active framebuffer object.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glGetFramebufferAttachmentParameteriv.xhtml
- GetFramebufferAttachmentParameteri(target, attachment, pname Enum) int
- // GetProgrami returns a parameter value for a program.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glGetProgramiv.xhtml
- GetProgrami(p Program, pname Enum) int
- // GetProgramInfoLog returns the information log for a program.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glGetProgramInfoLog.xhtml
- GetProgramInfoLog(p Program) string
- // GetRenderbufferParameteri returns a parameter value for a render buffer.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glGetRenderbufferParameteriv.xhtml
- GetRenderbufferParameteri(target, pname Enum) int
- // GetShaderi returns a parameter value for a shader.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glGetShaderiv.xhtml
- GetShaderi(s Shader, pname Enum) int
- // GetShaderInfoLog returns the information log for a shader.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glGetShaderInfoLog.xhtml
- GetShaderInfoLog(s Shader) string
- // GetShaderPrecisionFormat returns range and precision limits for
- // shader types.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glGetShaderPrecisionFormat.xhtml
- GetShaderPrecisionFormat(shadertype, precisiontype Enum) (rangeLow, rangeHigh, precision int)
- // GetShaderSource returns source code of shader s.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glGetShaderSource.xhtml
- GetShaderSource(s Shader) string
- // GetString reports current GL state.
- //
- // Valid name values:
- // EXTENSIONS
- // RENDERER
- // SHADING_LANGUAGE_VERSION
- // VENDOR
- // VERSION
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glGetString.xhtml
- GetString(pname Enum) string
- // GetTexParameterfv returns the float values of a texture parameter.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glGetTexParameter.xhtml
- GetTexParameterfv(dst []float32, target, pname Enum)
- // GetTexParameteriv returns the int values of a texture parameter.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glGetTexParameter.xhtml
- GetTexParameteriv(dst []int32, target, pname Enum)
- // GetUniformfv returns the float values of a uniform variable.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glGetUniform.xhtml
- GetUniformfv(dst []float32, src Uniform, p Program)
- // GetUniformiv returns the float values of a uniform variable.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glGetUniform.xhtml
- GetUniformiv(dst []int32, src Uniform, p Program)
- // GetUniformLocation returns the location of a uniform variable.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glGetUniformLocation.xhtml
- GetUniformLocation(p Program, name string) Uniform
- // GetVertexAttribf reads the float value of a vertex attribute.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glGetVertexAttrib.xhtml
- GetVertexAttribf(src Attrib, pname Enum) float32
- // GetVertexAttribfv reads float values of a vertex attribute.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glGetVertexAttrib.xhtml
- GetVertexAttribfv(dst []float32, src Attrib, pname Enum)
- // GetVertexAttribi reads the int value of a vertex attribute.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glGetVertexAttrib.xhtml
- GetVertexAttribi(src Attrib, pname Enum) int32
- // GetVertexAttribiv reads int values of a vertex attribute.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glGetVertexAttrib.xhtml
- GetVertexAttribiv(dst []int32, src Attrib, pname Enum)
- // TODO(crawshaw): glGetVertexAttribPointerv
- // Hint sets implementation-specific modes.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glHint.xhtml
- Hint(target, mode Enum)
- // IsBuffer reports if b is a valid buffer.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glIsBuffer.xhtml
- IsBuffer(b Buffer) bool
- // IsEnabled reports if cap is an enabled capability.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glIsEnabled.xhtml
- IsEnabled(cap Enum) bool
- // IsFramebuffer reports if fb is a valid frame buffer.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glIsFramebuffer.xhtml
- IsFramebuffer(fb Framebuffer) bool
- // IsProgram reports if p is a valid program object.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glIsProgram.xhtml
- IsProgram(p Program) bool
- // IsRenderbuffer reports if rb is a valid render buffer.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glIsRenderbuffer.xhtml
- IsRenderbuffer(rb Renderbuffer) bool
- // IsShader reports if s is valid shader.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glIsShader.xhtml
- IsShader(s Shader) bool
- // IsTexture reports if t is a valid texture.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glIsTexture.xhtml
- IsTexture(t Texture) bool
- // LineWidth specifies the width of lines.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glLineWidth.xhtml
- LineWidth(width float32)
- // LinkProgram links the specified program.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glLinkProgram.xhtml
- LinkProgram(p Program)
- // PixelStorei sets pixel storage parameters.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glPixelStorei.xhtml
- PixelStorei(pname Enum, param int32)
- // PolygonOffset sets the scaling factors for depth offsets.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glPolygonOffset.xhtml
- PolygonOffset(factor, units float32)
- // ReadPixels returns pixel data from a buffer.
- //
- // In GLES 3, the source buffer is controlled with ReadBuffer.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glReadPixels.xhtml
- ReadPixels(dst []byte, x, y, width, height int, format, ty Enum)
- // ReleaseShaderCompiler frees resources allocated by the shader compiler.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glReleaseShaderCompiler.xhtml
- ReleaseShaderCompiler()
- // RenderbufferStorage establishes the data storage, format, and
- // dimensions of a renderbuffer object's image.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glRenderbufferStorage.xhtml
- RenderbufferStorage(target, internalFormat Enum, width, height int)
- // SampleCoverage sets multisample coverage parameters.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glSampleCoverage.xhtml
- SampleCoverage(value float32, invert bool)
- // Scissor defines the scissor box rectangle, in window coordinates.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glScissor.xhtml
- Scissor(x, y, width, height int32)
- // TODO(crawshaw): ShaderBinary
- // ShaderSource sets the source code of s to the given source code.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glShaderSource.xhtml
- ShaderSource(s Shader, src string)
- // StencilFunc sets the front and back stencil test reference value.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glStencilFunc.xhtml
- StencilFunc(fn Enum, ref int, mask uint32)
- // StencilFunc sets the front or back stencil test reference value.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glStencilFuncSeparate.xhtml
- StencilFuncSeparate(face, fn Enum, ref int, mask uint32)
- // StencilMask controls the writing of bits in the stencil planes.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glStencilMask.xhtml
- StencilMask(mask uint32)
- // StencilMaskSeparate controls the writing of bits in the stencil planes.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glStencilMaskSeparate.xhtml
- StencilMaskSeparate(face Enum, mask uint32)
- // StencilOp sets front and back stencil test actions.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glStencilOp.xhtml
- StencilOp(fail, zfail, zpass Enum)
- // StencilOpSeparate sets front or back stencil tests.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glStencilOpSeparate.xhtml
- StencilOpSeparate(face, sfail, dpfail, dppass Enum)
- // TexImage2D writes a 2D texture image.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glTexImage2D.xhtml
- TexImage2D(target Enum, level int, internalFormat int, width, height int, format Enum, ty Enum, data []byte)
- // TexSubImage2D writes a subregion of a 2D texture image.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glTexSubImage2D.xhtml
- TexSubImage2D(target Enum, level int, x, y, width, height int, format, ty Enum, data []byte)
- // TexParameterf sets a float texture parameter.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glTexParameter.xhtml
- TexParameterf(target, pname Enum, param float32)
- // TexParameterfv sets a float texture parameter array.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glTexParameter.xhtml
- TexParameterfv(target, pname Enum, params []float32)
- // TexParameteri sets an integer texture parameter.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glTexParameter.xhtml
- TexParameteri(target, pname Enum, param int)
- // TexParameteriv sets an integer texture parameter array.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glTexParameter.xhtml
- TexParameteriv(target, pname Enum, params []int32)
- // Uniform1f writes a float uniform variable.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glUniform.xhtml
- Uniform1f(dst Uniform, v float32)
- // Uniform1fv writes a [len(src)]float uniform array.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glUniform.xhtml
- Uniform1fv(dst Uniform, src []float32)
- // Uniform1i writes an int uniform variable.
- //
- // Uniform1i and Uniform1iv are the only two functions that may be used
- // to load uniform variables defined as sampler types. Loading samplers
- // with any other function will result in a INVALID_OPERATION error.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glUniform.xhtml
- Uniform1i(dst Uniform, v int)
- // Uniform1iv writes a int uniform array of len(src) elements.
- //
- // Uniform1i and Uniform1iv are the only two functions that may be used
- // to load uniform variables defined as sampler types. Loading samplers
- // with any other function will result in a INVALID_OPERATION error.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glUniform.xhtml
- Uniform1iv(dst Uniform, src []int32)
- // Uniform2f writes a vec2 uniform variable.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glUniform.xhtml
- Uniform2f(dst Uniform, v0, v1 float32)
- // Uniform2fv writes a vec2 uniform array of len(src)/2 elements.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glUniform.xhtml
- Uniform2fv(dst Uniform, src []float32)
- // Uniform2i writes an ivec2 uniform variable.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glUniform.xhtml
- Uniform2i(dst Uniform, v0, v1 int)
- // Uniform2iv writes an ivec2 uniform array of len(src)/2 elements.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glUniform.xhtml
- Uniform2iv(dst Uniform, src []int32)
- // Uniform3f writes a vec3 uniform variable.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glUniform.xhtml
- Uniform3f(dst Uniform, v0, v1, v2 float32)
- // Uniform3fv writes a vec3 uniform array of len(src)/3 elements.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glUniform.xhtml
- Uniform3fv(dst Uniform, src []float32)
- // Uniform3i writes an ivec3 uniform variable.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glUniform.xhtml
- Uniform3i(dst Uniform, v0, v1, v2 int32)
- // Uniform3iv writes an ivec3 uniform array of len(src)/3 elements.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glUniform.xhtml
- Uniform3iv(dst Uniform, src []int32)
- // Uniform4f writes a vec4 uniform variable.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glUniform.xhtml
- Uniform4f(dst Uniform, v0, v1, v2, v3 float32)
- // Uniform4fv writes a vec4 uniform array of len(src)/4 elements.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glUniform.xhtml
- Uniform4fv(dst Uniform, src []float32)
- // Uniform4i writes an ivec4 uniform variable.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glUniform.xhtml
- Uniform4i(dst Uniform, v0, v1, v2, v3 int32)
- // Uniform4i writes an ivec4 uniform array of len(src)/4 elements.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glUniform.xhtml
- Uniform4iv(dst Uniform, src []int32)
- // UniformMatrix2fv writes 2x2 matrices. Each matrix uses four
- // float32 values, so the number of matrices written is len(src)/4.
- //
- // Each matrix must be supplied in column major order.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glUniform.xhtml
- UniformMatrix2fv(dst Uniform, src []float32)
- // UniformMatrix3fv writes 3x3 matrices. Each matrix uses nine
- // float32 values, so the number of matrices written is len(src)/9.
- //
- // Each matrix must be supplied in column major order.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glUniform.xhtml
- UniformMatrix3fv(dst Uniform, src []float32)
- // UniformMatrix4fv writes 4x4 matrices. Each matrix uses 16
- // float32 values, so the number of matrices written is len(src)/16.
- //
- // Each matrix must be supplied in column major order.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glUniform.xhtml
- UniformMatrix4fv(dst Uniform, src []float32)
- // UseProgram sets the active program.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glUseProgram.xhtml
- UseProgram(p Program)
- // ValidateProgram checks to see whether the executables contained in
- // program can execute given the current OpenGL state.
- //
- // Typically only used for debugging.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glValidateProgram.xhtml
- ValidateProgram(p Program)
- // VertexAttrib1f writes a float vertex attribute.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glVertexAttrib.xhtml
- VertexAttrib1f(dst Attrib, x float32)
- // VertexAttrib1fv writes a float vertex attribute.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glVertexAttrib.xhtml
- VertexAttrib1fv(dst Attrib, src []float32)
- // VertexAttrib2f writes a vec2 vertex attribute.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glVertexAttrib.xhtml
- VertexAttrib2f(dst Attrib, x, y float32)
- // VertexAttrib2fv writes a vec2 vertex attribute.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glVertexAttrib.xhtml
- VertexAttrib2fv(dst Attrib, src []float32)
- // VertexAttrib3f writes a vec3 vertex attribute.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glVertexAttrib.xhtml
- VertexAttrib3f(dst Attrib, x, y, z float32)
- // VertexAttrib3fv writes a vec3 vertex attribute.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glVertexAttrib.xhtml
- VertexAttrib3fv(dst Attrib, src []float32)
- // VertexAttrib4f writes a vec4 vertex attribute.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glVertexAttrib.xhtml
- VertexAttrib4f(dst Attrib, x, y, z, w float32)
- // VertexAttrib4fv writes a vec4 vertex attribute.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glVertexAttrib.xhtml
- VertexAttrib4fv(dst Attrib, src []float32)
- // VertexAttribPointer uses a bound buffer to define vertex attribute data.
- //
- // Direct use of VertexAttribPointer to load data into OpenGL is not
- // supported via the Go bindings. Instead, use BindBuffer with an
- // ARRAY_BUFFER and then fill it using BufferData.
- //
- // The size argument specifies the number of components per attribute,
- // between 1-4. The stride argument specifies the byte offset between
- // consecutive vertex attributes.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glVertexAttribPointer.xhtml
- VertexAttribPointer(dst Attrib, size int, ty Enum, normalized bool, stride, offset int)
- // Viewport sets the viewport, an affine transformation that
- // normalizes device coordinates to window coordinates.
- //
- // http://www.khronos.org/opengles/sdk/docs/man3/html/glViewport.xhtml
- Viewport(x, y, width, height int)
- }
- // Context3 is an OpenGL ES 3 context.
- //
- // When the gl package is compiled with GL ES 3 support, the produced
- // Context object also implements the Context3 interface.
- type Context3 interface {
- Context
- // BlitFramebuffer copies a block of pixels between framebuffers.
- //
- // https://www.khronos.org/opengles/sdk/docs/man3/html/glBlitFramebuffer.xhtml
- BlitFramebuffer(srcX0, srcY0, srcX1, srcY1, dstX0, dstY0, dstX1, dstY1 int, mask uint, filter Enum)
- }
- // Worker is used by display driver code to execute OpenGL calls.
- //
- // Typically display driver code creates a gl.Context for an application,
- // and along with it establishes a locked OS thread to execute the cgo
- // calls:
- //
- // go func() {
- // runtime.LockOSThread()
- // // ... platform-specific cgo call to bind a C OpenGL context
- // // into thread-local storage.
- //
- // glctx, worker := gl.NewContext()
- // workAvailable := worker.WorkAvailable()
- // go userAppCode(glctx)
- // for {
- // select {
- // case <-workAvailable:
- // worker.DoWork()
- // case <-drawEvent:
- // // ... platform-specific cgo call to draw screen
- // }
- // }
- // }()
- //
- // This interface is an internal implementation detail and should only be used
- // by the package responsible for managing the screen, such as
- // golang.org/x/mobile/app.
- type Worker interface {
- // WorkAvailable returns a channel that communicates when DoWork should be
- // called.
- WorkAvailable() <-chan struct{}
- // DoWork performs any pending OpenGL calls.
- DoWork()
- }
|