Skip to content
Andy Gill edited this page Jun 18, 2014 · 36 revisions

Background

blank-canvas is a Haskell binding to the complete HTML5 Canvas API. blank-canvas allows Haskell users to write, in Haskell, interactive images onto their web browsers. blank-canvas gives the users a single full-window canvas, and provides many well-documented functions for rendering images.

First Example

{-# LANGUAGE OverloadedStrings #-}
module Main where

import Graphics.Blank                     -- import the blank canvas

main = blankCanvas 3000 $ \ context -> do -- start blank canvas on port 3000
        send context $ do                 -- send commands to this specific context
                moveTo(50,50)
                lineTo(200,100)
                lineWidth 10
                strokeStyle "red"
                stroke()                  -- this draws the ink into the canvas

Running this program, and going to http://localhost:3000/ gives

For more details about this example, see Red Line.

Installation

cabal install blank-canvas

That's it!

If you want the examples, the install them as well

cabal install blank-canvas-examples

We recommend downloading the blank-canvas-examples repo and building by hand (or from this github repo), simply because you then have the source to start experimenting with.

Documentation

Link Notes
Examples Various complete examples of using blank-canvas
Hackage Current release is 0.4.0
API Discussion of API, compared with the original JavaScript API
Canvas Tutorial Transliterated from http://www.html5canvastutorials.com/ into Haskell and blank-canvas, with kind permission of Eric Rowell, author of the JavaScript HTML5 Canvas Tutorial.

Other Links

Clone this wiki locally