320 likes | 541 Views
Graphical User Interfaces in Haskell. Koen Lindström Claessen. First a Demo. An editor for simple straight line drawings. Line currently being drawn by dragging the mouse. A graphical user interface. Remove last line drawn. Load and save drawings to files. Saving a Drawing.
E N D
Graphical User Interfaces in Haskell Koen Lindström Claessen
First a Demo An editor for simple straight line drawings Line currently being drawn by dragging the mouse A graphical user interface Remove last line drawn Load and save drawings to files
Saving a Drawing File selection dialogue
GUI Libraries • GUI programming is complex • Much graphics programming needed • Many different elements needed (buttons, scroll bars, menus, entry fields…) • It is not practical to write a GUI from scratch • We must use an existing GUI library
Portability • Every platform provides a GUI library… • …but they are all different! • The differences are more than just skin deep • How do we write portable programs with GUIs?
Two Roads to Portability Applications Applications New portable GUI library Portable interface Windows GUI lib Mac GUI library Linux GUI lib Windows Mac Linux Windows Mac Linux • The Java approach • Interfaces ”look funny” • The wxWindows approach • Native look and feel
wxHaskell Haskell applications Industrial strength open source library wxHaskell 500 C++ classes with 4000 methods! wxWindows Windows GUI lib Mac GUI library Linux GUI lib • There are many ”native Haskell” GUI libraries: • More ”Haskellish” • Generally not portable • Generally less complete • wxHaskell is a good compromise. Windows Mac Linux
GHC • wxHaskell only works with GHC • Glasgow Haskell compiler Prog.hs prog Haskell main program ghc –package wx –make Prog -o prog Compiled code A compiled program like any other Cannot call individual functions in an interpreter
Haskell Main Programs • Definition main :: IO () • In module Main (the default) Main programs produce no ”result” – they just do input/output Hello.hs main :: IO () main = do putStrLn ”What is your name?” name <- getLine putStrLn (”Hello ”++name)
Hello with a GUI import Graphics.UI.WX main :: IO () main = start gui gui :: IO () gui = do f <- frame [text := "Hello"] inp <- entry f [] out <- entry f [] but <- button f [ text := "Hello” , on command := do s <- get inp text set out [text := "Hello "++s] ] set f [ layout := floatCentre $ column 5 [ label "What is your name?” , widget inp , widget but , widget out ] ] Import wxHaskell (a hierarchical library) Start up the GUI
GUI Concepts A frame – top level window Panel Panel Panel Several panels contained in one frame Widgets – ”WIndow gaDGETS” Entry fields and buttons are controls
GUI Hierarchy • Every GUI element (except a frame) has a parent • We specify the parent at creation Create a frame (no parent) f <- frame [text := "Hello"] inp <- entry f [] out <- entry f [] but <- button f [text := "Hello", on command := do s <- get inp text set out [text := "Hello "++s]] Create two entry fields (with parent f) Create a button (with parent f) The first parameter of a creation call is always the parent.
Attributes • GUI elements have attributes • Rather like the fields of a record, or components of a data structure • Types: Attr w a • An attribute of type a, for a widget of type w • Attributes can be specified at creation • Type checker ensures attributes match the widget type f <- frame [text := "Hello"] Create a frame with text attribute ”Hello” Do not confuse this with assignment – we are just specifying a list of attribute values
Overloading • The same attribute name can be used with many different widget types • Attribute names are overloaded • Type: text :: Textual w => Attr w String • Same idea used for many, many attributes f <- frame [text := "Hello"] but <- button f [text := "Hello”]
Layout • The layout attribute specifies the appearance on the screen f <- frame [text := "Hello"] set f [layout := floatCentre $ column 5 [label "What is your name?", widget inp, widget but, widget out]] Place argument in the centre of the frame widget converts GUI elements to a layout for inclusion in a frame
Instructions • Controls have attributes which are instructions to follow if the user activates them • A GUI’s purpose is to let a user give instructions to the computer These instructions are followed when the button is pressed but <- button f [text := "Hello", on command := do s <- get inp text set out [text := "Hello "++s]] on creates an instruction attribute
Modifying Attributes • Attributes can be read and modified • Modifying attributes changes what appears on the screen Instructions to read the value of an attribute do s <- get inp text set out [text := "Hello "++s]] Instructions to modify one or more attributes
Invisible Widgets • Some widgets are invisible • They still have attributes that can be set and modified • Examples: • Timer widget • Interval • On command • Variable widget • Value
Functions vs. Instructions Only the knowledge about the string is needed to understand the result… Compare: f :: String -> Int vs g :: String -> IO Int Anything can be used to compute the result: Reading from files, randomness, user input…! Moreover, anything can be modified or changed!
Design Principles • Separate the GUI from the functionality as much as possible • So that the GUI can later be replaced without changing the functionality • Avoid duplicating code as far as possible • So that errors need be fixed only once (c.f. ”cut and paste programming”)
Modelling the State • A GUI is often used to edit or modify something • What is the state?
Examples • Hello.hs • Simple hello example • BouncingBalls.hs • A simple animation containing bouncing balls • Draw.hs • A simple drawing program • Mine.hs • A version of the game minesweeper
How do I find the right function? • Haskell has many hierarchical libraries, with documentation on the web • Every wxHaskell function is documented on the web • Know how to find the documentation!
haskell.org Libraries!
haskell.org/libraries/ Hierarchical libraries! You have these already.
Hierarchical Libraries Lots of modules
Googling wxHaskell Here it is!
wxHaskell Home Page Documentation
wxHaskell Documentation Haddock documentation for wxHaskell General information on wxWidgets – sometimes you have to read this
wxHaskell Haddock Controls: Buttons, entry fields etc Layout: Operators to build layouts Classes: one for each attribute Draw: Functions for drawing on a panel Dialogs: Built-in popups, e.g. for choosing a file And much, much, more! Ignore WXCore! It’s a level below wxHaskell Attributes: defines set, get, (:=), …
Reading • http://wxhaskell.sourceforge.net/ • wxHaskell: A Portable and Concise GUI Library for Haskell, Daan Leijen • Haskell Workshop, Salt Lake City, 2004 • http://www.cs.uu.nl/~daan/download/papers/wxhaskell.pdf