summaryrefslogtreecommitdiff
path: root/js/dojo-1.6/dojox/image/Magnifier.xd.js
blob: 7899658bbece5d6a06daf09d572b5dd774b8029e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
/*
	Copyright (c) 2004-2011, The Dojo Foundation All Rights Reserved.
	Available via Academic Free License >= 2.1 OR the modified BSD license.
	see: http://dojotoolkit.org/license for details
*/


dojo._xdResourceLoaded(function(dojo, dijit, dojox){
return {depends: [["provide", "dojox.image.Magnifier"],
["require", "dojox.gfx"],
["require", "dojox.image.MagnifierLite"]],
defineResource: function(dojo, dijit, dojox){if(!dojo._hasResource["dojox.image.Magnifier"]){ //_hasResource checks added by build. Do not use _hasResource directly in your code.
dojo._hasResource["dojox.image.Magnifier"] = true;
dojo.provide("dojox.image.Magnifier");

dojo.require("dojox.gfx");
dojo.require("dojox.image.MagnifierLite");

dojo.declare("dojox.image.Magnifier",
	dojox.image.MagnifierLite,{
	// summary:
	//		Adds magnification on a portion of an image element, using `dojox.gfx`
	//
	// description:
	//		An unobtrusive way to add an unstyled overlay
	// 		above the srcNode image element. The overlay/glass is a
	//		scaled version of the src image (so larger images sized down
	//		are clearer).
	//
	//		over-ride the _createGlass method to create your custom surface,
	//		being sure to create an img node on that surface.

	_createGlass: function(){
		// summary: create the glassNode, and an img on a dojox.gfx surface

		// images are hard to make into workable templates, so just add outer overlay
		// and skip using dijit._Templated
		this.glassNode = dojo.create('div', {
			style:{
				height: this.glassSize + "px",
				width: this.glassSize + "px"
			},
			"className":"glassNode"
		}, dojo.body());
		this.surfaceNode = dojo.create('div', null, this.glassNode);

		this.surface = dojox.gfx.createSurface(this.surfaceNode, this.glassSize, this.glassSize);
		this.img = this.surface.createImage({
		   src: this.domNode.src,
		   width: this._zoomSize.w,
		   height: this._zoomSize.h
		});

	},

	_placeGlass: function(e){
		// summary: position the overlay centered under the cursor
		var x = e.pageX - 2,
			y = e.pageY - 2,
			xMax = this.offset.x + this.offset.w + 2,
			yMax = this.offset.y + this.offset.h + 2
		;
		
		// with svg, our mouseout connection to the image surface doesn't
		// fire, so we'r have to manually calculate offsets
		if(x < this.offset.x || y < this.offset.y || x > xMax || y > yMax){
			this._hideGlass();
		}else{
			this.inherited(arguments);
		}
	},

	_setImage: function(e){
		// summary: set the image's offset in the clipping window relative to the mouse position

		var xOff = (e.pageX - this.offset.l) / this.offset.w,
			yOff = (e.pageY - this.offset.t) / this.offset.h,
			x = (this._zoomSize.w * xOff * -1)+(this.glassSize*xOff),
			y = (this._zoomSize.h * yOff * -1)+(this.glassSize*yOff)
		;
		// set the image offset
		this.img.setShape({ x: x, y: y });

	}

});

}

}};});