module Graphics.Rendering.OpenGL.GL.VertexArrayObjects (
VertexArrayObject,
bindVertexArrayObject
) where
import Control.Monad.IO.Class
import Data.ObjectName
import Data.StateVar
import Foreign.Marshal.Array ( allocaArray, peekArray, withArrayLen )
import Graphics.Rendering.OpenGL.GL.DebugOutput
import Graphics.Rendering.OpenGL.GL.GLboolean
import Graphics.Rendering.OpenGL.GL.QueryUtils
import Graphics.GL
newtype VertexArrayObject = VertexArrayObject { vertexArrayID :: GLuint }
deriving( Eq, Ord, Show )
instance ObjectName VertexArrayObject where
isObjectName =
liftIO . fmap unmarshalGLboolean . glIsVertexArray . vertexArrayID
deleteObjectNames bufferObjects =
liftIO . withArrayLen (map vertexArrayID bufferObjects) $
glDeleteVertexArrays . fromIntegral
instance GeneratableObjectName VertexArrayObject where
genObjectNames n = liftIO . allocaArray n $ \buf -> do
glGenVertexArrays (fromIntegral n) buf
fmap (map VertexArrayObject) $ peekArray n buf
instance CanBeLabeled VertexArrayObject where
objectLabel = objectNameLabel GL_VERTEX_ARRAY . vertexArrayID
bindVertexArrayObject :: StateVar (Maybe VertexArrayObject)
bindVertexArrayObject = makeStateVar getVAO bindVAO
getVAO :: IO (Maybe VertexArrayObject)
getVAO = do
vao <- getInteger1 (VertexArrayObject . fromIntegral) GetVertexArrayBinding
return $ if vao == noVAO then Nothing else Just vao
bindVAO :: Maybe VertexArrayObject -> IO ()
bindVAO = glBindVertexArray . vertexArrayID . maybe noVAO id
noVAO :: VertexArrayObject
noVAO = VertexArrayObject 0