module Wumpus.Core.PageTranslation
(
trivialTranslation
) where
import Wumpus.Core.AffineTrans
import Wumpus.Core.PictureInternal
import Wumpus.Core.TrafoInternal
trivialTranslation :: (Num u, Ord u) => Picture u -> Picture u
trivialTranslation pic = scale 1 (1) (trivPic pic)
trivPic :: Num u => Picture u -> Picture u
trivPic (Leaf lc ones) = Leaf lc $ fmap trivPrim ones
trivPic (Picture lc ones) = Picture lc $ fmap trivPic ones
trivPic (Clip lc pp pic) = Clip lc pp $ trivPic pic
trivPrim :: Num u => Primitive u -> Primitive u
trivPrim (PPath a pp) = PPath a pp
trivPrim (PLabel a lbl) = PLabel a (trivLabel lbl)
trivPrim (PEllipse a ell) = PEllipse a (trivEllipse ell)
trivPrim (PContext a chi) = PContext a (trivPrim chi)
trivPrim (PSVG a chi) = PSVG a (trivPrim chi)
trivPrim (PGroup ones) = PGroup $ fmap trivPrim ones
trivLabel :: Num u => PrimLabel u -> PrimLabel u
trivLabel (PrimLabel txt ctm) = PrimLabel txt (trivPrimCTM ctm)
trivEllipse :: Num u => PrimEllipse u -> PrimEllipse u
trivEllipse (PrimEllipse hw hh ctm) = PrimEllipse hw hh (trivPrimCTM ctm)
trivPrimCTM :: Num u => PrimCTM u -> PrimCTM u
trivPrimCTM (PrimCTM dx dy sx sy theta) = PrimCTM dx dy sx (sy) theta