{-# OPTIONS -Wall #-} module FontMetrics where import Wumpus.Core import Data.AffineSpace -- package: vector-space import System.Directory main :: IO () main = do createDirectoryIfMissing True "./out/" writeEPS_latin1 "./out/font_metrics.eps" metrics_pic writeSVG_latin1 "./out/font_metrics.svg" metrics_pic peru :: RGBi peru = RGBi 205 133 63 plum :: RGBi plum = RGBi 221 160 221 black :: RGBi black = RGBi 0 0 0 courier_attr :: FontAttr courier_attr = FontAttr 48 (FontFace "Courier" "Courier New" SVG_REGULAR latin1_font_encoder) metrics_pic :: DPicture metrics_pic = char_pic `picOver` lines_pic lines_pic :: DPicture lines_pic = frame $ [ ascender_line, numeral_line, xheight_line, baseline, descender_line ] where descender_pos = 0 - courier48_descender_depth ascender_line = haxis peru (descender_pos + courier48_height) numeral_line = haxis peru courier48_numeral_height xheight_line = haxis peru courier48_xheight baseline = haxis peru 0 descender_line = haxis peru descender_pos char_pic :: Picture Double char_pic = frame $ zipWith ($) chars (iterate (.+^ hvec 32) zeroPt) where chars = (map letter "ABXabdgjxy12") ++ [agraveU] type PrimF = DPoint2 -> DPrimElement bodyHeight :: PrimF bodyHeight = vertLine peru $ fromPtSize courier48_numeral_height agraveU :: PrimF agraveU = textlabel black courier_attr "&#Agrave" letter :: Char -> DPoint2 -> DPrimElement letter ch pt = textlabel black courier_attr [ch] pt vertLine :: RGBi -> Double -> DPoint2 -> DPrimElement vertLine rgb height pt = ostroke rgb default_stroke_attr $ vertexPath [pt, pt .+^ vvec height] haxis :: RGBi -> PtSize -> DPrimElement haxis rgb ypos = ostroke rgb dash_attr $ vertexPath [ pt, pt .+^ hvec 440 ] where dash_attr = default_stroke_attr { dash_pattern = Dash 0 [(2,2)] } pt = P2 0 (fromPtSize ypos)