{-# LANGUAGE TypeFamilies #-} {-# OPTIONS -Wall #-} module TransformEllipse where import Wumpus.Core import Wumpus.Core.Colour import Data.AffineSpace -- package: vector-space import System.Directory main :: IO () main = do createDirectoryIfMissing True "./out/" writeEPS "./out/transform_ellipse01.eps" pic1 writeSVG "./out/transform_ellipse01.svg" pic1 writeEPS "./out/transform_ellipse02.eps" pic2 writeSVG "./out/transform_ellipse02.svg" pic2 writeEPS "./out/transform_ellipse03.eps" pic3 writeSVG "./out/transform_ellipse03.svg" pic3 writeEPS "./out/transform_ellipse04.eps" pic4 writeSVG "./out/transform_ellipse04.svg" pic4 writeEPS "./out/transform_ellipse05.eps" pic5 writeSVG "./out/transform_ellipse05.svg" pic5 pic1 :: Picture Double pic1 = cb `picOver` ell `picOver` xy_frame "no transform" where ell = mkRedEllipse id 20 10 pt cb = crossbar 20 10 pt pt = P2 70 10 pic2 :: Picture Double pic2 = cb `picOver` ell `picOver` xy_frame "rotate 30deg" where ell = mkRedEllipse (rotate ang) 20 10 pt cb = rotate ang $ crossbar 20 10 pt pt = P2 70 10 ang = 0.25*pi pic3 :: Picture Double pic3 = cb `picOver` ell `picOver` xy_frame "rotateAbout (60,0) 30deg" where ell = mkRedEllipse (rotateAbout ang pto) 20 10 pt cb = rotateAbout ang pto $ crossbar 20 10 pt pt = P2 70 10 pto = P2 60 0 ang = 0.25*pi pic4 :: Picture Double pic4 = cb `picOver` ell `picOver` xy_frame "scale 1 2" where ell = mkRedEllipse (scale 1 2) 20 10 pt cb = scale 1 2 $ crossbar 20 10 pt pt = P2 70 10 pic5 :: Picture Double pic5 = cb `picOver` ell `picOver` xy_frame "translate -70 -10" where ell = mkRedEllipse (translate (-70) (-10)) 20 10 pt cb = translate (-70) (-10) $ crossbar 20 10 pt pt = P2 70 10 mkRedEllipse :: (Real u, Floating u, FromPtSize u) => (Primitive u -> Primitive u) -> u -> u -> Point2 u -> Picture u mkRedEllipse trafo rx ry pt = frame [ trafo $ fillEllipse red rx ry pt] crossbar :: (Real u, Floating u, FromPtSize u) => u -> u -> Point2 u -> Picture u crossbar rx ry ctr = frame [ostroke black default_stroke_attr $ primPath west ps] where ps = [ lineTo east, lineTo ctr, lineTo north, lineTo south ] north = ctr .+^ vvec ry south = ctr .-^ vvec ry east = ctr .+^ hvec rx west = ctr .-^ hvec rx xy_frame :: (Real u, Floating u, FromPtSize u) => String -> Picture u xy_frame ss = frame [ mkline (P2 (-4) 0) (P2 150 0) , mkline (P2 0 (-4)) (P2 0 150) , textlabel black wumpus_default_font ss (P2 0 (-20)) ] where mkline p1 p2 = ostroke black default_stroke_attr $ primPath p1 [lineTo p2]