| Copyright | (c) 2015 Jeffrey Rosenbluth |
|---|---|
| License | BSD-style (see LICENSE) |
| Maintainer | jeffrey.rosenbluth@gmail.com |
| Safe Haskell | None |
| Language | Haskell2010 |
Graphics.Svg
Description
DSL for creating SVG.
- module Graphics.Svg.Core
- module Graphics.Svg.Path
- module Graphics.Svg.Elements
- module Graphics.Svg.Attributes
- (<>) :: Monoid m => m -> m -> m
- prettyText :: Element -> Text
Intro
SVG elements in Graphics-Svg are written with a postfix ‘_’.
Some examples:
path_, circle_, color_, scale_
Plain text is written using the OverloadedStrings
extension, and is automatically escaped:
As in Graphics, elements nest by function application (unlike Graphics, there
is no Monad instance for Elements and an Attribute list is always required):
>>>g_ [] (text_ [] "Hello SVG")<g><text>Hello SVG</text></g>
and elements are juxtaposed via monoidal append:
>>>text_ [] "Hello" <> text_ [] "SVG"<text>Hello</text><text>SVG</text>
Attributes are set by providing an argument list. Each argument is set
using the bindAttr function or operators, <<- and ->>.
>>>rect_ [Width_ <<- "100%", Height_ <<- "100%", "red" ->> Fill_]<rect height="100%" width="100%" fill="red"></rect>
Path data can be constructed using the functions in Path
and combined monoidally:
path_ [ D_ (mA 10 80 < qA 52.5 10 95 80 <> tA 180 80 <> z) , Stroke_ <<- "blue" , Fill_ <<- "orange" ]
<path d="M 10,80 Q 52.5,10 95,80 T 180,80 Z" stroke="blue" fill="orange"/>
A slightly longer example
import Graphics.Svg
svg :: Element -> Element
svg content =
doctype
<> with (svg11_ content) [Version_ <<- "1.1", Width_ <<- "300" , Height_ <<- "200"]
contents :: Element
contents =
rect_ [Width_ <<- "100%", Height_ <<- "100%", Fill_ <<- "red"]
<> circle_ [Cx_ <<- "150", Cy_ <<- "100", R_ <<- "80", Fill_ <<- "green"]
<> text_ [ X_ <<- "150", Y_ <<- "125", FontSize_ <<- "60"
, TextAnchor_ <<- "middle", Fill_ <<- "white" ] "SVG"
main :: IO ()
main = do
print $ svg contents
The haskell logo
{-# LANGUAGE OverloadedStrings #-}
import Graphics.Svg
svg :: Element -> Element
svg content =
doctype
<> with (svg11_ content) [Version_ <<- "1.1", Width_ <<- "482", Height_ <<- "340"]
logo :: Element
logo =
path_ [ Fill_ <<- "#352950"
, D_ <<- ( mA 0 340 <> lA 113 170 <> lA 0 0 <> lA 85 0
<> lA 198 170 <> lA 85 340 <> lA 0 340 <> z <> mA 0 340 ) ]
<> path_ [ Fill_ <<- "#4A3A74"
, D_ <<- ( mA 113 340 <> lA 226 170 <> lA 113 0 <> lA 198 0
<> lA 425 340 <> lA 340 340 <> lA 269 234 <> lA 198 340
<> lA 113 340 <> z <> mA 113 340 ) ]
<> path_ [ Fill_ <<- "#7C3679"
, D_ <<- ( mA 387 241 <> lA 350 184 <> lA 482 184 <> lA 482 241
<> lA 387 241 <> z <> mA 387 241 ) ]
<> path_ [ Fill_ <<- "#7C3679"
, D_ <<- ( mA 331 156 <> lA 293 99 <> lA 482 99 <> lA 482 156
<> lA 331 156 <> z <> mA 331 156 ) ]
main :: IO ()
main = do
print $ svg logo
module Graphics.Svg.Core
module Graphics.Svg.Path
module Graphics.Svg.Elements
module Graphics.Svg.Attributes
Rendering
prettyText :: Element -> Text Source #