Reactive-banana/Examples: Difference between revisions
Line 11: | Line 11: | ||
; [https://github.com/HeinrichApfelmus/Haskell-BlackBoard/blob/master/reactive-banana-wx/src/Counter.hs Counter.hs] | ; [https://github.com/HeinrichApfelmus/Haskell-BlackBoard/blob/master/reactive-banana-wx/src/Counter.hs Counter.hs] | ||
: A simple counter that can be manipulated with two buttons "Up" or "Down". | : A simple counter that can be manipulated with two buttons "Up" or "Down". Demonstrates the <code>accumD</code> function. | ||
[[Image:Reactive-banana-Counter.png]] | [[Image:Reactive-banana-Counter.png]] | ||
; [https://github.com/HeinrichApfelmus/Haskell-BlackBoard/blob/master/reactive-banana-wx/src/NetMonitor.hs NetMonitor.hs] | |||
: Minimalistic application that displays network statistics in real time. Demonstrates the <code>fromPoll</code> function. | |||
[[Image:Reactive-banana-NetMonitor.png]] | |||
; [https://github.com/HeinrichApfelmus/Haskell-BlackBoard/blob/master/reactive-banana-wx/src/CurrencyConverter.hs CurrencyConverter.hs] | ; [https://github.com/HeinrichApfelmus/Haskell-BlackBoard/blob/master/reactive-banana-wx/src/CurrencyConverter.hs CurrencyConverter.hs] | ||
: Simple currency converter. Reads | : Simple currency converter. Reads and writes values to text entry widgets. (Does wxHaskell offer a way to make this real-time?) Demonstrates how to use value recursion in the <code>NetworkDescription</code> monad. | ||
[[Image:Reactive-banana-CurrencyConverter.png]] | [[Image:Reactive-banana-CurrencyConverter.png]] | ||
; [https://github.com/HeinrichApfelmus/Haskell-BlackBoard/blob/master/reactive-banana-wx/src/TwoCounters.hs TwoCounters.hs] | ; [https://github.com/HeinrichApfelmus/Haskell-BlackBoard/blob/master/reactive-banana-wx/src/TwoCounters.hs TwoCounters.hs] | ||
: Two simple counters. There is only one pair of buttons "Up" or "Down", the button "Switch Counters" allows you to specify which counter should be affected. | : Two simple counters. There is only one pair of buttons "Up" or "Down", the button "Switch Counters" allows you to specify which counter should be affected. [[Image:Reactive-banana-TwoCounters.png]] | ||
[[Image:Reactive-banana-TwoCounters.png]] | |||
== GUI Examples - More elaborate == | == GUI Examples - More elaborate == |
Revision as of 12:41, 14 July 2011
Examples for the reactive-banana library.
Core Examples
- SlotMachine.hs
- Mainly demonstrates how to set up an event network with your own event loop. Also demonstrates the FRP functionality.
- RunPause.hs
- Demonstrates how to set up an event network with your own event loop and how to pause or resume it.
GUI Examples - Very simple
- Counter.hs
- A simple counter that can be manipulated with two buttons "Up" or "Down". Demonstrates the
accumD
function.
- NetMonitor.hs
- Minimalistic application that displays network statistics in real time. Demonstrates the
fromPoll
function.
- CurrencyConverter.hs
- Simple currency converter. Reads and writes values to text entry widgets. (Does wxHaskell offer a way to make this real-time?) Demonstrates how to use value recursion in the
NetworkDescription
monad.
- TwoCounters.hs
- Two simple counters. There is only one pair of buttons "Up" or "Down", the button "Switch Counters" allows you to specify which counter should be affected.
GUI Examples - More elaborate
- Asteroids.hs
- Port of the wxAsteroids example.
- Wave.hs
- A wave-like pattern. Not the most beautiful code, but it demonstrates that you can generated timed events.