1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950 |
- (*
- * Copyright (C)2005-2014 Haxe Foundation
- *
- * Permission is hereby granted, free of charge, to any person obtaining a
- * copy of this software and associated documentation files (the "Software"),
- * to deal in the Software without restriction, including without limitation
- * the rights to use, copy, modify, merge, publish, distribute, sublicense,
- * and/or sell copies of the Software, and to permit persons to whom the
- * Software is furnished to do so, subject to the following conditions:
- *
- * The above copyright notice and this permission notice shall be included in
- * all copies or substantial portions of the Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
- * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
- * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
- * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
- * DEALINGS IN THE SOFTWARE.
- *)
- open TTFData
- open TTFTools
- let rec write_glyph ttf key glyf =
- key,TTFTools.build_glyph_paths ttf false glyf
- let write_font ch ttf glyphs =
- let scale = 1024. /. (float_of_int ttf.ttf_head.hd_units_per_em) in
- List.iter (fun (key,paths) ->
- IO.nwrite_string ch (Printf.sprintf "\tfunction key%i(ctx) {\n" key);
- IO.nwrite_string ch "\t\tctx.beginPath();\n";
- List.iter (fun path ->
- IO.nwrite_string ch (match path.gp_type with
- | 0 -> Printf.sprintf "\t\tctx.moveTo(%.2f,%.2f);\n" (path.gp_x *. scale) (path.gp_y *. scale *. (-1.))
- | 1 -> Printf.sprintf "\t\tctx.lineTo(%.2f,%.2f);\n" (path.gp_x *. scale) (path.gp_y *. scale *. (-1.))
- | 2 -> Printf.sprintf "\t\tctx.quadraticCurveTo(%.2f,%.2f,%.2f,%.2f);\n" (path.gp_cx *. scale) (path.gp_cy *. scale *. (-1.)) (path.gp_x *. scale) (path.gp_y *. scale *. (-1.))
- | _ -> assert false)
- ) paths;
- IO.nwrite_string ch "\t\tctx.fill();\n";
- IO.nwrite_string ch "\t}\n";
- ) glyphs;
- ()
- let to_canvas ttf range_str =
- let lut = TTFTools.build_lut ttf range_str in
- let glyfs = Hashtbl.fold (fun k v acc -> (k,ttf.ttf_glyfs.(v)) :: acc) lut [] in
- let glyfs = List.stable_sort (fun a b -> compare (fst a) (fst b)) glyfs in
- List.map (fun (k,g) -> write_glyph ttf k g) glyfs
|