processing-1.1.0.0: Web graphic applications with Processing.

Safe HaskellNone

Graphics.Web.Processing.Core.Types

Contents

Description

Collection of types.

Synopsis

Processing Script

data ProcScript Source

A complete Processing script.

It consists in several parts, most of them optional.

To generate each part of the code, use the ProcM monad and the functions from the Graphics.Web.Processing.Interface module. Then, run runProcM or execProcM to get the code result.

More abstract functions generate ProcScript values as well. See modules Graphics.Web.Processing.Mid and Graphics.Web.Processing.Simple for two alternative ways.

Instances

emptyScript :: ProcScriptSource

Empty script.

Script rendering

renderScript :: ProcScript -> TextSource

Render a script as a lazy Text.

renderFile :: FilePath -> ProcScript -> IO ()Source

Render a script using renderScript and write it directly in a file.

Processing Code

data ProcCode c Source

A piece of Processing code. The type parameter indicates what the context of the code is. This context will allow or disallow the use of certain commands.

Instances

Contexts

data Preamble Source

The preamble is the code that is executed at the beginning of the script.

Constructors

Preamble 

data Setup Source

In the setup part, settings like size or frame rate are supplied.

Constructors

Setup 

data Draw Source

The drawing loop.

Constructors

Draw 

Instances

data MouseClicked Source

Code that is executed when the mouse is clicked.

Constructors

MouseClicked 

data MouseReleased Source

Code that is executed when the mouse is released.

Constructors

MouseReleased 

data KeyPressed Source

Code executed when a key is pressed.

Constructors

KeyPressed 

Instances

Proc_* types

class ProcType a Source

Class of Processing value types (Proc_* types).

Proc_* types are types from the world of Processing. Some of them are similar to Haskell types, like Proc_Bool and Bool. However, they are not equal. Proc_* types are instance of Eq. However, you should instead use methods from the analog Proc_Eq class. Proc_* types contain expressions instead of values. Think of 2+2 instead of 4. Under this situation, 2+2 /= 3+1, since they are different expressions, even if they evaluate to the same value. Actually, you will get True from the evaluation of 2+2 == 3+1, since the library is smart enough to figure out they have the same value. But, please, don't rely on this. Use the Proc_Eq and Proc_Ord classes instead. They return Processing boolean expressions instead of Bool values. Anyway, the types of the library will try to force you to use Proc_* types everywhere.

The reason this library stores expressions instead of values is that it needs to handle things like 2+x, where x is an unknown value. However, an effort is done to ensure that each expression is reduced to its minimum extension.

Bool

fromBool :: Bool -> Proc_BoolSource

Cast a Bool value.

Int

fromInt :: Int -> Proc_IntSource

Cast an Int value.

Float

data Proc_Float Source

Floating point numbers. The provided Eq instance checks the equality of the internal expression, not the value.

pfloor :: Proc_Float -> Proc_IntSource

Calculate the floor of a Proc_Float.

pround :: Proc_Float -> Proc_IntSource

Round a number to the closest integer.

Char

fromChar :: Char -> Proc_CharSource

Cast a Char value.

Text

fromStText :: Text -> Proc_TextSource

Cast a strict Text value.

Image

Processing classes

class Proc_Eq a whereSource

Eq class for Proc_* values.

Methods

(#==) :: a -> a -> Proc_BoolSource

(#/=) :: a -> a -> Proc_BoolSource

class Proc_Ord a whereSource

Ord class for Proc_* values.

Methods

(#<=) :: a -> a -> Proc_BoolSource

(#<) :: a -> a -> Proc_BoolSource

(#>=) :: a -> a -> Proc_BoolSource

(#>) :: a -> a -> Proc_BoolSource

Conditional values

if_ :: ProcType a => Proc_Bool -> a -> a -> aSource

Conditional value.