Project

General

Profile

Statistics
| Revision:

root / trunk / web / dojo / dojox / mobile / app / ImageView.js @ 11

History | View | Annotate | Download (9.8 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.mobile.app.ImageView"]){
9
dojo._hasResource["dojox.mobile.app.ImageView"]=true;
10
dojo.provide("dojox.mobile.app.ImageView");
11
dojo.experimental("dojox.mobile.app.ImageView");
12
dojo.require("dojox.mobile.app._Widget");
13
dojo.require("dojo.fx.easing");
14
dojo.declare("dojox.mobile.app.ImageView",dojox.mobile.app._Widget,{zoom:1,zoomCenterX:0,zoomCenterY:0,maxZoom:5,autoZoomLevel:3,disableAutoZoom:false,disableSwipe:false,autoZoomEvent:null,_leftImg:null,_centerImg:null,_rightImg:null,_leftSmallImg:null,_centerSmallImg:null,_rightSmallImg:null,constructor:function(){
15
this.panX=0;
16
this.panY=0;
17
this.handleLoad=dojo.hitch(this,this.handleLoad);
18
this._updateAnimatedZoom=dojo.hitch(this,this._updateAnimatedZoom);
19
this._updateAnimatedPan=dojo.hitch(this,this._updateAnimatedPan);
20
this._onAnimPanEnd=dojo.hitch(this,this._onAnimPanEnd);
21
},buildRendering:function(){
22
this.inherited(arguments);
23
this.canvas=dojo.create("canvas",{},this.domNode);
24
dojo.addClass(this.domNode,"mblImageView");
25
},postCreate:function(){
26
this.inherited(arguments);
27
this.size=dojo.marginBox(this.domNode);
28
dojo.style(this.canvas,{width:this.size.w+"px",height:this.size.h+"px"});
29
this.canvas.height=this.size.h;
30
this.canvas.width=this.size.w;
31
var _1=this;
32
this.connect(this.domNode,"onmousedown",function(_2){
33
if(_1.isAnimating()){
34
return;
35
}
36
if(_1.panX){
37
_1.handleDragEnd();
38
}
39
_1.downX=_2.targetTouches?_2.targetTouches[0].clientX:_2.clientX;
40
_1.downY=_2.targetTouches?_2.targetTouches[0].clientY:_2.clientY;
41
});
42
this.connect(this.domNode,"onmousemove",function(_3){
43
if(_1.isAnimating()){
44
return;
45
}
46
if((!_1.downX&&_1.downX!==0)||(!_1.downY&&_1.downY!==0)){
47
return;
48
}
49
if((!_1.disableSwipe&&_1.zoom==1)||(!_1.disableAutoZoom&&_1.zoom!=1)){
50
var x=_3.targetTouches?_3.targetTouches[0].clientX:_3.pageX;
51
var y=_3.targetTouches?_3.targetTouches[0].clientY:_3.pageY;
52
_1.panX=x-_1.downX;
53
_1.panY=y-_1.downY;
54
if(_1.zoom==1){
55
if(Math.abs(_1.panX)>10){
56
_1.render();
57
}
58
}else{
59
if(Math.abs(_1.panX)>10||Math.abs(_1.panY)>10){
60
_1.render();
61
}
62
}
63
}
64
});
65
this.connect(this.domNode,"onmouseout",function(_4){
66
if(!_1.isAnimating()&&_1.panX){
67
_1.handleDragEnd();
68
}
69
});
70
this.connect(this.domNode,"onmouseover",function(_5){
71
_1.downX=_1.downY=null;
72
});
73
this.connect(this.domNode,"onclick",function(_6){
74
if(_1.isAnimating()){
75
return;
76
}
77
if(_1.downX==null||_1.downY==null){
78
return;
79
}
80
var x=(_6.targetTouches?_6.targetTouches[0].clientX:_6.pageX);
81
var y=(_6.targetTouches?_6.targetTouches[0].clientY:_6.pageY);
82
if(Math.abs(_1.panX)>14||Math.abs(_1.panY)>14){
83
_1.downX=_1.downY=null;
84
_1.handleDragEnd();
85
return;
86
}
87
_1.downX=_1.downY=null;
88
if(!_1.disableAutoZoom){
89
if(!_1._centerImg||!_1._centerImg._loaded){
90
return;
91
}
92
if(_1.zoom!=1){
93
_1.set("animatedZoom",1);
94
return;
95
}
96
var _7=dojo._abs(_1.domNode);
97
var _8=_1.size.w/_1._centerImg.width;
98
var _9=_1.size.h/_1._centerImg.height;
99
_1.zoomTo(((x-_7.x)/_8)-_1.panX,((y-_7.y)/_9)-_1.panY,_1.autoZoomLevel);
100
}
101
});
102
dojo.connect(this.domNode,"flick",this,"handleFlick");
103
},isAnimating:function(){
104
return this._anim&&this._anim.status()=="playing";
105
},handleDragEnd:function(){
106
this.downX=this.downY=null;
107
if(this.zoom==1){
108
if(!this.panX){
109
return;
110
}
111
var _a=(this._leftImg&&this._leftImg._loaded)||(this._leftSmallImg&&this._leftSmallImg._loaded);
112
var _b=(this._rightImg&&this._rightImg._loaded)||(this._rightSmallImg&&this._rightSmallImg._loaded);
113
var _c=!(Math.abs(this.panX)<this._centerImg._baseWidth/2)&&((this.panX>0&&_a?1:0)||(this.panX<0&&_b?1:0));
114
if(!_c){
115
this._animPanTo(0,dojo.fx.easing.expoOut,700);
116
}else{
117
this.moveTo(this.panX);
118
}
119
}else{
120
if(!this.panX&&!this.panY){
121
return;
122
}
123
this.zoomCenterX-=(this.panX/this.zoom);
124
this.zoomCenterY-=(this.panY/this.zoom);
125
this.panX=this.panY=0;
126
}
127
},handleFlick:function(_d){
128
if(this.zoom==1&&_d.duration<500){
129
if(_d.direction=="ltr"){
130
this.moveTo(1);
131
}else{
132
if(_d.direction=="rtl"){
133
this.moveTo(-1);
134
}
135
}
136
this.downX=this.downY=null;
137
}
138
},moveTo:function(_e){
139
_e=_e>0?1:-1;
140
var _f;
141
if(_e<1){
142
if(this._rightImg&&this._rightImg._loaded){
143
_f=this._rightImg;
144
}else{
145
if(this._rightSmallImg&&this._rightSmallImg._loaded){
146
_f=this._rightSmallImg;
147
}
148
}
149
}else{
150
if(this._leftImg&&this._leftImg._loaded){
151
_f=this._leftImg;
152
}else{
153
if(this._leftSmallImg&&this._leftSmallImg._loaded){
154
_f=this._leftSmallImg;
155
}
156
}
157
}
158
this._moveDir=_e;
159
var _10=this;
160
if(_f&&_f._loaded){
161
this._animPanTo(this.size.w*_e,null,500,function(){
162
_10.panX=0;
163
_10.panY=0;
164
if(_e<0){
165
_10._switchImage("left","right");
166
}else{
167
_10._switchImage("right","left");
168
}
169
_10.render();
170
_10.onChange(_e*-1);
171
});
172
}else{
173
this._animPanTo(0,dojo.fx.easing.expoOut,700);
174
}
175
},_switchImage:function(_11,_12){
176
var _13="_"+_11+"SmallImg";
177
var _14="_"+_11+"Img";
178
var _15="_"+_12+"SmallImg";
179
var _16="_"+_12+"Img";
180
this[_14]=this._centerImg;
181
this[_13]=this._centerSmallImg;
182
this[_14]._type=_11;
183
if(this[_13]){
184
this[_13]._type=_11;
185
}
186
this._centerImg=this[_16];
187
this._centerSmallImg=this[_15];
188
this._centerImg._type="center";
189
if(this._centerSmallImg){
190
this._centerSmallImg._type="center";
191
}
192
this[_16]=this[_15]=null;
193
},_animPanTo:function(to,_17,_18,_19){
194
this._animCallback=_19;
195
this._anim=new dojo.Animation({curve:[this.panX,to],onAnimate:this._updateAnimatedPan,duration:_18||500,easing:_17,onEnd:this._onAnimPanEnd});
196
this._anim.play();
197
return this._anim;
198
},onChange:function(_1a){
199
},_updateAnimatedPan:function(_1b){
200
this.panX=_1b;
201
this.render();
202
},_onAnimPanEnd:function(){
203
this.panX=this.panY=0;
204
if(this._animCallback){
205
this._animCallback();
206
}
207
},zoomTo:function(_1c,_1d,_1e){
208
this.set("zoomCenterX",_1c);
209
this.set("zoomCenterY",_1d);
210
this.set("animatedZoom",_1e);
211
},render:function(){
212
var cxt=this.canvas.getContext("2d");
213
cxt.clearRect(0,0,this.canvas.width,this.canvas.height);
214
this._renderImg(this._centerSmallImg,this._centerImg,this.zoom==1?(this.panX<0?1:this.panX>0?-1:0):0);
215
if(this.zoom==1&&this.panX!=0){
216
if(this.panX>0){
217
this._renderImg(this._leftSmallImg,this._leftImg,1);
218
}else{
219
this._renderImg(this._rightSmallImg,this._rightImg,-1);
220
}
221
}
222
},_renderImg:function(_1f,_20,_21){
223
var img=(_20&&_20._loaded)?_20:_1f;
224
if(!img||!img._loaded){
225
return;
226
}
227
var cxt=this.canvas.getContext("2d");
228
var _22=img._baseWidth;
229
var _23=img._baseHeight;
230
var _24=_22*this.zoom;
231
var _25=_23*this.zoom;
232
var _26=Math.min(this.size.w,_24);
233
var _27=Math.min(this.size.h,_25);
234
var _28=this.dispWidth=img.width*(_26/_24);
235
var _29=this.dispHeight=img.height*(_27/_25);
236
var _2a=this.zoomCenterX-(this.panX/this.zoom);
237
var _2b=this.zoomCenterY-(this.panY/this.zoom);
238
var _2c=Math.floor(Math.max(_28/2,Math.min(img.width-_28/2,_2a)));
239
var _2d=Math.floor(Math.max(_29/2,Math.min(img.height-_29/2,_2b)));
240
var _2e=Math.max(0,Math.round((img.width-_28)/2+(_2c-img._centerX)));
241
var _2f=Math.max(0,Math.round((img.height-_29)/2+(_2d-img._centerY)));
242
var _30=Math.round(Math.max(0,this.canvas.width-_26)/2);
243
var _31=Math.round(Math.max(0,this.canvas.height-_27)/2);
244
var _32=_26;
245
var _33=_28;
246
if(this.zoom==1&&_21&&this.panX){
247
if(this.panX<0){
248
if(_21>0){
249
_26-=Math.abs(this.panX);
250
_30=0;
251
}else{
252
if(_21<0){
253
_26=Math.max(1,Math.abs(this.panX)-5);
254
_30=this.size.w-_26;
255
}
256
}
257
}else{
258
if(_21>0){
259
_26=Math.max(1,Math.abs(this.panX)-5);
260
_30=0;
261
}else{
262
if(_21<0){
263
_26-=Math.abs(this.panX);
264
_30=this.size.w-_26;
265
}
266
}
267
}
268
_28=Math.max(1,Math.floor(_28*(_26/_32)));
269
if(_21>0){
270
_2e=(_2e+_33)-(_28);
271
}
272
_2e=Math.floor(_2e);
273
}
274
try{
275
cxt.drawImage(img,Math.max(0,_2e),_2f,Math.min(_33,_28),_29,_30,_31,Math.min(_32,_26),_27);
276
}
277
catch(e){
278
}
279
},_setZoomAttr:function(_34){
280
this.zoom=Math.min(this.maxZoom,Math.max(1,_34));
281
if(this.zoom==1&&this._centerImg&&this._centerImg._loaded){
282
if(!this.isAnimating()){
283
this.zoomCenterX=this._centerImg.width/2;
284
this.zoomCenterY=this._centerImg.height/2;
285
}
286
this.panX=this.panY=0;
287
}
288
this.render();
289
},_setZoomCenterXAttr:function(_35){
290
if(_35!=this.zoomCenterX){
291
if(this._centerImg&&this._centerImg._loaded){
292
_35=Math.min(this._centerImg.width,_35);
293
}
294
this.zoomCenterX=Math.max(0,Math.round(_35));
295
}
296
},_setZoomCenterYAttr:function(_36){
297
if(_36!=this.zoomCenterY){
298
if(this._centerImg&&this._centerImg._loaded){
299
_36=Math.min(this._centerImg.height,_36);
300
}
301
this.zoomCenterY=Math.max(0,Math.round(_36));
302
}
303
},_setZoomCenterAttr:function(_37){
304
if(_37.x!=this.zoomCenterX||_37.y!=this.zoomCenterY){
305
this.set("zoomCenterX",_37.x);
306
this.set("zoomCenterY",_37.y);
307
this.render();
308
}
309
},_setAnimatedZoomAttr:function(_38){
310
if(this._anim&&this._anim.status()=="playing"){
311
return;
312
}
313
this._anim=new dojo.Animation({curve:[this.zoom,_38],onAnimate:this._updateAnimatedZoom,onEnd:this._onAnimEnd});
314
this._anim.play();
315
},_updateAnimatedZoom:function(_39){
316
this._setZoomAttr(_39);
317
},_setCenterUrlAttr:function(_3a){
318
this._setImage("center",_3a);
319
},_setLeftUrlAttr:function(_3b){
320
this._setImage("left",_3b);
321
},_setRightUrlAttr:function(_3c){
322
this._setImage("right",_3c);
323
},_setImage:function(_3d,_3e){
324
var _3f=null;
325
var _40=null;
326
if(dojo.isString(_3e)){
327
_40=_3e;
328
}else{
329
_40=_3e.large;
330
_3f=_3e.small;
331
}
332
if(this["_"+_3d+"Img"]&&this["_"+_3d+"Img"]._src==_40){
333
return;
334
}
335
var _41=this["_"+_3d+"Img"]=new Image();
336
_41._type=_3d;
337
_41._loaded=false;
338
_41._src=_40;
339
_41._conn=dojo.connect(_41,"onload",this.handleLoad);
340
if(_3f){
341
var _42=this["_"+_3d+"SmallImg"]=new Image();
342
_42._type=_3d;
343
_42._loaded=false;
344
_42._conn=dojo.connect(_42,"onload",this.handleLoad);
345
_42._isSmall=true;
346
_42._src=_3f;
347
_42.src=_3f;
348
}
349
_41.src=_40;
350
},handleLoad:function(evt){
351
var img=evt.target;
352
img._loaded=true;
353
dojo.disconnect(img._conn);
354
var _43=img._type;
355
switch(_43){
356
case "center":
357
this.zoomCenterX=img.width/2;
358
this.zoomCenterY=img.height/2;
359
break;
360
}
361
var _44=img.height;
362
var _45=img.width;
363
if(_45/this.size.w<_44/this.size.h){
364
img._baseHeight=this.canvas.height;
365
img._baseWidth=_45/(_44/this.size.h);
366
}else{
367
img._baseWidth=this.canvas.width;
368
img._baseHeight=_44/(_45/this.size.w);
369
}
370
img._centerX=_45/2;
371
img._centerY=_44/2;
372
this.render();
373
this.onLoad(img._type,img._src,img._isSmall);
374
},onLoad:function(_46,url,_47){
375
}});
376
}