root / trunk / web / dojo / dojox / html / ext-dojo / style.js @ 13
History | View | Annotate | Download (8.31 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.html.ext-dojo.style"]){ |
9 |
dojo._hasResource["dojox.html.ext-dojo.style"]=true; |
10 |
dojo.provide("dojox.html.ext-dojo.style");
|
11 |
dojo.experimental("dojox.html.ext-dojo.style");
|
12 |
dojo.mixin(dojox.html["ext-dojo"].style,{supportsTransform:true,_toPx:function(_1){ |
13 |
var ds=dojo.style,_2=this._conversion; |
14 |
if(typeof _1==="number"){ |
15 |
return _1+"px"; |
16 |
}else{
|
17 |
if(_1.toLowerCase().indexOf("px")!=-1){ |
18 |
return _1;
|
19 |
} |
20 |
} |
21 |
!_2.parentNode&&dojo.place(_2,dojo.body()); |
22 |
ds(_2,"margin",_1);
|
23 |
return ds(_2,"margin"); |
24 |
},init:function(){ |
25 |
var ds=dojo.style,_3=dojo.doc.documentElement.style,_4=dojox.html["ext-dojo"].style; |
26 |
dojo.style=function(_5,_6,_7){ |
27 |
var n=dojo.byId(_5),tr=(_6=="transform"),to=(_6=="transformOrigin"),_8=arguments.length; |
28 |
if(_8==3){ |
29 |
if(tr){
|
30 |
_4.setTransform(n,_7,true);
|
31 |
}else{
|
32 |
if(to){
|
33 |
_4.setTransformOrigin(n,_7); |
34 |
}else{
|
35 |
ds(_5,_6,_7); |
36 |
} |
37 |
} |
38 |
} |
39 |
if(_8==2){ |
40 |
if(tr){
|
41 |
return _4.getTransform(_5);
|
42 |
}else{
|
43 |
if(to){
|
44 |
return _4.getTransformOrigin(_5);
|
45 |
}else{
|
46 |
return ds(_5,_6);
|
47 |
} |
48 |
} |
49 |
} |
50 |
}; |
51 |
for(var i=0,_9=["WebkitT","MozT","OT","t"];i<_9.length;i++){ |
52 |
if(typeof _3[_9[i]+"ransform"]!=="undefined"){ |
53 |
this.tPropertyName=_9[i]+"ransform"; |
54 |
} |
55 |
if(typeof _3[_9[i]+"ransformOrigin"]!=="undefined"){ |
56 |
this.toPropertyName=_9[i]+"ransformOrigin"; |
57 |
} |
58 |
} |
59 |
if(this.tPropertyName){ |
60 |
this.setTransform=function(_a,_b){ |
61 |
return dojo.style(_a,this.tPropertyName,_b); |
62 |
}; |
63 |
this.getTransform=function(_c){ |
64 |
return dojo.style(_c,this.tPropertyName); |
65 |
}; |
66 |
}else{
|
67 |
if(dojo.isIE){
|
68 |
this.setTransform=this._setTransformFilter; |
69 |
this.getTransform=this._getTransformFilter; |
70 |
} |
71 |
} |
72 |
if(this.toPropertyName){ |
73 |
this.setTransformOrigin=function(_d,_e){ |
74 |
return dojo.style(_d,this.toPropertyName,_e); |
75 |
}; |
76 |
this.getTransformOrigin=function(_f){ |
77 |
return dojo.style(_f,this.toPropertyName); |
78 |
}; |
79 |
}else{
|
80 |
if(dojo.isIE){
|
81 |
this.setTransformOrigin=this._setTransformOriginFilter; |
82 |
this.getTransformOrigin=this._getTransformOriginFilter; |
83 |
}else{
|
84 |
this.supportsTransform=false; |
85 |
} |
86 |
} |
87 |
this._conversion=dojo.create("div",{style:{position:"absolute",top:"-100px",left:"-100px",fontSize:0,width:"0",backgroundPosition:"50% 50%"}}); |
88 |
},_notSupported:function(){ |
89 |
console.warn("Sorry, this browser doesn't support transform and transform-origin");
|
90 |
},_setTransformOriginFilter:function(_10,_11){ |
91 |
var to=dojo.trim(_11).replace(" top"," 0").replace("left ","0 ").replace(" center","50%").replace("center ","50% ").replace(" bottom"," 100%").replace("right ","100% ").replace(/\s+/," "),_12=to.split(" "),n=dojo.byId(_10),t=this.getTransform(n),_13=true; |
92 |
for(var i=0;i<_12.length;i++){ |
93 |
_13=_13&&/^0|(\d+(%|px|pt|in|pc|mm|cm))$/.test(_12[i]);
|
94 |
if(_12[i].indexOf("%")==-1){ |
95 |
_12[i]=this._toPx(_12[i]);
|
96 |
} |
97 |
} |
98 |
if(!_13){
|
99 |
return;
|
100 |
} |
101 |
if(!_12.length||_12.length>2){ |
102 |
return;
|
103 |
} |
104 |
dojo.attr(n,"dojo-transform-origin",_12.join(" ")); |
105 |
t&&this.setTransform(_10,t);
|
106 |
},_getTransformOriginFilter:function(_14){ |
107 |
return dojo.attr(_14,"dojo-transform-origin")||"50% 50%"; |
108 |
},_setTransformFilter:function(_15,_16){ |
109 |
var t=_16.replace(/\s/g,""),n=dojo.byId(_15),_17=t.split(")"),_18=1,_19=1,_1a="DXImageTransform.Microsoft.Matrix",_1b=dojo.hasAttr,_1c=dojo.attr,PI=Math.PI,cos=Math.cos,sin=Math.sin,tan=Math.tan,max=Math.max,min=Math.min,abs=Math.abs,_1d=PI/180,_1e=PI/200,ct="",_1f="",_20=[],x0=0,y0=0,dx=0,dy=0,xc=0,yc=0,a=0,m11=1,m12=0,m21=0,m22=1,tx=0,ty=0,_21=[m11,m12,m21,m22,tx,ty],_22=false,ds=dojo.style,_23=ds(n,"position")=="absolute"?"absolute":"relative",w=ds(n,"width")+ds(n,"paddingLeft")+ds(n,"paddingRight"),h=ds(n,"height")+ds(n,"paddingTop")+ds(n,"paddingBottom"),_24=this._toPx; |
110 |
!_1b(n,"dojo-transform-origin")&&this.setTransformOrigin(n,"50% 50%"); |
111 |
for(var i=0,l=_17.length;i<l;i++){ |
112 |
_20=_17[i].match(/matrix|rotate|scaleX|scaleY|scale|skewX|skewY|skew|translateX|translateY|translate/);
|
113 |
_1f=_20?_20[0]:""; |
114 |
switch(_1f){
|
115 |
case "matrix": |
116 |
ct=_17[i].replace(/matrix\(|\)/g,""); |
117 |
var _25=ct.split(","); |
118 |
m11=_21[0]*_25[0]+_21[1]*_25[2]; |
119 |
m12=_21[0]*_25[1]+_21[1]*_25[3]; |
120 |
m21=_21[2]*_25[0]+_21[3]*_25[2]; |
121 |
m22=_21[2]*_25[1]+_21[3]*_25[3]; |
122 |
tx=_21[4]+_25[4]; |
123 |
ty=_21[5]+_25[5]; |
124 |
break;
|
125 |
case "rotate": |
126 |
ct=_17[i].replace(/rotate\(|\)/g,""); |
127 |
_18=ct.indexOf("deg")!=-1?_1d:ct.indexOf("grad")!=-1?_1e:1; |
128 |
a=parseFloat(ct)*_18; |
129 |
var s=sin(a),c=cos(a);
|
130 |
m11=_21[0]*c+_21[1]*s; |
131 |
m12=-_21[0]*s+_21[1]*c; |
132 |
m21=_21[2]*c+_21[3]*s; |
133 |
m22=-_21[2]*s+_21[3]*c; |
134 |
break;
|
135 |
case "skewX": |
136 |
ct=_17[i].replace(/skewX\(|\)/g,""); |
137 |
_18=ct.indexOf("deg")!=-1?_1d:ct.indexOf("grad")!=-1?_1e:1; |
138 |
var ta=tan(parseFloat(ct)*_18);
|
139 |
m11=_21[0];
|
140 |
m12=_21[0]*ta+_21[1]; |
141 |
m21=_21[2];
|
142 |
m22=_21[2]*ta+_21[3]; |
143 |
break;
|
144 |
case "skewY": |
145 |
ct=_17[i].replace(/skewY\(|\)/g,""); |
146 |
_18=ct.indexOf("deg")!=-1?_1d:ct.indexOf("grad")!=-1?_1e:1; |
147 |
ta=tan(parseFloat(ct)*_18); |
148 |
m11=_21[0]+_21[1]*ta; |
149 |
m12=_21[1];
|
150 |
m21=_21[2]+_21[3]*ta; |
151 |
m22=_21[3];
|
152 |
break;
|
153 |
case "skew": |
154 |
ct=_17[i].replace(/skew\(|\)/g,""); |
155 |
var _26=ct.split(","); |
156 |
_26[1]=_26[1]||"0"; |
157 |
_18=_26[0].indexOf("deg")!=-1?_1d:_26[0].indexOf("grad")!=-1?_1e:1; |
158 |
_19=_26[1].indexOf("deg")!=-1?_1d:_26[1].indexOf("grad")!=-1?_1e:1; |
159 |
var a0=tan(parseFloat(_26[0])*_18),a1=tan(parseFloat(_26[1])*_19); |
160 |
m11=_21[0]+_21[1]*a1; |
161 |
m12=_21[0]*a0+_21[1]; |
162 |
m21=_21[2]+_21[3]*a1; |
163 |
m22=_21[2]*a0+_21[3]; |
164 |
break;
|
165 |
case "scaleX": |
166 |
ct=parseFloat(_17[i].replace(/scaleX\(|\)/g,""))||1; |
167 |
m11=_21[0]*ct;
|
168 |
m12=_21[1];
|
169 |
m21=_21[2]*ct;
|
170 |
m22=_21[3];
|
171 |
break;
|
172 |
case "scaleY": |
173 |
ct=parseFloat(_17[i].replace(/scaleY\(|\)/g,""))||1; |
174 |
m11=_21[0];
|
175 |
m12=_21[1]*ct;
|
176 |
m21=_21[2];
|
177 |
m22=_21[3]*ct;
|
178 |
break;
|
179 |
case "scale": |
180 |
ct=_17[i].replace(/scale\(|\)/g,""); |
181 |
var _27=ct.split(","); |
182 |
_27[1]=_27[1]||_27[0]; |
183 |
m11=_21[0]*_27[0]; |
184 |
m12=_21[1]*_27[1]; |
185 |
m21=_21[2]*_27[0]; |
186 |
m22=_21[3]*_27[1]; |
187 |
break;
|
188 |
case "translateX": |
189 |
ct=parseInt(_17[i].replace(/translateX\(|\)/g,""))||1; |
190 |
m11=_21[0];
|
191 |
m12=_21[1];
|
192 |
m21=_21[2];
|
193 |
m22=_21[3];
|
194 |
tx=_24(ct); |
195 |
tx&&_1c(n,"dojo-transform-matrix-tx",tx);
|
196 |
break;
|
197 |
case "translateY": |
198 |
ct=parseInt(_17[i].replace(/translateY\(|\)/g,""))||1; |
199 |
m11=_21[0];
|
200 |
m12=_21[1];
|
201 |
m21=_21[2];
|
202 |
m22=_21[3];
|
203 |
ty=_24(ct); |
204 |
ty&&_1c(n,"dojo-transform-matrix-ty",ty);
|
205 |
break;
|
206 |
case "translate": |
207 |
ct=_17[i].replace(/translate\(|\)/g,""); |
208 |
m11=_21[0];
|
209 |
m12=_21[1];
|
210 |
m21=_21[2];
|
211 |
m22=_21[3];
|
212 |
var _28=ct.split(","); |
213 |
_28[0]=parseInt(_24(_28[0]))||0; |
214 |
_28[1]=parseInt(_24(_28[1]))||0; |
215 |
tx=_28[0];
|
216 |
ty=_28[1];
|
217 |
tx&&_1c(n,"dojo-transform-matrix-tx",tx);
|
218 |
ty&&_1c(n,"dojo-transform-matrix-ty",ty);
|
219 |
break;
|
220 |
} |
221 |
_21=[m11,m12,m21,m22,tx,ty]; |
222 |
} |
223 |
var Bx=min(w*m11+h*m12,min(min(w*m11,h*m12),0)),By=min(w*m21+h*m22,min(min(w*m21,h*m22),0)); |
224 |
dx=-Bx; |
225 |
dy=-By; |
226 |
if(dojo.isIE<8){ |
227 |
n.style.zoom="1";
|
228 |
if(_23!="absolute"){ |
229 |
var _29=ds(_15.parentNode,"width"),tw=abs(w*m11),th=abs(h*m12),_2a=max(tw+th,max(max(th,tw),0)); |
230 |
dx-=(_2a-w)/2-(_29>_2a?0:(_2a-_29)/2); |
231 |
} |
232 |
}else{
|
233 |
if(dojo.isIE==8){ |
234 |
ds(n,"zIndex")=="auto"&&(n.style.zIndex="0"); |
235 |
} |
236 |
} |
237 |
try{
|
238 |
_22=!!n.filters.item(_1a); |
239 |
} |
240 |
catch(e){
|
241 |
_22=false;
|
242 |
} |
243 |
if(_22){
|
244 |
n.filters.item(_1a).M11=m11; |
245 |
n.filters.item(_1a).M12=m12; |
246 |
n.filters.item(_1a).M21=m21; |
247 |
n.filters.item(_1a).M22=m22; |
248 |
n.filters.item(_1a).filterType="bilinear";
|
249 |
n.filters.item(_1a).Dx=0;
|
250 |
n.filters.item(_1a).Dy=0;
|
251 |
n.filters.item(_1a).sizingMethod="auto expand";
|
252 |
}else{
|
253 |
n.style.filter+=" progid:"+_1a+"(M11="+m11+",M12="+m12+",M21="+m21+",M22="+m22+",FilterType='bilinear',Dx=0,Dy=0,sizingMethod='auto expand')"; |
254 |
} |
255 |
tx=parseInt(_1c(n,"dojo-transform-matrix-tx")||"0"); |
256 |
ty=parseInt(_1c(n,"dojo-transform-matrix-ty")||"0"); |
257 |
var _2b=_1c(n,"dojo-transform-origin").split(" "); |
258 |
for(i=0;i<2;i++){ |
259 |
_2b[i]=_2b[i]||"50%";
|
260 |
} |
261 |
xc=(_2b[0].toString().indexOf("%")!=-1)?w*parseInt(_2b[0])*0.01:_2b[0]; |
262 |
yc=(_2b[1].toString().indexOf("%")!=-1)?h*parseInt(_2b[1])*0.01:_2b[1]; |
263 |
if(_1b(n,"dojo-startX")){ |
264 |
x0=parseInt(_1c(n,"dojo-startX"));
|
265 |
}else{
|
266 |
x0=parseInt(ds(n,"left"));
|
267 |
_1c(n,"dojo-startX",_23=="absolute"?x0:"0"); |
268 |
} |
269 |
if(_1b(n,"dojo-startY")){ |
270 |
y0=parseInt(_1c(n,"dojo-startY"));
|
271 |
}else{
|
272 |
y0=parseInt(ds(n,"top"));
|
273 |
_1c(n,"dojo-startY",_23=="absolute"?y0:"0"); |
274 |
} |
275 |
ds(n,{position:_23,left:x0-parseInt(dx)+parseInt(xc)-((parseInt(xc)-tx)*m11+(parseInt(yc)-ty)*m12)+"px",top:y0-parseInt(dy)+parseInt(yc)-((parseInt(xc)-tx)*m21+(parseInt(yc)-ty)*m22)+"px"}); |
276 |
},_getTransformFilter:function(_2c){ |
277 |
try{
|
278 |
var n=dojo.byId(_2c),_2d=n.filters.item(0); |
279 |
return "matrix("+_2d.M11+", "+_2d.M12+", "+_2d.M21+", "+_2d.M22+", "+(dojo.attr(_2c,"dojo-transform-tx")||"0")+", "+(dojo.attr(_2c,"dojo-transform-ty")||"0")+")"; |
280 |
} |
281 |
catch(e){
|
282 |
return "matrix(1, 0, 0, 1, 0, 0)"; |
283 |
} |
284 |
},setTransform:function(){ |
285 |
this._notSupported();
|
286 |
},setTransformOrigin:function(){ |
287 |
this._notSupported();
|
288 |
}}); |
289 |
dojox.html["ext-dojo"].style.init();
|
290 |
} |