Mercurial > MadButterfly
diff pyink/MBScene.py @ 1133:bc619172bd2c
Do translation for every elements.
author | wycc |
---|---|
date | Sun, 19 Dec 2010 00:02:31 +0800 |
parents | 3ec0ad89e443 |
children | 950076863b7e |
line wrap: on
line diff
--- a/pyink/MBScene.py Sat Dec 18 23:51:22 2010 +0800 +++ b/pyink/MBScene.py Sun Dec 19 00:02:31 2010 +0800 @@ -664,6 +664,10 @@ return [m[0],m[1],m[2],m[3],(m[4]-m[3]*m[4]+m[1]*m[5])/d,(m[5]-m[0]*m[5]+m[2]*m[4])/d] def decomposition(self,m): + """ + Decompose the affine matrix into production of translation,rotation,shear and scale. + The algorithm is documented at http://lists.w3.org/Archives/Public/www-style/2010Jun/0602.html + """ if m[0]*m[3] == m[1]*m[2]: print "The affine matrix is singular" return [1,0,0,1,0,0] @@ -756,15 +760,12 @@ a = ss[2]*(1-p)+dd[2]*p tx = ox*(1-p)+dx*p ty = oy*(1-p)+dy*p - #m = self.mulA([math.cos(a),-math.sin(a),math.sin(a),math.cos(a),0,0],[sx,0,0,sy,0,0]) - #a=3.141592/2*p m = [math.cos(a),math.sin(a),-math.sin(a),math.cos(a),0,0] m = self.mulA([sx,0,0,sy,0,0],m) m = self.mulA(m,[1,0,0,1,-ox,oy-self.height]) m = self.mulA([1,0,0,1,tx,self.height-ty],m) - if dd[0] != ss[0]: - top.setAttribute("transform","matrix(%g,%g,%g,%g,%g,%g)" % (m[0],m[2],m[1],m[3],m[4],m[5])) + top.setAttribute("transform","matrix(%g,%g,%g,%g,%g,%g)" % (m[0],m[2],m[1],m[3],m[4],m[5])) else: try: sw = float(s.attribute("width"))