module Graphics.Rendering.OpenGL.GL.PixelRectangles.Rasterization (
PixelData(..), PixelFormat(..), drawPixels, pixelZoom
) where
import Control.Monad
import Data.StateVar
import Graphics.Rendering.OpenGL.GL.CoordTrans
import Graphics.Rendering.OpenGL.GL.PixelData
import Graphics.Rendering.OpenGL.GL.PixelFormat
import Graphics.Rendering.OpenGL.GL.QueryUtils
import Graphics.GL
drawPixels :: Size -> PixelData a -> IO ()
drawPixels :: forall a. Size -> PixelData a -> IO ()
drawPixels (Size GLsizei
w GLsizei
h) PixelData a
pd = forall a b. PixelData a -> (GLenum -> GLenum -> Ptr a -> b) -> b
withPixelData PixelData a
pd forall a b. (a -> b) -> a -> b
$ forall (m :: * -> *) a.
MonadIO m =>
GLsizei -> GLsizei -> GLenum -> GLenum -> Ptr a -> m ()
glDrawPixels GLsizei
w GLsizei
h
pixelZoom :: StateVar (GLfloat, GLfloat)
pixelZoom :: StateVar (GLfloat, GLfloat)
pixelZoom =
forall a. IO a -> (a -> IO ()) -> StateVar a
makeStateVar
(forall (m :: * -> *) a1 a2 r.
Monad m =>
(a1 -> a2 -> r) -> m a1 -> m a2 -> m r
liftM2 (,) (forall p a. GetPName1F p => (GLfloat -> a) -> p -> IO a
getFloat1 forall a. a -> a
id PName1F
GetZoomX) (forall p a. GetPName1F p => (GLfloat -> a) -> p -> IO a
getFloat1 forall a. a -> a
id PName1F
GetZoomY))
(forall a b c. (a -> b -> c) -> (a, b) -> c
uncurry forall (m :: * -> *). MonadIO m => GLfloat -> GLfloat -> m ()
glPixelZoom)