module Diagrams.TwoD.Model
(
showOrigin
, showOrigin'
, OriginOpts(..), oColor, oScale, oMinSize
, showLabels
) where
import Control.Lens (makeLenses, (^.))
import Diagrams.Core
import Diagrams.TwoD.Attributes
import Diagrams.Path
import Diagrams.TwoD.Ellipse
import Diagrams.TwoD.Path
import Diagrams.TwoD.Size (size2D)
import Diagrams.TwoD.Text
import Diagrams.TwoD.Types
import Diagrams.Util
import Control.Arrow (second)
import Data.AffineSpace ((.-.))
import Data.Default.Class
import Data.Semigroup
import Data.VectorSpace ((^*))
import qualified Data.Map as M
import Data.Colour (Colour)
import Data.Colour.Names
data OriginOpts = OriginOpts { _oColor :: Colour Double
, _oScale :: Double
, _oMinSize :: Double
}
makeLenses ''OriginOpts
instance Default OriginOpts where
def = OriginOpts red (1/50) 0.001
showOrigin :: (Renderable (Path R2) b, Backend b R2, Monoid' m)
=> QDiagram b R2 m -> QDiagram b R2 m
showOrigin = showOrigin' def
showOrigin' :: (Renderable (Path R2) b, Backend b R2, Monoid' m)
=> OriginOpts -> QDiagram b R2 m -> QDiagram b R2 m
showOrigin' oo d = o <> d
where o = stroke (circle sz)
# fc (oo^.oColor)
# lineWidth (Output 0)
# fmap (const mempty)
(w,h) = size2D d ^* oo^.oScale
sz = maximum [w, h, oo^.oMinSize]
showLabels :: (Renderable Text b, Backend b R2, Semigroup m)
=> QDiagram b R2 m -> QDiagram b R2 Any
showLabels d =
( mconcat
. map (\(n,p) -> text (show n) # translate (p .-. origin))
. concatMap (\(n,ps) -> zip (repeat n) ps)
. (map . second . map) location
. M.assocs
$ m
) <>
fmap (const (Any False)) d
where
SubMap m = d^.subMap