12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849 |
- (*
- * 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
- IO.nwrite_string ch "{\n\t";
- IO.nwrite_string ch (String.concat ",\n\t" (List.map (fun (key,paths) ->
- (Printf.sprintf "\"g%i\":[" key)
- ^ (String.concat "," (List.map (fun path ->
- match path.gp_type with
- | 0 -> Printf.sprintf "[0,%.2f,%.2f]" (path.gp_x *. scale) (path.gp_y *. scale *. (-1.))
- | 1 -> Printf.sprintf "[1,%.2f,%.2f]" (path.gp_x *. scale) (path.gp_y *. scale *. (-1.))
- | 2 -> Printf.sprintf "[2,%.2f,%.2f,%.2f,%.2f]" (path.gp_cx *. scale) (path.gp_cy *. scale *. (-1.)) (path.gp_x *. scale) (path.gp_y *. scale *. (-1.))
- | _ -> assert false
- ) paths))
- ^ "]";
- ) glyphs));
- IO.nwrite_string ch "\n}"
- let to_json 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
|