root / trunk / web / dojo / dojox / fx / flip.js @ 12
History | View | Annotate | Download (7.01 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.fx.flip"]){ |
9 |
dojo._hasResource["dojox.fx.flip"]=true; |
10 |
dojo.provide("dojox.fx.flip");
|
11 |
dojo.experimental("dojox.fx.flip");
|
12 |
dojo.require("dojo.fx");
|
13 |
(function(){
|
14 |
var _1="border",_2="Width",_3="Height",_4="Top",_5="Right",_6="Left",_7="Bottom"; |
15 |
dojox.fx.flip=function(_8){ |
16 |
var _9=dojo.create("div"),_a=_8.node=dojo.byId(_8.node),s=_a.style,_b=null,hs=null,pn=null,_c=_8.lightColor||"#dddddd",_d=_8.darkColor||"#555555",_e=dojo.style(_a,"backgroundColor"),_f=_8.endColor||_e,_10={},_11=[],_12=_8.duration?_8.duration/2:250,dir=_8.dir||"left",_13=0.9,_14="transparent",_15=_8.whichAnim,_16=_8.axis||"center",_17=_8.depth; |
17 |
var _18=function(_19){ |
18 |
return ((new dojo.Color(_19)).toHex()==="#000000")?"#000001":_19; |
19 |
}; |
20 |
if(dojo.isIE<7){ |
21 |
_f=_18(_f); |
22 |
_c=_18(_c); |
23 |
_d=_18(_d); |
24 |
_e=_18(_e); |
25 |
_14="black";
|
26 |
_9.style.filter="chroma(color='#000000')";
|
27 |
} |
28 |
var _1a=(function(n){ |
29 |
return function(){ |
30 |
var ret=dojo.coords(n,true); |
31 |
_b={top:ret.y,left:ret.x,width:ret.w,height:ret.h}; |
32 |
}; |
33 |
})(_a); |
34 |
_1a(); |
35 |
hs={position:"absolute",top:_b["top"]+"px",left:_b["left"]+"px",height:"0",width:"0",zIndex:_8.zIndex||(s.zIndex||0),border:"0 solid "+_14,fontSize:"0",visibility:"hidden"}; |
36 |
var _1b=[{},{top:_b["top"],left:_b["left"]}]; |
37 |
var _1c={left:[_6,_5,_4,_7,_2,_3,"end"+_3+"Min",_6,"end"+_3+"Max"],right:[_5,_6,_4,_7,_2,_3,"end"+_3+"Min",_6,"end"+_3+"Max"],top:[_4,_7,_6,_5,_3,_2,"end"+_2+"Min",_4,"end"+_2+"Max"],bottom:[_7,_4,_6,_5,_3,_2,"end"+_2+"Min",_4,"end"+_2+"Max"]}; |
38 |
pn=_1c[dir]; |
39 |
if(typeof _17!="undefined"){ |
40 |
_17=Math.max(0,Math.min(1,_17))/2; |
41 |
_13=0.4+(0.5-_17); |
42 |
}else{
|
43 |
_13=Math.min(0.9,Math.max(0.4,_b[pn[5].toLowerCase()]/_b[pn[4].toLowerCase()])); |
44 |
} |
45 |
var p0=_1b[0]; |
46 |
for(var i=4;i<6;i++){ |
47 |
if(_16=="center"||_16=="cube"){ |
48 |
_b["end"+pn[i]+"Min"]=_b[pn[i].toLowerCase()]*_13; |
49 |
_b["end"+pn[i]+"Max"]=_b[pn[i].toLowerCase()]/_13; |
50 |
}else{
|
51 |
if(_16=="shortside"){ |
52 |
_b["end"+pn[i]+"Min"]=_b[pn[i].toLowerCase()]; |
53 |
_b["end"+pn[i]+"Max"]=_b[pn[i].toLowerCase()]/_13; |
54 |
}else{
|
55 |
if(_16=="longside"){ |
56 |
_b["end"+pn[i]+"Min"]=_b[pn[i].toLowerCase()]*_13; |
57 |
_b["end"+pn[i]+"Max"]=_b[pn[i].toLowerCase()]; |
58 |
} |
59 |
} |
60 |
} |
61 |
} |
62 |
if(_16=="center"){ |
63 |
p0[pn[2].toLowerCase()]=_b[pn[2].toLowerCase()]-(_b[pn[8]]-_b[pn[6]])/4; |
64 |
}else{
|
65 |
if(_16=="shortside"){ |
66 |
p0[pn[2].toLowerCase()]=_b[pn[2].toLowerCase()]-(_b[pn[8]]-_b[pn[6]])/2; |
67 |
} |
68 |
} |
69 |
_10[pn[5].toLowerCase()]=_b[pn[5].toLowerCase()]+"px"; |
70 |
_10[pn[4].toLowerCase()]="0"; |
71 |
_10[_1+pn[1]+_2]=_b[pn[4].toLowerCase()]+"px"; |
72 |
_10[_1+pn[1]+"Color"]=_e; |
73 |
p0[_1+pn[1]+_2]=0; |
74 |
p0[_1+pn[1]+"Color"]=_d; |
75 |
p0[_1+pn[2]+_2]=p0[_1+pn[3]+_2]=_16!="cube"?(_b["end"+pn[5]+"Max"]-_b["end"+pn[5]+"Min"])/2:_b[pn[6]]/2; |
76 |
p0[pn[7].toLowerCase()]=_b[pn[7].toLowerCase()]+_b[pn[4].toLowerCase()]/2+(_8.shift||0); |
77 |
p0[pn[5].toLowerCase()]=_b[pn[6]]; |
78 |
var p1=_1b[1]; |
79 |
p1[_1+pn[0]+"Color"]={start:_c,end:_f}; |
80 |
p1[_1+pn[0]+_2]=_b[pn[4].toLowerCase()]; |
81 |
p1[_1+pn[2]+_2]=0; |
82 |
p1[_1+pn[3]+_2]=0; |
83 |
p1[pn[5].toLowerCase()]={start:_b[pn[6]],end:_b[pn[5].toLowerCase()]}; |
84 |
dojo.mixin(hs,_10); |
85 |
dojo.style(_9,hs); |
86 |
dojo.body().appendChild(_9); |
87 |
var _1d=function(){ |
88 |
dojo.destroy(_9); |
89 |
s.backgroundColor=_f; |
90 |
s.visibility="visible";
|
91 |
}; |
92 |
if(_15=="last"){ |
93 |
for(i in p0){ |
94 |
p0[i]={start:p0[i]};
|
95 |
} |
96 |
p0[_1+pn[1]+"Color"]={start:_d,end:_f}; |
97 |
p1=p0; |
98 |
} |
99 |
if(!_15||_15=="first"){ |
100 |
_11.push(dojo.animateProperty({node:_9,duration:_12,properties:p0})); |
101 |
} |
102 |
if(!_15||_15=="last"){ |
103 |
_11.push(dojo.animateProperty({node:_9,duration:_12,properties:p1,onEnd:_1d})); |
104 |
} |
105 |
dojo.connect(_11[0],"play",function(){ |
106 |
_9.style.visibility="visible";
|
107 |
s.visibility="hidden";
|
108 |
}); |
109 |
return dojo.fx.chain(_11);
|
110 |
}; |
111 |
dojox.fx.flipCube=function(_1e){ |
112 |
var _1f=[],mb=dojo.marginBox(_1e.node),_20=mb.w/2,_21=mb.h/2,_22={top:{pName:"height",args:[{whichAnim:"first",dir:"top",shift:-_21},{whichAnim:"last",dir:"bottom",shift:_21}]},right:{pName:"width",args:[{whichAnim:"first",dir:"right",shift:_20},{whichAnim:"last",dir:"left",shift:-_20}]},bottom:{pName:"height",args:[{whichAnim:"first",dir:"bottom",shift:_21},{whichAnim:"last",dir:"top",shift:-_21}]},left:{pName:"width",args:[{whichAnim:"first",dir:"left",shift:-_20},{whichAnim:"last",dir:"right",shift:_20}]}}; |
113 |
var d=_22[_1e.dir||"left"],p=d.args; |
114 |
_1e.duration=_1e.duration?_1e.duration*2:500; |
115 |
_1e.depth=0.8;
|
116 |
_1e.axis="cube";
|
117 |
for(var i=p.length-1;i>=0;i--){ |
118 |
dojo.mixin(_1e,p[i]); |
119 |
_1f.push(dojox.fx.flip(_1e)); |
120 |
} |
121 |
return dojo.fx.combine(_1f);
|
122 |
}; |
123 |
dojox.fx.flipPage=function(_23){ |
124 |
var n=_23.node,_24=dojo.coords(n,true),x=_24.x,y=_24.y,w=_24.w,h=_24.h,_25=dojo.style(n,"backgroundColor"),_26=_23.lightColor||"#dddddd",_27=_23.darkColor,_28=dojo.create("div"),_29=[],hn=[],dir=_23.dir||"right",pn={left:["left","right","x","w"],top:["top","bottom","y","h"],right:["left","left","x","w"],bottom:["top","top","y","h"]},_2a={right:[1,-1],left:[-1,1],top:[-1,1],bottom:[1,-1]}; |
125 |
dojo.style(_28,{position:"absolute",width:w+"px",height:h+"px",top:y+"px",left:x+"px",visibility:"hidden"}); |
126 |
var hs=[];
|
127 |
for(var i=0;i<2;i++){ |
128 |
var r=i%2,d=r?pn[dir][1]:dir,wa=r?"last":"first",_2b=r?_25:_26,_2c=r?_2b:_23.startColor||n.style.backgroundColor; |
129 |
hn[i]=dojo.clone(_28); |
130 |
var _2d=function(x){ |
131 |
return function(){ |
132 |
dojo.destroy(hn[x]); |
133 |
}; |
134 |
}(i); |
135 |
dojo.body().appendChild(hn[i]); |
136 |
hs[i]={backgroundColor:r?_2c:_25};
|
137 |
hs[i][pn[dir][0]]=_24[pn[dir][2]]+_2a[dir][0]*i*_24[pn[dir][3]]+"px"; |
138 |
dojo.style(hn[i],hs[i]); |
139 |
_29.push(dojox.fx.flip({node:hn[i],dir:d,axis:"shortside",depth:_23.depth,duration:_23.duration/2,shift:_2a[dir][i]*_24[pn[dir][3]]/2,darkColor:_27,lightColor:_26,whichAnim:wa,endColor:_2b})); |
140 |
dojo.connect(_29[i],"onEnd",_2d);
|
141 |
} |
142 |
return dojo.fx.chain(_29);
|
143 |
}; |
144 |
dojox.fx.flipGrid=function(_2e){ |
145 |
var _2f=_2e.rows||4,_30=_2e.cols||4,_31=[],_32=dojo.create("div"),n=_2e.node,_33=dojo.coords(n,true),x=_33.x,y=_33.y,nw=_33.w,nh=_33.h,w=_33.w/_30,h=_33.h/_2f,_34=[]; |
146 |
dojo.style(_32,{position:"absolute",width:w+"px",height:h+"px",backgroundColor:dojo.style(n,"backgroundColor")}); |
147 |
for(var i=0;i<_2f;i++){ |
148 |
var r=i%2,d=r?"right":"left",_35=r?1:-1; |
149 |
var cn=dojo.clone(n);
|
150 |
dojo.style(cn,{position:"absolute",width:nw+"px",height:nh+"px",top:y+"px",left:x+"px",clip:"rect("+i*h+"px,"+nw+"px,"+nh+"px,0)"}); |
151 |
dojo.body().appendChild(cn); |
152 |
_31[i]=[]; |
153 |
for(var j=0;j<_30;j++){ |
154 |
var hn=dojo.clone(_32),l=r?j:_30-(j+1); |
155 |
var _36=function(xn,_37,_38){ |
156 |
return function(){ |
157 |
if(!(_37%2)){ |
158 |
dojo.style(xn,{clip:"rect("+_37*h+"px,"+(nw-(_38+1)*w)+"px,"+((_37+1)*h)+"px,0px)"}); |
159 |
}else{
|
160 |
dojo.style(xn,{clip:"rect("+_37*h+"px,"+nw+"px,"+((_37+1)*h)+"px,"+((_38+1)*w)+"px)"}); |
161 |
} |
162 |
}; |
163 |
}(cn,i,j); |
164 |
dojo.body().appendChild(hn); |
165 |
dojo.style(hn,{left:x+l*w+"px",top:y+i*h+"px",visibility:"hidden"}); |
166 |
var a=dojox.fx.flipPage({node:hn,dir:d,duration:_2e.duration||900,shift:_35*w/2,depth:0.2,darkColor:_2e.darkColor,lightColor:_2e.lightColor,startColor:_2e.startColor||_2e.node.style.backgroundColor}),_39=function(xn){ |
167 |
return function(){ |
168 |
dojo.destroy(xn); |
169 |
}; |
170 |
}(hn); |
171 |
dojo.connect(a,"play",this,_36); |
172 |
dojo.connect(a,"play",this,_39); |
173 |
_31[i].push(a); |
174 |
} |
175 |
_34.push(dojo.fx.chain(_31[i])); |
176 |
} |
177 |
dojo.connect(_34[0],"play",function(){ |
178 |
dojo.style(n,{visibility:"hidden"}); |
179 |
}); |
180 |
return dojo.fx.combine(_34);
|
181 |
}; |
182 |
})(); |
183 |
} |