root / trunk / web / dojo / dojox / gfx / fx.js @ 12
History | View | Annotate | Download (4.54 KB)
1 |
/*
|
---|---|
2 |
Copyright (c) 2004-2010, The Dojo Foundation All Rights Reserved.
|
3 |
Available via Academic Free License >= 2.1 OR the modified BSD license.
|
4 |
see: http://dojotoolkit.org/license for details
|
5 |
*/
|
6 |
|
7 |
|
8 |
if(!dojo._hasResource["dojox.gfx.fx"]){ |
9 |
dojo._hasResource["dojox.gfx.fx"]=true; |
10 |
dojo.provide("dojox.gfx.fx");
|
11 |
dojo.require("dojox.gfx.matrix");
|
12 |
(function(){
|
13 |
var d=dojo,g=dojox.gfx,m=g.matrix;
|
14 |
var _1=function(_2,_3){ |
15 |
this.start=_2,this.end=_3; |
16 |
}; |
17 |
d.extend(_1,{getValue:function(r){ |
18 |
return (this.end-this.start)*r+this.start; |
19 |
}}); |
20 |
var _4=function(_5,_6,_7){ |
21 |
this.start=_5,this.end=_6; |
22 |
this.units=_7;
|
23 |
}; |
24 |
d.extend(_4,{getValue:function(r){ |
25 |
return (this.end-this.start)*r+this.start+this.units; |
26 |
}}); |
27 |
var _8=function(_9,_a){ |
28 |
this.start=_9,this.end=_a; |
29 |
this.temp=new dojo.Color(); |
30 |
}; |
31 |
d.extend(_8,{getValue:function(r){ |
32 |
return d.blendColors(this.start,this.end,r,this.temp); |
33 |
}}); |
34 |
var _b=function(_c){ |
35 |
this.values=_c;
|
36 |
this.length=_c.length;
|
37 |
}; |
38 |
d.extend(_b,{getValue:function(r){ |
39 |
return this.values[Math.min(Math.floor(r*this.length),this.length-1)]; |
40 |
}}); |
41 |
var _d=function(_e,_f){ |
42 |
this.values=_e;
|
43 |
this.def=_f?_f:{};
|
44 |
}; |
45 |
d.extend(_d,{getValue:function(r){ |
46 |
var ret=dojo.clone(this.def); |
47 |
for(var i in this.values){ |
48 |
ret[i]=this.values[i].getValue(r);
|
49 |
} |
50 |
return ret;
|
51 |
}}); |
52 |
var _10=function(_11,_12){ |
53 |
this.stack=_11;
|
54 |
this.original=_12;
|
55 |
}; |
56 |
d.extend(_10,{getValue:function(r){ |
57 |
var ret=[];
|
58 |
dojo.forEach(this.stack,function(t){ |
59 |
if(t instanceof m.Matrix2D){ |
60 |
ret.push(t); |
61 |
return;
|
62 |
} |
63 |
if(t.name=="original"&&this.original){ |
64 |
ret.push(this.original);
|
65 |
return;
|
66 |
} |
67 |
if(!(t.name in m)){ |
68 |
return;
|
69 |
} |
70 |
var f=m[t.name];
|
71 |
if(typeof f!="function"){ |
72 |
ret.push(f); |
73 |
return;
|
74 |
} |
75 |
var val=dojo.map(t.start,function(v,i){ |
76 |
return (t.end[i]-v)*r+v;
|
77 |
}),_13=f.apply(m,val); |
78 |
if(_13 instanceof m.Matrix2D){ |
79 |
ret.push(_13); |
80 |
} |
81 |
},this);
|
82 |
return ret;
|
83 |
}}); |
84 |
var _14=new d.Color(0,0,0,0); |
85 |
var _15=function(_16,obj,_17,def){ |
86 |
if(_16.values){
|
87 |
return new _b(_16.values); |
88 |
} |
89 |
var _18,_19,end;
|
90 |
if(_16.start){
|
91 |
_19=g.normalizeColor(_16.start); |
92 |
}else{
|
93 |
_19=_18=obj?(_17?obj[_17]:obj):def; |
94 |
} |
95 |
if(_16.end){
|
96 |
end=g.normalizeColor(_16.end); |
97 |
}else{
|
98 |
if(!_18){
|
99 |
_18=obj?(_17?obj[_17]:obj):def; |
100 |
} |
101 |
end=_18; |
102 |
} |
103 |
return new _8(_19,end); |
104 |
}; |
105 |
var _1a=function(_1b,obj,_1c,def){ |
106 |
if(_1b.values){
|
107 |
return new _b(_1b.values); |
108 |
} |
109 |
var _1d,_1e,end;
|
110 |
if(_1b.start){
|
111 |
_1e=_1b.start; |
112 |
}else{
|
113 |
_1e=_1d=obj?obj[_1c]:def; |
114 |
} |
115 |
if(_1b.end){
|
116 |
end=_1b.end; |
117 |
}else{
|
118 |
if(typeof _1d!="number"){ |
119 |
_1d=obj?obj[_1c]:def; |
120 |
} |
121 |
end=_1d; |
122 |
} |
123 |
return new _1(_1e,end); |
124 |
}; |
125 |
g.fx.animateStroke=function(_1f){ |
126 |
if(!_1f.easing){
|
127 |
_1f.easing=d._defaultEasing; |
128 |
} |
129 |
var _20=new d.Animation(_1f),_21=_1f.shape,_22; |
130 |
d.connect(_20,"beforeBegin",_20,function(){ |
131 |
_22=_21.getStroke(); |
132 |
var _23=_1f.color,_24={},_25,_26,end;
|
133 |
if(_23){
|
134 |
_24.color=_15(_23,_22,"color",_14);
|
135 |
} |
136 |
_23=_1f.style; |
137 |
if(_23&&_23.values){
|
138 |
_24.style=new _b(_23.values);
|
139 |
} |
140 |
_23=_1f.width; |
141 |
if(_23){
|
142 |
_24.width=_1a(_23,_22,"width",1); |
143 |
} |
144 |
_23=_1f.cap; |
145 |
if(_23&&_23.values){
|
146 |
_24.cap=new _b(_23.values);
|
147 |
} |
148 |
_23=_1f.join; |
149 |
if(_23){
|
150 |
if(_23.values){
|
151 |
_24.join=new _b(_23.values);
|
152 |
}else{
|
153 |
_26=_23.start?_23.start:(_22&&_22.join||0);
|
154 |
end=_23.end?_23.end:(_22&&_22.join||0);
|
155 |
if(typeof _26=="number"&&typeof end=="number"){ |
156 |
_24.join=new _1(_26,end);
|
157 |
} |
158 |
} |
159 |
} |
160 |
this.curve=new _d(_24,_22); |
161 |
}); |
162 |
d.connect(_20,"onAnimate",_21,"setStroke"); |
163 |
return _20;
|
164 |
}; |
165 |
g.fx.animateFill=function(_27){ |
166 |
if(!_27.easing){
|
167 |
_27.easing=d._defaultEasing; |
168 |
} |
169 |
var _28=new d.Animation(_27),_29=_27.shape,_2a; |
170 |
d.connect(_28,"beforeBegin",_28,function(){ |
171 |
_2a=_29.getFill(); |
172 |
var _2b=_27.color,_2c={};
|
173 |
if(_2b){
|
174 |
this.curve=_15(_2b,_2a,"",_14); |
175 |
} |
176 |
}); |
177 |
d.connect(_28,"onAnimate",_29,"setFill"); |
178 |
return _28;
|
179 |
}; |
180 |
g.fx.animateFont=function(_2d){ |
181 |
if(!_2d.easing){
|
182 |
_2d.easing=d._defaultEasing; |
183 |
} |
184 |
var _2e=new d.Animation(_2d),_2f=_2d.shape,_30; |
185 |
d.connect(_2e,"beforeBegin",_2e,function(){ |
186 |
_30=_2f.getFont(); |
187 |
var _31=_2d.style,_32={},_33,_34,end;
|
188 |
if(_31&&_31.values){
|
189 |
_32.style=new _b(_31.values);
|
190 |
} |
191 |
_31=_2d.variant; |
192 |
if(_31&&_31.values){
|
193 |
_32.variant=new _b(_31.values);
|
194 |
} |
195 |
_31=_2d.weight; |
196 |
if(_31&&_31.values){
|
197 |
_32.weight=new _b(_31.values);
|
198 |
} |
199 |
_31=_2d.family; |
200 |
if(_31&&_31.values){
|
201 |
_32.family=new _b(_31.values);
|
202 |
} |
203 |
_31=_2d.size; |
204 |
if(_31&&_31.units){
|
205 |
_34=parseFloat(_31.start?_31.start:(_2f.font&&_2f.font.size||"0"));
|
206 |
end=parseFloat(_31.end?_31.end:(_2f.font&&_2f.font.size||"0"));
|
207 |
_32.size=new _4(_34,end,_31.units);
|
208 |
} |
209 |
this.curve=new _d(_32,_30); |
210 |
}); |
211 |
d.connect(_2e,"onAnimate",_2f,"setFont"); |
212 |
return _2e;
|
213 |
}; |
214 |
g.fx.animateTransform=function(_35){ |
215 |
if(!_35.easing){
|
216 |
_35.easing=d._defaultEasing; |
217 |
} |
218 |
var _36=new d.Animation(_35),_37=_35.shape,_38; |
219 |
d.connect(_36,"beforeBegin",_36,function(){ |
220 |
_38=_37.getTransform(); |
221 |
this.curve=new _10(_35.transform,_38); |
222 |
}); |
223 |
d.connect(_36,"onAnimate",_37,"setTransform"); |
224 |
return _36;
|
225 |
}; |
226 |
})(); |
227 |
} |