module Wumpus.Drawing.Dots.Marks
(
markChar
, markText
, markHLine
, markVLine
, markX
, markPlus
, markCross
, markDiamond
, markFDiamond
, markBDiamond
, markDisk
, markSquare
, markCircle
, markPentagon
, markStar
, markAsterisk
, markOPlus
, markOCross
, markFOCross
, markTriangle
) where
import Wumpus.Drawing.Text.Base.RotTextZero
import Wumpus.Basic.Geometry.Paths
import Wumpus.Basic.Kernel
import Wumpus.Core
import Data.AffineSpace
import Data.VectorSpace
infixr 9 `renderPathWith`
renderPathWith :: LocQuery u PrimPath
-> (PrimPath -> Graphic u)
-> LocGraphic u
renderPathWith qy mk = promoteR1 $ \pt -> apply1R1 qy pt >>= mk
markChar :: (Real u, Floating u, InterpretUnit u) => Char -> LocGraphic u
markChar ch = markText [ch]
markText :: (Real u, Floating u, InterpretUnit u) => String -> LocGraphic u
markText ss = pushR1 ignoreAns $ ccTextline ss
axialLine :: (Fractional u, InterpretUnit u) => Vec2 u -> LocGraphic u
axialLine v = moveStart (\ctr -> ctr .-^ (0.5 *^ v)) (locStraightLine v)
markHLine :: (Fractional u, InterpretUnit u) => LocGraphic u
markHLine = markHeight >>= \h -> axialLine (hvec h)
markVLine :: (Fractional u, InterpretUnit u) => LocGraphic u
markVLine = markHeight >>= \h -> axialLine (vvec h)
markX :: (Fractional u, InterpretUnit u) => LocGraphic u
markX = markHeight >>= mkX
where
mkX h = let w = 0.75 * h
in axialLine (vec w h) `oplus` axialLine (vec (w) h)
markPlus :: (Fractional u, InterpretUnit u) => LocGraphic u
markPlus = markVLine `oplus` markHLine
markCross :: (Floating u, InterpretUnit u) => LocGraphic u
markCross = markHeight >>= mkCross
where
mkCross h = axialLine (avec ang h) `oplus` axialLine (avec (ang) h)
ang = pi*0.25
pathDiamond :: (Fractional u, InterpretUnit u)
=> LocQuery u PrimPath
pathDiamond = promoteR1 $ \pt ->
markHeight >>= \h -> let cp = diamondCoordPath (0.5*h) (0.66*h)
in coordinatePrimPath cp pt
markDiamond :: (Fractional u, InterpretUnit u) => LocGraphic u
markDiamond = pathDiamond `renderPathWith` closedStroke
markFDiamond :: (Fractional u, InterpretUnit u) => LocGraphic u
markFDiamond = pathDiamond `renderPathWith` filledPath
markBDiamond :: (Fractional u, InterpretUnit u) => LocGraphic u
markBDiamond = pathDiamond `renderPathWith` borderedPath
markDisk :: (Fractional u, InterpretUnit u) => LocGraphic u
markDisk = markHalfHeight >>= filledDisk
markSquare :: (Fractional u, InterpretUnit u) => LocGraphic u
markSquare =
markHeight >>= \h ->
let d = 0.5*(h) in moveStart (displace d d) $ strokedRectangle h h
markCircle :: (Fractional u, InterpretUnit u) => LocGraphic u
markCircle = markHalfHeight >>= strokedDisk
markBCircle :: (Fractional u, InterpretUnit u) => LocGraphic u
markBCircle = markHalfHeight >>= borderedDisk
markPentagon :: (Floating u, InterpretUnit u) => LocGraphic u
markPentagon = promoteR1 $ \pt ->
pentagonPath pt >>= closedStroke
where
pentagonPath pt = markHalfHeight >>= \hh ->
coordinatePrimPath (polygonCoordPath 5 hh) pt
markStar :: (Floating u, InterpretUnit u) => LocGraphic u
markStar = markHeight >>= \h -> starLines (0.5*h)
starLines :: (Floating u, InterpretUnit u) => u -> LocGraphic u
starLines hh = promoteR1 $ \ctr ->
let cp = polygonCoordPath 5 hh
in step $ map (fn ctr) $ cp ctr
where
fn p0 p1 = straightLine p0 p1
step (x:xs) = oconcat x xs
step _ = error "starLines - unreachable"
markAsterisk :: (Floating u, InterpretUnit u) => LocGraphic u
markAsterisk = markHeight >>= asteriskLines
asteriskLines :: (Floating u, InterpretUnit u) => u -> LocGraphic u
asteriskLines h = lineF1 `oplus` lineF2 `oplus` lineF3
where
ang = (pi*2) / 6
lineF1 = axialLine (vvec h)
lineF2 = axialLine (avec ((pi*0.5) + ang) h)
lineF3 = axialLine (avec ((pi*0.5) + ang + ang) h)
markOPlus :: (Fractional u, InterpretUnit u) => LocGraphic u
markOPlus = markCircle `oplus` markPlus
markOCross :: (Floating u, InterpretUnit u) => LocGraphic u
markOCross = markCircle `oplus` markCross
markFOCross :: (Floating u, InterpretUnit u) => LocGraphic u
markFOCross = markCross `oplus` markBCircle
markTriangle :: (Floating u, InterpretUnit u) => LocGraphic u
markTriangle = tripath `renderPathWith` closedStroke
where
tripath = promoteR1 $ \pt ->
markHeight >>= \h ->
let cp = equilateralTriangleCoordPath h
in coordinatePrimPath cp pt