Mercurial > MadButterfly
view nodejs/svg.js @ 699:0b98bdc53215
Add binding for color changing of paint_color_t in JS
author | Thinker K.F. Li <thinker@branda.to> |
---|---|
date | Wed, 11 Aug 2010 17:38:44 +0800 |
parents | 492da72e6537 |
children | 3457519e3b9c |
line wrap: on
line source
var libxml = require('libxmljs'); var sys=require('sys'); var mbfly = require("mbfly"); var mb_rt = new mbfly.mb_rt(":0.0", 720,480); var ldr = mbfly.img_ldr_new("."); function MB_loadSVG(mb_rt,root,filename) { var doc = libxml.parseXmlFile(filename); var nodes = doc.root().childNodes(); var coord = mb_rt.coord_new(root); var k; for(k in nodes) { var n = nodes[k].name(); if (n == "defs") { _MB_parseDefs(root,nodes[k]); } else if (n == "g") { _MB_parseGroup(root,'root_coord',nodes[k]); } } } function getInteger(n,name) { if (n == null) return 0; var a = n.attr(name); if (a==null) return 0; return parseInt(a.value()); } function parsePointSize(s) { var fs=0; var i; for(i=0;i<s.length;i++) { if (s[i]<'0' || s[i] > '9') break; fs = fs*10 + (s[i]-'0'); } return fs; } function parseColor(c) { if (c[0] == '#') { return parseInt(c.substring(1,3),16)<<16 | parseInt(c.substring(3,5),16)<<8 | parseInt(c.substring(5,7),16); } } function parseTextStyle(style,n) { var attr; if (n) { attr = n.attr('style'); } else { attr = null; } if (attr == null) { return; } var f = attr.value().split(';'); for(i in f) { var kv = f[i].split(':'); if (kv[0] == 'font-size') { style.fs = parsePointSize(kv[1]); } else if (kv[0] == "font-style") { } else if (kv[0] == "font-weight") { } else if (kv[0] == "fill") { style.color = parseColor(kv[1]); } else if (kv[0] == "fill-opacity") { } else if (kv[0] == "stroke") { } else if (kv[0] == "stroke-width") { } else if (kv[0] == "stroke-linecap") { } else if (kv[0] == "stroke-linejoin") { } else if (kv[0] == "stroke-lineopacity") { } else if (kv[0] == "font-family") { style.family = kv[1]; } else if (kv[0] == "font-stretch") { } else if (kv[0] == "font-variant") { } else if (kv[0] == "text-anchor") { } else if (kv[0] == "text-align") { } else if (kv[0] == "writing-mode") { } else if (kv[0] == "line-height") { } else { sys.puts("Unknown style: "+kv[0]); } } } function _MB_parseTSpan(coord, n,style) { var x = getInteger(n,'x'); var y = getInteger(n,'y'); var tcoord = mb_rt.coord_new(coord); var nodes = n.childNodes(); var k; sys.puts(n.text()); var obj = mb_rt.stext_new(n.text(),x,y); parseTextStyle(style,n); style.paint = mb_rt.paint_color_new(1,1,1,1); style.face=mb_rt.font_face_query(style.family, 2, 100); obj.set_style([[20,style.face,style.fs]]); style.paint.fill(obj); tcoord.add_shape(obj); for(k in nodes) { var name = nodes[k].name(); if (name == "tspan") { _MB_parseTSpan(tcoord,nodes[k]); } else { } } } function _MB_parseText(coord,id, n) { var x = getInteger(n,'x'); var y = getInteger(n,'y'); var tcoord = mb_rt.coord_new(coord); var style = new Object(); style.fs = 20; style.family = 'courier'; parseTextStyle(style,n); var nodes = n.childNodes(); var k; for(k in nodes) { var n = nodes[k].name(); if (n == "tspan") { _MB_parseTSpan(tcoord,nodes[k],style); } else { } } } function parseTransform(coord, s) { var off = s.indexOf('translate'); if (off != -1) { var ss = s.substring(off+9); for(i=0;i<ss.length;i++) { if (ss[i] == '(') break; } ss = ss.substring(i+1); for(i=0;i<ss.length;i++) { if (ss[i] == ')') { ss = ss.substring(0,i); break; } } var f = ss.split(','); var x,y; x = parseInt(f[0]); y = parseInt(f[1]); coord[2] = x; coord[5] = y; } off = s.indexOf('matrix'); if (off != -1) { sys.puts("matrix"); } } function _MB_parseRect(coord, id, n) { } function _MB_parseGroup(root, group_id, n) { var k; var nodes = n.childNodes(); var coord = mb_rt.coord_new(root); // Parse the transform and style here var trans = n.attr('transform'); if (trans!=null) { parseTransform(coord, trans.value()); } for(k in nodes) { var n = nodes[k].name(); var attr = nodes[k].attr('id'); var id; if (attr) { id = attr.value(); } if (n == "g") { _MB_parseGroup(coord, id, nodes[k]); } else if (n == "text") { _MB_parseText(coord, id, nodes[k]); } else if (n == "rect") { _MB_parseRect(coord, id, nodes[k]); } else if (n == "image") { _MB_parseImage(coord, id, nodes[k]); } } } function _MB_parseImage(coord,id, n) { sys.puts("---> image"); var ref = n.attr('href').value(); if (ref == null) return; sys.puts(ref); if (ref.substr(0,7) == "file://") { ref = ref.substring(7); } else if (ref.substr(0,5)=="file:") { ref = ref.substring(5); } else { return; } sys.puts("Load image "+ref); var w; var h; var x,y; w = n.attr("width"); if (w == null) return; w = parseInt(w.value()); h = n.attr("height"); if (h == null) return; h = parseInt(h.value()); x = n.attr("x"); if (x == null) return; x = parseInt(x.value()); y = n.attr("y"); if (y == null) return; y = parseInt(y.value()); sys.puts("x="+x+",y="+y+",w="+w+",h="+h); var img = mb_rt.image_new(x,y,w,h); var img_data = ldr.load(ref); sys.puts(img_data); var paint = mb_rt.paint_image_new(img_data); paint.fill(img); coord.add_shape(img); } function _MB_parseDefs(root,n) { var k; var nodes = n.childNodes(); for(k in nodes) { var name = nodes[k].name(); if (name == "linearGradient") { //_MB_parseLinearGradient(root,nodes[k]); } } } MB_loadSVG(mb_rt,mb_rt.root,"test.svg"); mb_rt.redraw_all();