diff nodejs/svg.js @ 861:e69f551e4a37 abs_n_rel_center

Move initial values of bbox and center to bbox.orig and center.orig
author Thinker K.F. Li <thinker@codemud.net>
date Tue, 21 Sep 2010 00:28:44 +0800
parents ea1e88c40548
children 881efcd8a18f
line wrap: on
line diff
--- a/nodejs/svg.js	Mon Sep 20 22:43:44 2010 +0800
+++ b/nodejs/svg.js	Tue Sep 21 00:28:44 2010 +0800
@@ -385,10 +385,10 @@
     update: function() {
 	var mtx;
 
-	this.x = this._svg_saved_x;
-	this.y = this._svg_saved_y;
-	this.width = this._svg_saved_width;
-	this.height = this._svg_saved_height;
+	this.x = this.orig.x;
+	this.y = this.orig.y;
+	this.width = this.orig.width;
+	this.height = this.orig.height;
 	
 	mtx = this._saved_to_current();
 	_transform_bbox(this, mtx);
@@ -459,7 +459,7 @@
 	var xy;
 
 	mtx = this._saved_to_current();
-	xy = _pnt_transform(this._svg_saved_x, this._svg_saved_y, mtx);
+	xy = _pnt_transform(this.orig.x, this.orig.y, mtx);
 
 	this._x = xy[0];
 	this._y = xy[1];
@@ -507,7 +507,7 @@
 	var xy;
 	
 	rev = this._get_ac_rev();
-	xy = _pnt_transform(this._svg_saved_x, this._svg_saved_y, rev);
+	xy = _pnt_transform(this.orig.x, this.orig.y, rev);
 
 	return {x: xy[0], y: xy[1]};
     },
@@ -517,44 +517,54 @@
     var a;
     var vstr;
     var bbox, center;
+    var orig;
     
     a = node.attr("bbox-x");
     sys.puts("a="+a);
     if(!a)
 	return 0;
     
+    /* bbox.orig is initial values of bbox.  The bbox is recomputed
+     * according bbox.orig and current matrix.  See bbox.update().
+     */
     tgt.bbox = bbox = new Object();
+    bbox.orig = orig = new Object();
     bbox.owner = tgt;
     bbox.__proto__ = _bbox_proto;
     vstr = a.value();
-    bbox._svg_saved_x = parseFloat(vstr);
+    orig.x = parseFloat(vstr);
 
     a = node.attr("bbox-y");
     vstr = a.value();
-    bbox._svg_saved_y = this.height - parseFloat(vstr);
+    orig.y = this.height - parseFloat(vstr);
 
     a = node.attr("bbox-width");
     vstr = a.value();
-    bbox._svg_saved_width = parseFloat(vstr);
+    orig.width = parseFloat(vstr);
 
     a = node.attr("bbox-height");
     vstr = a.value();
-    bbox._svg_saved_height = parseFloat(vstr);
-    bbox._svg_saved_y -= bbox._svg_saved_height;
+    orig.height = parseFloat(vstr);
+    orig.y -= orig.height;
     
     bbox.update();
 
+    /* center.orig is initial values of center.  The center is
+     * recomputed according center.orig and current matrix.  See
+     * center.update().
+     */
     tgt.center = center = new Object();
+    center.orig = orig = new Object();
     
-    center._svg_saved_x = bbox._svg_saved_width / 2 + bbox._svg_saved_x;
-    center._svg_saved_y = bbox._svg_saved_height / 2 + bbox._svg_saved_y;
+    orig.x = bbox.orig.width / 2 + bbox.orig.x;
+    orig.y = bbox.orig.height / 2 + bbox.orig.y;
     a = node.attr("transform-center-x");
     if(a) {
 	vstr = a.value();
-	center._svg_saved_x += parseFloat(vstr);
+	orig.x += parseFloat(vstr);
 	a = node.attr("transform-center-y");
 	vstr = a.value();
-	center._svg_saved_y -= parseFloat(vstr);
+	orig.y -= parseFloat(vstr);
     }
     center.__proto__ = _center_proto;
     center.owner = tgt;