# HG changeset patch # User Thinker K.F. Li # Date 1276065860 -28800 # Node ID f87a368e847aa472c32c3c4ac828555d31c0373c # Parent d796e6b8b97e79a2bdf948eb52e0c1319163ad80 Functions of stroke and fill a shape diff -r d796e6b8b97e -r f87a368e847a nodejs/paints.cc --- a/nodejs/paints.cc Wed Jun 09 14:10:58 2010 +0800 +++ b/nodejs/paints.cc Wed Jun 09 14:44:20 2010 +0800 @@ -13,6 +13,71 @@ #endif +/*! \brief Fill a shape with the paint. + */ +static Handle +xnjsmb_paint_fill(const Arguments &args) { + int argc = args.Length(); + Handle self = args.This(); + Handle sh_obj; + Handle rt; + Handle rt_val; + paint_t *paint; + shape_t *sh; + redraw_man_t *rdman; + + if(argc != 1) + THROW("Invalid number of arguments (!= 1)"); + if(!args[0]->IsObject()) + THROW("Invalid argument type (shape)"); + + paint = (paint_t *)UNWRAP(self); + + sh_obj = args[0]->ToObject(); + sh = (shape_t *)UNWRAP(sh_obj); + + rt_val = GET(self, "mbrt"); + rt = rt_val->ToObject(); + rdman = xnjsmb_rt_rdman(rt); + + rdman_paint_fill(rdman, paint, sh); + + return Null(); +} + +/*! \brief Stroke a shape with the paint. + */ +static Handle +xnjsmb_paint_stroke(const Arguments &args) { + int argc = args.Length(); + Handle self = args.This(); + Handle sh_obj; + Handle rt; + Handle rt_val, sh_val; + paint_t *paint; + shape_t *sh; + redraw_man_t *rdman; + + if(argc != 1) + THROW("Invalid number of arguments (!= 1)"); + if(!args[0]->IsObject()) + THROW("Invalid argument type (shape)"); + + paint = (paint_t *)UNWRAP(self); + + sh_val = args[0]; + sh_obj = sh_val->ToObject(); + sh = (shape_t *)UNWRAP(sh_obj); + + rt_val = GET(self, "mbrt"); + rt = rt_val->ToObject(); + rdman = xnjsmb_rt_rdman(rt); + + rdman_paint_stroke(rdman, paint, sh); + + return Null(); +} + /*! \brief Constructor of color paint_color_t object for Javascript. */ static Handle @@ -42,6 +107,7 @@ ASSERT(sh != NULL); WRAP(self, paint); + SET(self, "mbrt", rt); return Null(); } @@ -88,8 +154,9 @@ */ static void xnjsmb_init_paints(void) { - Handle temp; + Handle temp, meth; Handle inst_temp; + Handle proto_temp; /* * Base type of paint types. @@ -97,6 +164,14 @@ temp = FunctionTemplate::New(); xnjsmb_paint_temp = Persistent::New(temp); xnjsmb_paint_temp->SetClassName(String::New("paint")); + + meth = FunctionTemplate::New(xnjsmb_paint_fill); + proto_temp = xnjsmb_paint_temp->PrototypeTemplate(); + SET(proto_temp, "fill", meth); + + meth = FunctionTemplate::New(xnjsmb_paint_stroke); + proto_temp = xnjsmb_paint_temp->PrototypeTemplate(); + SET(proto_temp, "stroke", meth); /* * Paint color diff -r d796e6b8b97e -r f87a368e847a nodejs/shapes.cc --- a/nodejs/shapes.cc Wed Jun 09 14:10:58 2010 +0800 +++ b/nodejs/shapes.cc Wed Jun 09 14:44:20 2010 +0800 @@ -89,6 +89,7 @@ sh = rdman_shape_path_new(rdman, dstr); WRAP(self, sh); + SET(self, "mbrt", rt); return Null(); } diff -r d796e6b8b97e -r f87a368e847a nodejs/testcase.js --- a/nodejs/testcase.js Wed Jun 09 14:10:58 2010 +0800 +++ b/nodejs/testcase.js Wed Jun 09 14:44:20 2010 +0800 @@ -12,13 +12,14 @@ [coord[0], coord[1], coord[2], coord[3], coord[4], coord[5]]); sys.puts(mb_rt.path_new); -var path = mb_rt.path_new("m 100,100 L 200,200"); +var path = mb_rt.path_new("m 100,50 L 120,50 L 200,150 L 150,150 z"); sys.puts(path); sys.puts(coord.add_shape); coord.add_shape(path); sys.puts(mb_rt.paint_color_new); -var paint = mb_rt.paint_color_new(1, 1, 1, 1); +var paint = mb_rt.paint_color_new(1.0, 1.0, 1.0, 1.0); sys.puts(paint); +paint.stroke(path); setTimeout(function() { sys.puts("timeout"); }, 1000);