1 # Copyright (C) 2002-2004 Kouichirou Eto, All rights reserved.
5 require "chise/kageserver"
9 #<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.0//EN" "http://www.w3.org/TR/2001/REC-SVG-20010904/DTD/svg10.dtd">
10 #<svg viewBox="0 0 1000 1000">
11 #<path d="M 50,540 950,255 " style="fill: none; stroke: black; stroke-width: 10; stroke-linecap: round;"/>
12 #<path d="M 330,50 330,900 M 330,900 Q 330,950 380,950 M 380,950 840,950 M 840,950 Q 890,950 915,850 " style="fill: none; stroke: black; stroke-width: 10; stroke-linecap: round;"/>
16 class QuadraticPath # 動的な分割に対応できるようにする
19 def initialize(p1, p2, p3)
20 @p1, @p2, @p3 = p1, p2, p3
24 def divide_adaptic #適応的分割数をする。
31 def divide_num(num) #分割数を指定できる
36 #2次のbezier曲線の計算式、 P(t) = (1-t)^2*P1 + 2*t*(1-t)*P2 + t^2*P3
38 (num+1).times {|i| #ここで最後の点を含めないのがポイント。これによって次の曲線との重複が無いようにしている。
40 x = (1-t)*(1-t)*x1 + 2*t*(1-t)*x2 + t*t*x3
41 y = (1-t)*(1-t)*y1 + 2*t*(1-t)*y2 + t*t*y3
52 #M 330,50 330,900 M 330,900 Q 330,950 380,950 M 380,950 840,950 M 840,950 Q 890,950 915,850
67 if par.length == 1 #コマンドである
68 exec_cmd(cmd) if 0 < cmd.length #前のコマンドが残っていたら実行
70 elsif par =~ /[,0-9]+/ #座標値である
71 sx, sy = par.split(/,/)
72 x, y = sx.to_i, sy.to_i
73 cmd << [x, y] #cmdへのargを追加
76 exec_cmd(cmd) if 0 < cmd.length #前のコマンドが残っていたら実行
84 cmd.each {|x, y| moveto(x, y) }
86 quadratic([@px, @py], cmd.shift, cmd.shift)
91 @lines << [@px, @py, x, y] if @px != -1
95 def quadratic(p1, p2, p3)
96 #p ["quadratic", p1, p2, p3]
97 qp = QuadraticPath.new(p1, p2, p3)
108 @strokes = Strokes.new
109 pr = PathResolver.new
110 lines = svg.split(/\n/)
112 next unless line =~ /^<path/
113 if line =~ /d=\"([a-zA-Z0-9, ]+)\"/
114 #lines = KageParser.parse_path($1)
116 lines.each {|px, py, x, y|
117 @strokes.add_line(px, 1000-py, x, 1000-y)
125 class KageGlyph # てなかんじ
126 def initialize(code, svg)
135 @strokes = KageParser.parse(@svg)
139 parse if @strokes.nil?
145 @server = KageServer.instance
147 @cache_list = @server.list_cache
149 @rend = StrokesRenderer.new
150 # @rend.hsv = [13, 100, 100]
151 # @rend.hsv = [0, 0, 0]
152 # @rend.hsv = [13, 100, 100] #黄色
153 @rend.hsv = [6, 100, 100] #オレンジ
155 attr_reader :cache_list, :server
158 return @glyphs[code] if @glyphs[code]
159 svg = @server.get(code)
160 return nil if svg.nil?
161 @glyphs[code] = KageGlyph.new(code, svg)
169 @rend.set_strokes(glyph.strokes)
179 char = Character.new(@code)
180 printf("[%s][%04x]\n", char.nil? ? "nil" : char.map_sjis, code)