annotate client/digitallibrary/jquery/jquery.digilib.js @ 626:e9493573e5d8 jquery

rendering marks works now
author robcast
date Tue, 18 Jan 2011 16:06:22 +0100
parents 6b1b4d269967
children adb852652441
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
597
33605dd3e9c6 version zero of jquery.digilib
robcast
parents:
diff changeset
1 /*
33605dd3e9c6 version zero of jquery.digilib
robcast
parents:
diff changeset
2 * digilib jQuery plugin
33605dd3e9c6 version zero of jquery.digilib
robcast
parents:
diff changeset
3 *
33605dd3e9c6 version zero of jquery.digilib
robcast
parents:
diff changeset
4 */
33605dd3e9c6 version zero of jquery.digilib
robcast
parents:
diff changeset
5
33605dd3e9c6 version zero of jquery.digilib
robcast
parents:
diff changeset
6 (function($) {
611
d332c61da1b0 some refactoring, onclick handlers now work with arguments
hertzhaft
parents: 610
diff changeset
7 var actions = {
603
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
8 reference : {
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
9 onclick : "javascript:getRefWin()",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
10 tooltip : "get a reference URL",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
11 img : "reference.png"
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
12 },
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
13 zoomin : {
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
14 onclick : "javascript:dl.zoomBy(1.4)",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
15 tooltip : "zoom in",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
16 img : "zoom-in.png"
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
17 },
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
18 zoomout : {
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
19 onclick : "javascript:zoomBy(0.7)",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
20 tooltip : "zoom out",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
21 img : "zoom-out.png"
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
22 },
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
23 zoomarea : {
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
24 onclick : "javascript:zoomArea()",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
25 tooltip : "zoom area",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
26 img : "zoom-area.png"
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
27 },
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
28 zoomfull : {
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
29 onclick : "javascript:zoomFullpage()",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
30 tooltip : "view the whole image",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
31 img : "zoom-full.png"
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
32 },
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
33 pagewidth : {
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
34 onclick : "javascript:zoomFullpage('width')",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
35 tooltip : "page width",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
36 img : "pagewidth.png"
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
37 },
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
38 back : {
616
89f53fb8fd13 first attempt at switching images by page number
hertzhaft
parents: 615
diff changeset
39 onclick : ["gotoPage", "-1"],
603
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
40 tooltip : "goto previous image",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
41 img : "back.png"
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
42 },
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
43 fwd : {
616
89f53fb8fd13 first attempt at switching images by page number
hertzhaft
parents: 615
diff changeset
44 onclick : ["gotoPage", "+1"],
603
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
45 tooltip : "goto next image",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
46 img : "fwd.png"
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
47 },
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
48 page : {
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
49 onclick : "javascript:gotoPageWin()",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
50 tooltip : "specify image",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
51 img : "page.png"
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
52 },
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
53 bird : {
610
2f2cd8c44a1c toggle view event handlers for bird's eye and 'about windows
hertzhaft
parents: 609
diff changeset
54 onclick : "toggleBirdDiv",
603
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
55 tooltip : "show bird's eye view",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
56 img : "birds-eye.png"
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
57 },
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
58 help : {
616
89f53fb8fd13 first attempt at switching images by page number
hertzhaft
parents: 615
diff changeset
59 onclick : "toggleAboutDiv",
603
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
60 tooltip : "about Digilib",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
61 img : "help.png"
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
62 },
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
63 reset : {
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
64 onclick : "javascript:resetImage()",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
65 tooltip : "reset image",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
66 img : "reset.png"
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
67 },
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
68 mark : {
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
69 onclick : "javascript:setMark()",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
70 tooltip : "set a mark",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
71 img : "mark.png"
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
72 },
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
73 delmark : {
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
74 onclick : "javascript:removeMark()",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
75 tooltip : "delete the last mark",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
76 img : "delmark.png"
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
77 },
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
78 hmir : {
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
79 onclick : "javascript:mirror('h')",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
80 tooltip : "mirror horizontally",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
81 img : "mirror-horizontal.png"
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
82 },
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
83 vmir : {
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
84 onclick : "javascript:mirror('v')",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
85 tooltip : "mirror vertically",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
86 img : "mirror-vertical.png"
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
87 },
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
88 rot : {
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
89 onclick : "javascript:setParamWin('rot', 'Rotate (0..360) clockwise')",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
90 tooltip : "rotate image",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
91 img : "rotate.png"
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
92 },
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
93 brgt : {
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
94 onclick : "javascript:setParamWin('brgt', 'Brightness (-255..255)')",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
95 tooltip : "set brightness",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
96 img : "brightness.png"
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
97 },
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
98 cont : {
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
99 onclick : "javascript:setParamWin('cont', 'Contrast (0..8)')",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
100 tooltip : "set contrast",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
101 img : "contrast.png"
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
102 },
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
103 rgb : {
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
104 onclick : "javascript:setParamWin('rgb', '...')",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
105 tooltip : "set rgb values",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
106 img : "rgb.png"
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
107 },
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
108 quality : {
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
109 onclick : "javascript:setQualityWin('Quality (0..2)')",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
110 tooltip : "set image quality",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
111 img : "quality.png"
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
112 },
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
113 size : {
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
114 onclick : "javascript:toggleSizeMenu()",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
115 tooltip : "set page size",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
116 img : "size.png"
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
117 },
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
118 calibrationx : {
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
119 onclick : "javascript:calibrate('x')",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
120 tooltip : "calibrate screen x-ratio",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
121 img : "calibration-x.png"
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
122 },
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
123 scale : {
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
124 onclick : "javascript:toggleScaleMenu()",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
125 tooltip : "change image scale",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
126 img : "original-size.png"
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
127 },
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
128 options : {
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
129 onclick : "javascript:toggleOptionDiv()",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
130 tooltip : "hide options",
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
131 img : "options.png"
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
132 },
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
133 SEP : {
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
134 img : "sep.png"
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
135 }
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
136 };
610
2f2cd8c44a1c toggle view event handlers for bird's eye and 'about windows
hertzhaft
parents: 609
diff changeset
137
598
81723e7efe82 next version zero of jquery.digilib
robcast
parents: 597
diff changeset
138 var defaults = {
610
2f2cd8c44a1c toggle view event handlers for bird's eye and 'about windows
hertzhaft
parents: 609
diff changeset
139 // the root digilib element, for easy retrieval
2f2cd8c44a1c toggle view event handlers for bird's eye and 'about windows
hertzhaft
parents: 609
diff changeset
140 'digilibRoot' : null,
609
e18dedef32fb setup the 'about' window
hertzhaft
parents: 608
diff changeset
141 // version of this script
e18dedef32fb setup the 'about' window
hertzhaft
parents: 608
diff changeset
142 'version' : 'jquery.digilib.js 1.0',
e18dedef32fb setup the 'about' window
hertzhaft
parents: 608
diff changeset
143 // logo url
e18dedef32fb setup the 'about' window
hertzhaft
parents: 608
diff changeset
144 'logoUrl' : '../img/digilib-logo-text1.png',
e18dedef32fb setup the 'about' window
hertzhaft
parents: 608
diff changeset
145 // repository url
e18dedef32fb setup the 'about' window
hertzhaft
parents: 608
diff changeset
146 'reposUrl' : 'http://digilib.berlios.de',
603
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
147 // base URL to Scaler servlet
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
148 'scalerBaseUrl' : 'http://digilib.mpiwg-berlin.mpg.de/digitallibrary/servlet/Scaler',
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
149 // list of Scaler parameters
620
b930fa64c684 scalerImgLoaded sets up img trafo
robcast
parents: 619
diff changeset
150 'scalerParamNames' : ['fn','pn','dw','dh','ww','wh','wx','wy','ws','mo',
b930fa64c684 scalerImgLoaded sets up img trafo
robcast
parents: 619
diff changeset
151 'rot','cont','brgt','rgbm','rgba','ddpi','ddpix','ddpiy'],
b930fa64c684 scalerImgLoaded sets up img trafo
robcast
parents: 619
diff changeset
152 // Scaler parameter defaults
b930fa64c684 scalerImgLoaded sets up img trafo
robcast
parents: 619
diff changeset
153 'ww' : 1.0,
b930fa64c684 scalerImgLoaded sets up img trafo
robcast
parents: 619
diff changeset
154 'wh' : 1.0,
b930fa64c684 scalerImgLoaded sets up img trafo
robcast
parents: 619
diff changeset
155 'wx' : 0.0,
b930fa64c684 scalerImgLoaded sets up img trafo
robcast
parents: 619
diff changeset
156 'wy' : 0.0,
b930fa64c684 scalerImgLoaded sets up img trafo
robcast
parents: 619
diff changeset
157 'ws' : 1.0,
603
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
158 // mode of operation.
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
159 // fullscreen: takes parameters from page URL, keeps state in page URL
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
160 // embedded: takes parameters from Javascript options, keeps state inside object
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
161 'interactionMode' : 'fullscreen',
611
d332c61da1b0 some refactoring, onclick handlers now work with arguments
hertzhaft
parents: 610
diff changeset
162 // actions
d332c61da1b0 some refactoring, onclick handlers now work with arguments
hertzhaft
parents: 610
diff changeset
163 'actions' : actions,
605
959bf7c3d684 bind data and actions to buttons
hertzhaft
parents: 604
diff changeset
164 // path to button images (must end with a slash)
959bf7c3d684 bind data and actions to buttons
hertzhaft
parents: 604
diff changeset
165 'buttonsImagePath' : '../greyskin/',
611
d332c61da1b0 some refactoring, onclick handlers now work with arguments
hertzhaft
parents: 610
diff changeset
166 // actions groups
d332c61da1b0 some refactoring, onclick handlers now work with arguments
hertzhaft
parents: 610
diff changeset
167 'actionsStandard' : ["reference","zoomin","zoomout","zoomarea","zoomfull","pagewidth","back","fwd","page","bird","SEP","help","reset","options"],
d332c61da1b0 some refactoring, onclick handlers now work with arguments
hertzhaft
parents: 610
diff changeset
168 'actionsSpecial' : ["mark","delmark","hmir","vmir","rot","brgt","cont","rgb","quality","size","calibrationx","scale","SEP","options"],
d332c61da1b0 some refactoring, onclick handlers now work with arguments
hertzhaft
parents: 610
diff changeset
169 'actionsCustom' : [],
609
e18dedef32fb setup the 'about' window
hertzhaft
parents: 608
diff changeset
170 // is birdView shown?
e18dedef32fb setup the 'about' window
hertzhaft
parents: 608
diff changeset
171 'isBirdDivVisible' : false,
608
5de82bb5022d setup bird's eye view div
hertzhaft
parents: 607
diff changeset
172 // dimensions of bird's eye window
5de82bb5022d setup bird's eye view div
hertzhaft
parents: 607
diff changeset
173 'birdMaxX' : 200,
609
e18dedef32fb setup the 'about' window
hertzhaft
parents: 608
diff changeset
174 'birdMaxY' : 200,
e18dedef32fb setup the 'about' window
hertzhaft
parents: 608
diff changeset
175 // is the "about" window shown?
e18dedef32fb setup the 'about' window
hertzhaft
parents: 608
diff changeset
176 'isAboutDivVisible' : false
e18dedef32fb setup the 'about' window
hertzhaft
parents: 608
diff changeset
177
603
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
178 };
598
81723e7efe82 next version zero of jquery.digilib
robcast
parents: 597
diff changeset
179
601
4da7592149e7 start work on scaler call
robcast
parents: 600
diff changeset
180 // parameters from the query string
600
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
181 var queryParams = {};
601
4da7592149e7 start work on scaler call
robcast
parents: 600
diff changeset
182
4da7592149e7 start work on scaler call
robcast
parents: 600
diff changeset
183 // affine geometry classes
4da7592149e7 start work on scaler call
robcast
parents: 600
diff changeset
184 var geom = dlGeometry();
597
33605dd3e9c6 version zero of jquery.digilib
robcast
parents:
diff changeset
185
33605dd3e9c6 version zero of jquery.digilib
robcast
parents:
diff changeset
186 var methods = {
601
4da7592149e7 start work on scaler call
robcast
parents: 600
diff changeset
187 // digilib initialization
597
33605dd3e9c6 version zero of jquery.digilib
robcast
parents:
diff changeset
188 init : function(options) {
601
4da7592149e7 start work on scaler call
robcast
parents: 600
diff changeset
189 // settings for this digilib instance are merged from defaults and options
600
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
190 var settings = $.extend({}, defaults, options);
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
191 var isFullscreen = settings.interactionMode === 'fullscreen';
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
192 if (isFullscreen) {
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
193 queryParams = parseQueryParams();
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
194 };
597
33605dd3e9c6 version zero of jquery.digilib
robcast
parents:
diff changeset
195 return this.each(function() {
598
81723e7efe82 next version zero of jquery.digilib
robcast
parents: 597
diff changeset
196 var $elem = $(this);
81723e7efe82 next version zero of jquery.digilib
robcast
parents: 597
diff changeset
197 var data = $elem.data('digilib');
600
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
198 var elemSettings;
601
4da7592149e7 start work on scaler call
robcast
parents: 600
diff changeset
199 // if the plugin hasn't been initialized yet
597
33605dd3e9c6 version zero of jquery.digilib
robcast
parents:
diff changeset
200 if (!data) {
598
81723e7efe82 next version zero of jquery.digilib
robcast
parents: 597
diff changeset
201 // merge query parameters
600
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
202 if (isFullscreen) {
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
203 elemSettings = $.extend({}, settings, queryParams);
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
204 } else {
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
205 elemSettings = $.extend({}, settings, parseImgParams($elem));
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
206 };
610
2f2cd8c44a1c toggle view event handlers for bird's eye and 'about windows
hertzhaft
parents: 609
diff changeset
207 // store $(this) element in the settings
2f2cd8c44a1c toggle view event handlers for bird's eye and 'about windows
hertzhaft
parents: 609
diff changeset
208 elemSettings.digilibRoot = $elem;
620
b930fa64c684 scalerImgLoaded sets up img trafo
robcast
parents: 619
diff changeset
209 data = {
b930fa64c684 scalerImgLoaded sets up img trafo
robcast
parents: 619
diff changeset
210 target : $elem,
b930fa64c684 scalerImgLoaded sets up img trafo
robcast
parents: 619
diff changeset
211 settings : elemSettings
b930fa64c684 scalerImgLoaded sets up img trafo
robcast
parents: 619
diff changeset
212 };
598
81723e7efe82 next version zero of jquery.digilib
robcast
parents: 597
diff changeset
213 // store in data element
620
b930fa64c684 scalerImgLoaded sets up img trafo
robcast
parents: 619
diff changeset
214 $elem.data('digilib', data);
597
33605dd3e9c6 version zero of jquery.digilib
robcast
parents:
diff changeset
215 }
626
e9493573e5d8 rendering marks works now
robcast
parents: 624
diff changeset
216 unpackParams(data);
601
4da7592149e7 start work on scaler call
robcast
parents: 600
diff changeset
217 // create HTML structure
620
b930fa64c684 scalerImgLoaded sets up img trafo
robcast
parents: 619
diff changeset
218 setupScalerDiv(data);
621
7f97716b901c changed methods to pass "data" around instead of "settings"
robcast
parents: 620
diff changeset
219 setupButtons(data, 'actionsStandard');
620
b930fa64c684 scalerImgLoaded sets up img trafo
robcast
parents: 619
diff changeset
220 // bird's eye view creation - TODO: could be deferred?
621
7f97716b901c changed methods to pass "data" around instead of "settings"
robcast
parents: 620
diff changeset
221 setupBirdviewDiv(data);
620
b930fa64c684 scalerImgLoaded sets up img trafo
robcast
parents: 619
diff changeset
222 // about window creation - TODO: could be deferred? restrict to only one item?
621
7f97716b901c changed methods to pass "data" around instead of "settings"
robcast
parents: 620
diff changeset
223 setupAboutDiv(data);
597
33605dd3e9c6 version zero of jquery.digilib
robcast
parents:
diff changeset
224 });
33605dd3e9c6 version zero of jquery.digilib
robcast
parents:
diff changeset
225 },
601
4da7592149e7 start work on scaler call
robcast
parents: 600
diff changeset
226
4da7592149e7 start work on scaler call
robcast
parents: 600
diff changeset
227 // clean up digilib
597
33605dd3e9c6 version zero of jquery.digilib
robcast
parents:
diff changeset
228 destroy : function() {
33605dd3e9c6 version zero of jquery.digilib
robcast
parents:
diff changeset
229 return this.each(function(){
33605dd3e9c6 version zero of jquery.digilib
robcast
parents:
diff changeset
230 var $this = $(this);
33605dd3e9c6 version zero of jquery.digilib
robcast
parents:
diff changeset
231 var data = $this.data('digilib');
33605dd3e9c6 version zero of jquery.digilib
robcast
parents:
diff changeset
232 // Namespacing FTW
598
81723e7efe82 next version zero of jquery.digilib
robcast
parents: 597
diff changeset
233 $(window).unbind('.digilib'); // unbinds all digilibs(?)
597
33605dd3e9c6 version zero of jquery.digilib
robcast
parents:
diff changeset
234 data.digilib.remove();
33605dd3e9c6 version zero of jquery.digilib
robcast
parents:
diff changeset
235 $this.removeData('digilib');
33605dd3e9c6 version zero of jquery.digilib
robcast
parents:
diff changeset
236 });
610
2f2cd8c44a1c toggle view event handlers for bird's eye and 'about windows
hertzhaft
parents: 609
diff changeset
237 },
2f2cd8c44a1c toggle view event handlers for bird's eye and 'about windows
hertzhaft
parents: 609
diff changeset
238
2f2cd8c44a1c toggle view event handlers for bird's eye and 'about windows
hertzhaft
parents: 609
diff changeset
239 // event handler: toggles the visibility of the 'about' window
2f2cd8c44a1c toggle view event handlers for bird's eye and 'about windows
hertzhaft
parents: 609
diff changeset
240 toggleAboutDiv : function () {
2f2cd8c44a1c toggle view event handlers for bird's eye and 'about windows
hertzhaft
parents: 609
diff changeset
241 var $elem = $(this); // the clicked button
2f2cd8c44a1c toggle view event handlers for bird's eye and 'about windows
hertzhaft
parents: 609
diff changeset
242 var settings = $elem.data('digilib').settings;
2f2cd8c44a1c toggle view event handlers for bird's eye and 'about windows
hertzhaft
parents: 609
diff changeset
243 var $root = settings.digilibRoot;
2f2cd8c44a1c toggle view event handlers for bird's eye and 'about windows
hertzhaft
parents: 609
diff changeset
244 var $about = $root.find('div.about');
2f2cd8c44a1c toggle view event handlers for bird's eye and 'about windows
hertzhaft
parents: 609
diff changeset
245 settings.isAboutDivVisible = !settings.isAboutDivVisible;
2f2cd8c44a1c toggle view event handlers for bird's eye and 'about windows
hertzhaft
parents: 609
diff changeset
246 if (settings.isAboutDivVisible) {
2f2cd8c44a1c toggle view event handlers for bird's eye and 'about windows
hertzhaft
parents: 609
diff changeset
247 $about.fadeIn();
2f2cd8c44a1c toggle view event handlers for bird's eye and 'about windows
hertzhaft
parents: 609
diff changeset
248 } else {
2f2cd8c44a1c toggle view event handlers for bird's eye and 'about windows
hertzhaft
parents: 609
diff changeset
249 $about.fadeOut();
2f2cd8c44a1c toggle view event handlers for bird's eye and 'about windows
hertzhaft
parents: 609
diff changeset
250 };
2f2cd8c44a1c toggle view event handlers for bird's eye and 'about windows
hertzhaft
parents: 609
diff changeset
251 return false;
2f2cd8c44a1c toggle view event handlers for bird's eye and 'about windows
hertzhaft
parents: 609
diff changeset
252 },
2f2cd8c44a1c toggle view event handlers for bird's eye and 'about windows
hertzhaft
parents: 609
diff changeset
253
2f2cd8c44a1c toggle view event handlers for bird's eye and 'about windows
hertzhaft
parents: 609
diff changeset
254 // event handler: toggles the visibility of the bird's eye window
2f2cd8c44a1c toggle view event handlers for bird's eye and 'about windows
hertzhaft
parents: 609
diff changeset
255 toggleBirdDiv : function () {
616
89f53fb8fd13 first attempt at switching images by page number
hertzhaft
parents: 615
diff changeset
256 // TODO: red frame functionality
610
2f2cd8c44a1c toggle view event handlers for bird's eye and 'about windows
hertzhaft
parents: 609
diff changeset
257 var $elem = $(this); // the clicked button
2f2cd8c44a1c toggle view event handlers for bird's eye and 'about windows
hertzhaft
parents: 609
diff changeset
258 var settings = $elem.data('digilib').settings;
2f2cd8c44a1c toggle view event handlers for bird's eye and 'about windows
hertzhaft
parents: 609
diff changeset
259 var $root = settings.digilibRoot;
2f2cd8c44a1c toggle view event handlers for bird's eye and 'about windows
hertzhaft
parents: 609
diff changeset
260 var $bird = $root.find('div.birdview');
2f2cd8c44a1c toggle view event handlers for bird's eye and 'about windows
hertzhaft
parents: 609
diff changeset
261 settings.isBirdDivVisible = !settings.isBirdDivVisible;
2f2cd8c44a1c toggle view event handlers for bird's eye and 'about windows
hertzhaft
parents: 609
diff changeset
262 if (settings.isBirdDivVisible) {
2f2cd8c44a1c toggle view event handlers for bird's eye and 'about windows
hertzhaft
parents: 609
diff changeset
263 $bird.fadeIn();
2f2cd8c44a1c toggle view event handlers for bird's eye and 'about windows
hertzhaft
parents: 609
diff changeset
264 } else {
2f2cd8c44a1c toggle view event handlers for bird's eye and 'about windows
hertzhaft
parents: 609
diff changeset
265 $bird.fadeOut();
2f2cd8c44a1c toggle view event handlers for bird's eye and 'about windows
hertzhaft
parents: 609
diff changeset
266 };
2f2cd8c44a1c toggle view event handlers for bird's eye and 'about windows
hertzhaft
parents: 609
diff changeset
267 return false;
616
89f53fb8fd13 first attempt at switching images by page number
hertzhaft
parents: 615
diff changeset
268 },
89f53fb8fd13 first attempt at switching images by page number
hertzhaft
parents: 615
diff changeset
269
89f53fb8fd13 first attempt at switching images by page number
hertzhaft
parents: 615
diff changeset
270 // goto given page nr (+/-: relative)
89f53fb8fd13 first attempt at switching images by page number
hertzhaft
parents: 615
diff changeset
271 gotoPage : function(pageNr, keepMarks) {
89f53fb8fd13 first attempt at switching images by page number
hertzhaft
parents: 615
diff changeset
272 var $elem = $(this); // the clicked button
89f53fb8fd13 first attempt at switching images by page number
hertzhaft
parents: 615
diff changeset
273 var settings = $elem.data('digilib').settings;
89f53fb8fd13 first attempt at switching images by page number
hertzhaft
parents: 615
diff changeset
274 var oldpn = settings.pn;
617
8b1e255b617c small retouches
hertzhaft
parents: 616
diff changeset
275 var pn = setNumValue(settings, "pn", pageNr);
8b1e255b617c small retouches
hertzhaft
parents: 616
diff changeset
276 if (pn == null) return false; // nothing happened
616
89f53fb8fd13 first attempt at switching images by page number
hertzhaft
parents: 615
diff changeset
277 if (pn < 1) {
89f53fb8fd13 first attempt at switching images by page number
hertzhaft
parents: 615
diff changeset
278 alert("no such page (page number too low)");
89f53fb8fd13 first attempt at switching images by page number
hertzhaft
parents: 615
diff changeset
279 settings.pn = oldpn;
89f53fb8fd13 first attempt at switching images by page number
hertzhaft
parents: 615
diff changeset
280 return false;
89f53fb8fd13 first attempt at switching images by page number
hertzhaft
parents: 615
diff changeset
281 };
89f53fb8fd13 first attempt at switching images by page number
hertzhaft
parents: 615
diff changeset
282 if (settings.pt) {
89f53fb8fd13 first attempt at switching images by page number
hertzhaft
parents: 615
diff changeset
283 if (pn > settings.pt) {
89f53fb8fd13 first attempt at switching images by page number
hertzhaft
parents: 615
diff changeset
284 alert("no such page (page number too high)");
89f53fb8fd13 first attempt at switching images by page number
hertzhaft
parents: 615
diff changeset
285 settings.pn = oldpn;
89f53fb8fd13 first attempt at switching images by page number
hertzhaft
parents: 615
diff changeset
286 return false;
89f53fb8fd13 first attempt at switching images by page number
hertzhaft
parents: 615
diff changeset
287 }
89f53fb8fd13 first attempt at switching images by page number
hertzhaft
parents: 615
diff changeset
288 };
89f53fb8fd13 first attempt at switching images by page number
hertzhaft
parents: 615
diff changeset
289 // TODO: keepMarks
89f53fb8fd13 first attempt at switching images by page number
hertzhaft
parents: 615
diff changeset
290 var $root = settings.digilibRoot;
89f53fb8fd13 first attempt at switching images by page number
hertzhaft
parents: 615
diff changeset
291 var $img = $root.find('img.pic');
89f53fb8fd13 first attempt at switching images by page number
hertzhaft
parents: 615
diff changeset
292 display($img, settings);
617
8b1e255b617c small retouches
hertzhaft
parents: 616
diff changeset
293 return false;
597
33605dd3e9c6 version zero of jquery.digilib
robcast
parents:
diff changeset
294 }
598
81723e7efe82 next version zero of jquery.digilib
robcast
parents: 597
diff changeset
295 };
597
33605dd3e9c6 version zero of jquery.digilib
robcast
parents:
diff changeset
296
616
89f53fb8fd13 first attempt at switching images by page number
hertzhaft
parents: 615
diff changeset
297 // sets a key to a value (relative values with +/- if relative=true)
89f53fb8fd13 first attempt at switching images by page number
hertzhaft
parents: 615
diff changeset
298 var setNumValue = function(settings, key, value) {
89f53fb8fd13 first attempt at switching images by page number
hertzhaft
parents: 615
diff changeset
299 // TODO: type and error checking
89f53fb8fd13 first attempt at switching images by page number
hertzhaft
parents: 615
diff changeset
300 if (settings[key] == null) return null;
89f53fb8fd13 first attempt at switching images by page number
hertzhaft
parents: 615
diff changeset
301 var sign = value.substring(0,1);
89f53fb8fd13 first attempt at switching images by page number
hertzhaft
parents: 615
diff changeset
302 if (sign === '+' || sign === '-') {
89f53fb8fd13 first attempt at switching images by page number
hertzhaft
parents: 615
diff changeset
303 settings[key] = parseFloat(settings[key]) + parseFloat(value);
89f53fb8fd13 first attempt at switching images by page number
hertzhaft
parents: 615
diff changeset
304 } else {
89f53fb8fd13 first attempt at switching images by page number
hertzhaft
parents: 615
diff changeset
305 settings[key] = value;
89f53fb8fd13 first attempt at switching images by page number
hertzhaft
parents: 615
diff changeset
306 }
89f53fb8fd13 first attempt at switching images by page number
hertzhaft
parents: 615
diff changeset
307 return settings[key];
89f53fb8fd13 first attempt at switching images by page number
hertzhaft
parents: 615
diff changeset
308 };
89f53fb8fd13 first attempt at switching images by page number
hertzhaft
parents: 615
diff changeset
309
601
4da7592149e7 start work on scaler call
robcast
parents: 600
diff changeset
310 // returns parameters from page url
600
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
311 var parseQueryParams = function() {
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
312 return parseQueryString(location.search.slice(1));
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
313 };
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
314
601
4da7592149e7 start work on scaler call
robcast
parents: 600
diff changeset
315 // returns parameters taken from embedded img-element
600
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
316 var parseImgParams = function($elem) {
606
d08d095430c3 keeping img tag for embedded mode seems to work now
robcast
parents: 605
diff changeset
317 var src = $elem.find('img').first().attr('src');
d08d095430c3 keeping img tag for embedded mode seems to work now
robcast
parents: 605
diff changeset
318 if (!src) {
d08d095430c3 keeping img tag for embedded mode seems to work now
robcast
parents: 605
diff changeset
319 return null;
d08d095430c3 keeping img tag for embedded mode seems to work now
robcast
parents: 605
diff changeset
320 }
600
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
321 var pos = src.indexOf('?');
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
322 var query = (pos < 0) ? '' : src.substring(pos + 1);
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
323 var scalerUrl = src.substring(0, pos);
620
b930fa64c684 scalerImgLoaded sets up img trafo
robcast
parents: 619
diff changeset
324 var params = parseQueryString(query);
b930fa64c684 scalerImgLoaded sets up img trafo
robcast
parents: 619
diff changeset
325 params.scalerBaseUrl = scalerUrl;
600
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
326 // console.log(hash);
620
b930fa64c684 scalerImgLoaded sets up img trafo
robcast
parents: 619
diff changeset
327 return params;
600
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
328 };
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
329
601
4da7592149e7 start work on scaler call
robcast
parents: 600
diff changeset
330 // parses query parameter string into parameter object
600
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
331 var parseQueryString = function(query) {
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
332 var pairs = query.split("&");
620
b930fa64c684 scalerImgLoaded sets up img trafo
robcast
parents: 619
diff changeset
333 var params = {};
600
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
334 for (var i = 0; i < pairs.length; i++) {
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
335 var pair = pairs[i].split("=");
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
336 if (pair.length === 2) {
620
b930fa64c684 scalerImgLoaded sets up img trafo
robcast
parents: 619
diff changeset
337 params[pair[0]] = pair[1];
600
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
338 };
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
339 };
620
b930fa64c684 scalerImgLoaded sets up img trafo
robcast
parents: 619
diff changeset
340 return params;
600
9da729b90004 parameter parsing
hertzhaft
parents: 598
diff changeset
341 };
597
33605dd3e9c6 version zero of jquery.digilib
robcast
parents:
diff changeset
342
608
5de82bb5022d setup bird's eye view div
hertzhaft
parents: 607
diff changeset
343 // returns a query string from key names from a parameter hash
621
7f97716b901c changed methods to pass "data" around instead of "settings"
robcast
parents: 620
diff changeset
344 var getParamString = function (settings, keys) {
608
5de82bb5022d setup bird's eye view div
hertzhaft
parents: 607
diff changeset
345 var paramString = '';
5de82bb5022d setup bird's eye view div
hertzhaft
parents: 607
diff changeset
346 var latter = false;
5de82bb5022d setup bird's eye view div
hertzhaft
parents: 607
diff changeset
347 for (i = 0; i < keys.length; ++i) {
5de82bb5022d setup bird's eye view div
hertzhaft
parents: 607
diff changeset
348 var key = keys[i];
5de82bb5022d setup bird's eye view div
hertzhaft
parents: 607
diff changeset
349 if (settings[key]) {
5de82bb5022d setup bird's eye view div
hertzhaft
parents: 607
diff changeset
350 // first param gets no '&'
5de82bb5022d setup bird's eye view div
hertzhaft
parents: 607
diff changeset
351 paramString += latter ? '&' : '';
5de82bb5022d setup bird's eye view div
hertzhaft
parents: 607
diff changeset
352 latter = true;
5de82bb5022d setup bird's eye view div
hertzhaft
parents: 607
diff changeset
353 // add parm=val
5de82bb5022d setup bird's eye view div
hertzhaft
parents: 607
diff changeset
354 paramString += key + '=' + settings[key];
5de82bb5022d setup bird's eye view div
hertzhaft
parents: 607
diff changeset
355 };
5de82bb5022d setup bird's eye view div
hertzhaft
parents: 607
diff changeset
356 }
5de82bb5022d setup bird's eye view div
hertzhaft
parents: 607
diff changeset
357 return paramString;
624
6b1b4d269967 more work on initialisation
robcast
parents: 622
diff changeset
358 };
6b1b4d269967 more work on initialisation
robcast
parents: 622
diff changeset
359
6b1b4d269967 more work on initialisation
robcast
parents: 622
diff changeset
360 // processes some parameters into objects and stuff
6b1b4d269967 more work on initialisation
robcast
parents: 622
diff changeset
361 var unpackParams = function (data) {
6b1b4d269967 more work on initialisation
robcast
parents: 622
diff changeset
362 var settings = data.settings;
6b1b4d269967 more work on initialisation
robcast
parents: 622
diff changeset
363 // read zoom area
6b1b4d269967 more work on initialisation
robcast
parents: 622
diff changeset
364 var zoomArea = geom.rectangle(settings.wx, settings.wy, settings.ww, settings.wh);
6b1b4d269967 more work on initialisation
robcast
parents: 622
diff changeset
365 settings.zoomArea = zoomArea;
608
5de82bb5022d setup bird's eye view div
hertzhaft
parents: 607
diff changeset
366
624
6b1b4d269967 more work on initialisation
robcast
parents: 622
diff changeset
367 // read marks
6b1b4d269967 more work on initialisation
robcast
parents: 622
diff changeset
368 var marks = [];
626
e9493573e5d8 rendering marks works now
robcast
parents: 624
diff changeset
369 var mk = settings.mk || '';
e9493573e5d8 rendering marks works now
robcast
parents: 624
diff changeset
370 if (mk.indexOf(";") >= 0) {
e9493573e5d8 rendering marks works now
robcast
parents: 624
diff changeset
371 var pa = mk.split(";"); // old format with ";"
624
6b1b4d269967 more work on initialisation
robcast
parents: 622
diff changeset
372 } else {
626
e9493573e5d8 rendering marks works now
robcast
parents: 624
diff changeset
373 var pa = mk.split(","); // new format
624
6b1b4d269967 more work on initialisation
robcast
parents: 622
diff changeset
374 }
6b1b4d269967 more work on initialisation
robcast
parents: 622
diff changeset
375 for (var i = 0; i < pa.length ; i++) {
6b1b4d269967 more work on initialisation
robcast
parents: 622
diff changeset
376 var pos = pa[i].split("/");
626
e9493573e5d8 rendering marks works now
robcast
parents: 624
diff changeset
377 if (pos.length > 1) {
e9493573e5d8 rendering marks works now
robcast
parents: 624
diff changeset
378 marks.push(geom.position(pos[0], pos[1]));
e9493573e5d8 rendering marks works now
robcast
parents: 624
diff changeset
379 }
624
6b1b4d269967 more work on initialisation
robcast
parents: 622
diff changeset
380 }
6b1b4d269967 more work on initialisation
robcast
parents: 622
diff changeset
381 settings.marks = marks;
6b1b4d269967 more work on initialisation
robcast
parents: 622
diff changeset
382 };
6b1b4d269967 more work on initialisation
robcast
parents: 622
diff changeset
383
6b1b4d269967 more work on initialisation
robcast
parents: 622
diff changeset
384 // put objects back into parameters
6b1b4d269967 more work on initialisation
robcast
parents: 622
diff changeset
385 var packParams = function (data) {
6b1b4d269967 more work on initialisation
robcast
parents: 622
diff changeset
386 var settings = data.settings;
6b1b4d269967 more work on initialisation
robcast
parents: 622
diff changeset
387 if (settings.zoomArea) {
6b1b4d269967 more work on initialisation
robcast
parents: 622
diff changeset
388 settings.wx = settings.zoomArea.x;
6b1b4d269967 more work on initialisation
robcast
parents: 622
diff changeset
389 settings.wy = settings.zoomArea.y;
6b1b4d269967 more work on initialisation
robcast
parents: 622
diff changeset
390 settings.ww = settings.zoomArea.width;
6b1b4d269967 more work on initialisation
robcast
parents: 622
diff changeset
391 settings.wh = settings.zoomArea.height;
6b1b4d269967 more work on initialisation
robcast
parents: 622
diff changeset
392 }
6b1b4d269967 more work on initialisation
robcast
parents: 622
diff changeset
393 if (settings.marks) {
6b1b4d269967 more work on initialisation
robcast
parents: 622
diff changeset
394 var ma = [];
6b1b4d269967 more work on initialisation
robcast
parents: 622
diff changeset
395 for (var i = 0; i < settings.marks.length; i++) {
6b1b4d269967 more work on initialisation
robcast
parents: 622
diff changeset
396 ma.push(cropFloat(settings.marks[i].x) + "/" + cropFloat(settings.marks[i].y));
6b1b4d269967 more work on initialisation
robcast
parents: 622
diff changeset
397 }
6b1b4d269967 more work on initialisation
robcast
parents: 622
diff changeset
398 settings.mk = ma.join(",");
6b1b4d269967 more work on initialisation
robcast
parents: 622
diff changeset
399 }
6b1b4d269967 more work on initialisation
robcast
parents: 622
diff changeset
400 };
6b1b4d269967 more work on initialisation
robcast
parents: 622
diff changeset
401
601
4da7592149e7 start work on scaler call
robcast
parents: 600
diff changeset
402 // returns URL and query string for Scaler
4da7592149e7 start work on scaler call
robcast
parents: 600
diff changeset
403 var getScalerString = function (settings) {
608
5de82bb5022d setup bird's eye view div
hertzhaft
parents: 607
diff changeset
404 var keys = settings.scalerParamNames;
621
7f97716b901c changed methods to pass "data" around instead of "settings"
robcast
parents: 620
diff changeset
405 var queryString = getParamString(settings, keys);
608
5de82bb5022d setup bird's eye view div
hertzhaft
parents: 607
diff changeset
406 var url = settings.scalerBaseUrl + '?' + queryString;
602
c6f62be59683 start work on scaler call
robcast
parents: 601
diff changeset
407 return url;
c6f62be59683 start work on scaler call
robcast
parents: 601
diff changeset
408 };
608
5de82bb5022d setup bird's eye view div
hertzhaft
parents: 607
diff changeset
409
602
c6f62be59683 start work on scaler call
robcast
parents: 601
diff changeset
410 // returns maximum size for scaler img in fullscreen mode
c6f62be59683 start work on scaler call
robcast
parents: 601
diff changeset
411 var getFullscreenImgSize = function($elem) {
c6f62be59683 start work on scaler call
robcast
parents: 601
diff changeset
412 var winH = $(window).height();
c6f62be59683 start work on scaler call
robcast
parents: 601
diff changeset
413 var winW = $(window).width();
c6f62be59683 start work on scaler call
robcast
parents: 601
diff changeset
414 // TODO: account for borders?
c6f62be59683 start work on scaler call
robcast
parents: 601
diff changeset
415 return geom.size(winW, winH);
601
4da7592149e7 start work on scaler call
robcast
parents: 600
diff changeset
416 };
4da7592149e7 start work on scaler call
robcast
parents: 600
diff changeset
417
615
ca1cdfe7b064 factored out display function
hertzhaft
parents: 614
diff changeset
418 // (re)load the img from a new scaler URL
ca1cdfe7b064 factored out display function
hertzhaft
parents: 614
diff changeset
419 var display = function ($img, settings) {
616
89f53fb8fd13 first attempt at switching images by page number
hertzhaft
parents: 615
diff changeset
420 // TODO: update location.href (browser URL) in fullscreen mode
615
ca1cdfe7b064 factored out display function
hertzhaft
parents: 614
diff changeset
421 var scalerUrl = getScalerString(settings);
ca1cdfe7b064 factored out display function
hertzhaft
parents: 614
diff changeset
422 $img.attr('src', scalerUrl);
616
89f53fb8fd13 first attempt at switching images by page number
hertzhaft
parents: 615
diff changeset
423 // TODO: update bird view?
615
ca1cdfe7b064 factored out display function
hertzhaft
parents: 614
diff changeset
424 };
ca1cdfe7b064 factored out display function
hertzhaft
parents: 614
diff changeset
425
601
4da7592149e7 start work on scaler call
robcast
parents: 600
diff changeset
426 // creates HTML structure for digilib in elem
620
b930fa64c684 scalerImgLoaded sets up img trafo
robcast
parents: 619
diff changeset
427 var setupScalerDiv = function (data) {
b930fa64c684 scalerImgLoaded sets up img trafo
robcast
parents: 619
diff changeset
428 var settings = data.settings;
b930fa64c684 scalerImgLoaded sets up img trafo
robcast
parents: 619
diff changeset
429 var $elem = data.target;
616
89f53fb8fd13 first attempt at switching images by page number
hertzhaft
parents: 615
diff changeset
430 var $img;
601
4da7592149e7 start work on scaler call
robcast
parents: 600
diff changeset
431 if (settings.interactionMode === 'fullscreen') {
602
c6f62be59683 start work on scaler call
robcast
parents: 601
diff changeset
432 // fullscreen
c6f62be59683 start work on scaler call
robcast
parents: 601
diff changeset
433 var imgSize = getFullscreenImgSize($elem);
c6f62be59683 start work on scaler call
robcast
parents: 601
diff changeset
434 settings.dw = imgSize.width;
c6f62be59683 start work on scaler call
robcast
parents: 601
diff changeset
435 settings.dh = imgSize.height;
606
d08d095430c3 keeping img tag for embedded mode seems to work now
robcast
parents: 605
diff changeset
436 $img = $('<img/>');
622
2fd6928be5dd questions about display()...
robcast
parents: 621
diff changeset
437 display($img, settings); // TODO: is display the right thing here?
602
c6f62be59683 start work on scaler call
robcast
parents: 601
diff changeset
438 } else {
606
d08d095430c3 keeping img tag for embedded mode seems to work now
robcast
parents: 605
diff changeset
439 // embedded mode -- try to keep img tag
616
89f53fb8fd13 first attempt at switching images by page number
hertzhaft
parents: 615
diff changeset
440 $img = $elem.find('img');
606
d08d095430c3 keeping img tag for embedded mode seems to work now
robcast
parents: 605
diff changeset
441 if ($img.length > 0) {
d08d095430c3 keeping img tag for embedded mode seems to work now
robcast
parents: 605
diff changeset
442 console.debug("img detach:",$img);
d08d095430c3 keeping img tag for embedded mode seems to work now
robcast
parents: 605
diff changeset
443 $img.detach();
d08d095430c3 keeping img tag for embedded mode seems to work now
robcast
parents: 605
diff changeset
444 } else {
d08d095430c3 keeping img tag for embedded mode seems to work now
robcast
parents: 605
diff changeset
445 $img = $('<img/>');
622
2fd6928be5dd questions about display()...
robcast
parents: 621
diff changeset
446 display($img, settings); // dito
606
d08d095430c3 keeping img tag for embedded mode seems to work now
robcast
parents: 605
diff changeset
447 }
601
4da7592149e7 start work on scaler call
robcast
parents: 600
diff changeset
448 }
606
d08d095430c3 keeping img tag for embedded mode seems to work now
robcast
parents: 605
diff changeset
449 // create new html
d08d095430c3 keeping img tag for embedded mode seems to work now
robcast
parents: 605
diff changeset
450 $elem.empty(); // TODO: should we keep stuff for customization?
d08d095430c3 keeping img tag for embedded mode seems to work now
robcast
parents: 605
diff changeset
451 var $scaler = $('<div class="scaler"/>');
d08d095430c3 keeping img tag for embedded mode seems to work now
robcast
parents: 605
diff changeset
452 $elem.append($scaler);
d08d095430c3 keeping img tag for embedded mode seems to work now
robcast
parents: 605
diff changeset
453 $scaler.append($img);
615
ca1cdfe7b064 factored out display function
hertzhaft
parents: 614
diff changeset
454 $img.addClass('pic');
620
b930fa64c684 scalerImgLoaded sets up img trafo
robcast
parents: 619
diff changeset
455 data.img = $img;
b930fa64c684 scalerImgLoaded sets up img trafo
robcast
parents: 619
diff changeset
456 $img.load(scalerImgLoadedFn(data));
601
4da7592149e7 start work on scaler call
robcast
parents: 600
diff changeset
457 };
608
5de82bb5022d setup bird's eye view div
hertzhaft
parents: 607
diff changeset
458
603
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
459 // creates HTML structure for buttons in elem
621
7f97716b901c changed methods to pass "data" around instead of "settings"
robcast
parents: 620
diff changeset
460 var setupButtons = function (data, actionGroup) {
7f97716b901c changed methods to pass "data" around instead of "settings"
robcast
parents: 620
diff changeset
461 var $elem = data.target;
7f97716b901c changed methods to pass "data" around instead of "settings"
robcast
parents: 620
diff changeset
462 var settings = data.settings;
603
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
463 if (settings.interactionMode === 'fullscreen') {
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
464 // fullscreen -- create new
605
959bf7c3d684 bind data and actions to buttons
hertzhaft
parents: 604
diff changeset
465 var $buttonsDiv = $('<div class="buttons"></div>');
959bf7c3d684 bind data and actions to buttons
hertzhaft
parents: 604
diff changeset
466 $elem.append($buttonsDiv);
611
d332c61da1b0 some refactoring, onclick handlers now work with arguments
hertzhaft
parents: 610
diff changeset
467 var actionNames = settings[actionGroup];
d332c61da1b0 some refactoring, onclick handlers now work with arguments
hertzhaft
parents: 610
diff changeset
468 for (var i = 0; i < actionNames.length; i++) {
d332c61da1b0 some refactoring, onclick handlers now work with arguments
hertzhaft
parents: 610
diff changeset
469 var actionName = actionNames[i];
d332c61da1b0 some refactoring, onclick handlers now work with arguments
hertzhaft
parents: 610
diff changeset
470 var actionSettings = settings.actions[actionName];
605
959bf7c3d684 bind data and actions to buttons
hertzhaft
parents: 604
diff changeset
471 // construct the button html
959bf7c3d684 bind data and actions to buttons
hertzhaft
parents: 604
diff changeset
472 var $button = $('<div class="button"></div>');
959bf7c3d684 bind data and actions to buttons
hertzhaft
parents: 604
diff changeset
473 var $a = $('<a/>');
607
dc6b2e7f3621 highlight hovered buttons
hertzhaft
parents: 606
diff changeset
474 var $img = $('<img class="button"/>');
605
959bf7c3d684 bind data and actions to buttons
hertzhaft
parents: 604
diff changeset
475 $buttonsDiv.append($button);
959bf7c3d684 bind data and actions to buttons
hertzhaft
parents: 604
diff changeset
476 $button.append($a);
959bf7c3d684 bind data and actions to buttons
hertzhaft
parents: 604
diff changeset
477 $a.append($img);
959bf7c3d684 bind data and actions to buttons
hertzhaft
parents: 604
diff changeset
478 // add attributes and bindings
611
d332c61da1b0 some refactoring, onclick handlers now work with arguments
hertzhaft
parents: 610
diff changeset
479 $button.attr('title', actionSettings.tooltip);
d332c61da1b0 some refactoring, onclick handlers now work with arguments
hertzhaft
parents: 610
diff changeset
480 $button.addClass('button-' + actionName);
605
959bf7c3d684 bind data and actions to buttons
hertzhaft
parents: 604
diff changeset
481 // let the clicked <a> element know about the digilib context
611
d332c61da1b0 some refactoring, onclick handlers now work with arguments
hertzhaft
parents: 610
diff changeset
482 $a.data('digilib', { 'action' : actionName, 'settings' : settings } );
606
d08d095430c3 keeping img tag for embedded mode seems to work now
robcast
parents: 605
diff changeset
483 $a.bind('click', function() {
612
97082d0c0192 'about' window has its own event handler
hertzhaft
parents: 611
diff changeset
484 var $elem = $(this);
97082d0c0192 'about' window has its own event handler
hertzhaft
parents: 611
diff changeset
485 // get the context data
97082d0c0192 'about' window has its own event handler
hertzhaft
parents: 611
diff changeset
486 var data = $elem.data('digilib');
605
959bf7c3d684 bind data and actions to buttons
hertzhaft
parents: 604
diff changeset
487 // find the action for the clicked element
611
d332c61da1b0 some refactoring, onclick handlers now work with arguments
hertzhaft
parents: 610
diff changeset
488 var method = data.settings.actions[data.action].onclick;
612
97082d0c0192 'about' window has its own event handler
hertzhaft
parents: 611
diff changeset
489 if ($.isArray(method)) {
97082d0c0192 'about' window has its own event handler
hertzhaft
parents: 611
diff changeset
490 $elem.digilib.apply(this, method);
97082d0c0192 'about' window has its own event handler
hertzhaft
parents: 611
diff changeset
491 } else {
97082d0c0192 'about' window has its own event handler
hertzhaft
parents: 611
diff changeset
492 $elem.digilib(method);
97082d0c0192 'about' window has its own event handler
hertzhaft
parents: 611
diff changeset
493 };
611
d332c61da1b0 some refactoring, onclick handlers now work with arguments
hertzhaft
parents: 610
diff changeset
494 console.log(method);
605
959bf7c3d684 bind data and actions to buttons
hertzhaft
parents: 604
diff changeset
495 });
959bf7c3d684 bind data and actions to buttons
hertzhaft
parents: 604
diff changeset
496 // binding mit closure
612
97082d0c0192 'about' window has its own event handler
hertzhaft
parents: 611
diff changeset
497 //(function(){ var action = actionSettings.onclick;
605
959bf7c3d684 bind data and actions to buttons
hertzhaft
parents: 604
diff changeset
498 // $a.bind('click', function(){ console.log( action )} );
959bf7c3d684 bind data and actions to buttons
hertzhaft
parents: 604
diff changeset
499 //})();
611
d332c61da1b0 some refactoring, onclick handlers now work with arguments
hertzhaft
parents: 610
diff changeset
500 $img.attr('src', settings.buttonsImagePath + actionSettings.img);
604
13c8b1ad99d4 work on button creation
robcast
parents: 603
diff changeset
501 };
13c8b1ad99d4 work on button creation
robcast
parents: 603
diff changeset
502 }
605
959bf7c3d684 bind data and actions to buttons
hertzhaft
parents: 604
diff changeset
503 return $buttonsDiv;
603
e92511f4dddc code for generating the buttons
hertzhaft
parents: 602
diff changeset
504 };
608
5de82bb5022d setup bird's eye view div
hertzhaft
parents: 607
diff changeset
505
5de82bb5022d setup bird's eye view div
hertzhaft
parents: 607
diff changeset
506 // creates HTML structure for the bird's eye view in elem
621
7f97716b901c changed methods to pass "data" around instead of "settings"
robcast
parents: 620
diff changeset
507 var setupBirdviewDiv = function (data) {
7f97716b901c changed methods to pass "data" around instead of "settings"
robcast
parents: 620
diff changeset
508 var $elem = data.target;
7f97716b901c changed methods to pass "data" around instead of "settings"
robcast
parents: 620
diff changeset
509 var settings = data.settings;
608
5de82bb5022d setup bird's eye view div
hertzhaft
parents: 607
diff changeset
510 // use only the relevant parameters
5de82bb5022d setup bird's eye view div
hertzhaft
parents: 607
diff changeset
511 var keys = ['fn','pn','dw','dh'];
5de82bb5022d setup bird's eye view div
hertzhaft
parents: 607
diff changeset
512 var birdDimensions = {
5de82bb5022d setup bird's eye view div
hertzhaft
parents: 607
diff changeset
513 'dw' : settings.birdMaxX,
5de82bb5022d setup bird's eye view div
hertzhaft
parents: 607
diff changeset
514 'dh' : settings.birdMaxY
5de82bb5022d setup bird's eye view div
hertzhaft
parents: 607
diff changeset
515 };
5de82bb5022d setup bird's eye view div
hertzhaft
parents: 607
diff changeset
516 var birdSettings = $.extend({}, settings, birdDimensions);
621
7f97716b901c changed methods to pass "data" around instead of "settings"
robcast
parents: 620
diff changeset
517 var birdUrl = settings.scalerBaseUrl + '?' + getParamString(birdSettings, keys);
608
5de82bb5022d setup bird's eye view div
hertzhaft
parents: 607
diff changeset
518 // the bird's eye div
618
8bdc9659ecfa small merge and fix
robcast
parents: 612 613
diff changeset
519 var $birdviewDiv = $('<div class="birdview" style="display:none"/>');
608
5de82bb5022d setup bird's eye view div
hertzhaft
parents: 607
diff changeset
520 // the detail indicator frame
5de82bb5022d setup bird's eye view div
hertzhaft
parents: 607
diff changeset
521 var $birdzoomDiv = $('<div class="birdzoom"/>');
5de82bb5022d setup bird's eye view div
hertzhaft
parents: 607
diff changeset
522 // the small image
5de82bb5022d setup bird's eye view div
hertzhaft
parents: 607
diff changeset
523 var $birdImg = $('<img class="birdimg"/>');
5de82bb5022d setup bird's eye view div
hertzhaft
parents: 607
diff changeset
524 $elem.append($birdviewDiv);
5de82bb5022d setup bird's eye view div
hertzhaft
parents: 607
diff changeset
525 $birdviewDiv.append($birdzoomDiv);
5de82bb5022d setup bird's eye view div
hertzhaft
parents: 607
diff changeset
526 $birdviewDiv.append($birdImg);
5de82bb5022d setup bird's eye view div
hertzhaft
parents: 607
diff changeset
527 $birdImg.attr('src', birdUrl);
5de82bb5022d setup bird's eye view div
hertzhaft
parents: 607
diff changeset
528 };
5de82bb5022d setup bird's eye view div
hertzhaft
parents: 607
diff changeset
529
618
8bdc9659ecfa small merge and fix
robcast
parents: 612 613
diff changeset
530 // creates HTML structure for the about view in elem
621
7f97716b901c changed methods to pass "data" around instead of "settings"
robcast
parents: 620
diff changeset
531 var setupAboutDiv = function (data) {
7f97716b901c changed methods to pass "data" around instead of "settings"
robcast
parents: 620
diff changeset
532 var $elem = data.target;
7f97716b901c changed methods to pass "data" around instead of "settings"
robcast
parents: 620
diff changeset
533 var settings = data.settings;
618
8bdc9659ecfa small merge and fix
robcast
parents: 612 613
diff changeset
534 var $aboutDiv = $('<div class="about" style="display:none"/>');
609
e18dedef32fb setup the 'about' window
hertzhaft
parents: 608
diff changeset
535 var $header = $('<p>Digilib Graphic Viewer</p>');
e18dedef32fb setup the 'about' window
hertzhaft
parents: 608
diff changeset
536 var $link = $('<a/>');
e18dedef32fb setup the 'about' window
hertzhaft
parents: 608
diff changeset
537 var $logo = $('<img class="logo" title="digilib"/>');
e18dedef32fb setup the 'about' window
hertzhaft
parents: 608
diff changeset
538 var $content = $('<p/>');
e18dedef32fb setup the 'about' window
hertzhaft
parents: 608
diff changeset
539 $elem.append($aboutDiv);
e18dedef32fb setup the 'about' window
hertzhaft
parents: 608
diff changeset
540 $aboutDiv.append($header);
e18dedef32fb setup the 'about' window
hertzhaft
parents: 608
diff changeset
541 $aboutDiv.append($link);
e18dedef32fb setup the 'about' window
hertzhaft
parents: 608
diff changeset
542 $aboutDiv.append($content);
e18dedef32fb setup the 'about' window
hertzhaft
parents: 608
diff changeset
543 $link.append($logo);
e18dedef32fb setup the 'about' window
hertzhaft
parents: 608
diff changeset
544 $logo.attr('src', settings.logoUrl);
e18dedef32fb setup the 'about' window
hertzhaft
parents: 608
diff changeset
545 $link.attr('href', settings.reposUrl);
e18dedef32fb setup the 'about' window
hertzhaft
parents: 608
diff changeset
546 $content.text('Version: ' + settings.version);
612
97082d0c0192 'about' window has its own event handler
hertzhaft
parents: 611
diff changeset
547 // let the element know about the digilib context
97082d0c0192 'about' window has its own event handler
hertzhaft
parents: 611
diff changeset
548 $aboutDiv.data('digilib', { 'settings' : settings } );
97082d0c0192 'about' window has its own event handler
hertzhaft
parents: 611
diff changeset
549 $aboutDiv.bind('click', function() {
97082d0c0192 'about' window has its own event handler
hertzhaft
parents: 611
diff changeset
550 console.log($(this));
97082d0c0192 'about' window has its own event handler
hertzhaft
parents: 611
diff changeset
551 $(this).digilib('toggleAboutDiv');
97082d0c0192 'about' window has its own event handler
hertzhaft
parents: 611
diff changeset
552 });
609
e18dedef32fb setup the 'about' window
hertzhaft
parents: 608
diff changeset
553 };
e18dedef32fb setup the 'about' window
hertzhaft
parents: 608
diff changeset
554
606
d08d095430c3 keeping img tag for embedded mode seems to work now
robcast
parents: 605
diff changeset
555 // returns function for load event of scaler img
626
e9493573e5d8 rendering marks works now
robcast
parents: 624
diff changeset
556 var scalerImgLoadedFn = function (data) {
620
b930fa64c684 scalerImgLoaded sets up img trafo
robcast
parents: 619
diff changeset
557 var settings = data.settings;
b930fa64c684 scalerImgLoaded sets up img trafo
robcast
parents: 619
diff changeset
558 var $elem = data.target;
b930fa64c684 scalerImgLoaded sets up img trafo
robcast
parents: 619
diff changeset
559 var $img = data.img;
b930fa64c684 scalerImgLoaded sets up img trafo
robcast
parents: 619
diff changeset
560
626
e9493573e5d8 rendering marks works now
robcast
parents: 624
diff changeset
561 return function () {
620
b930fa64c684 scalerImgLoaded sets up img trafo
robcast
parents: 619
diff changeset
562 console.debug("img loaded! this=", this, " data=", data);
624
6b1b4d269967 more work on initialisation
robcast
parents: 622
diff changeset
563 var area = settings.zoomArea;
620
b930fa64c684 scalerImgLoaded sets up img trafo
robcast
parents: 619
diff changeset
564 // create Transform from current area and picsize
b930fa64c684 scalerImgLoaded sets up img trafo
robcast
parents: 619
diff changeset
565 var picpos = $img.offset();
b930fa64c684 scalerImgLoaded sets up img trafo
robcast
parents: 619
diff changeset
566 var picrect = geom.rectangle(picpos.left, picpos.top, $img.width(), $img.height());
b930fa64c684 scalerImgLoaded sets up img trafo
robcast
parents: 619
diff changeset
567 var trafo = geom.transform();
b930fa64c684 scalerImgLoaded sets up img trafo
robcast
parents: 619
diff changeset
568 // subtract area offset and size
b930fa64c684 scalerImgLoaded sets up img trafo
robcast
parents: 619
diff changeset
569 trafo.concat(trafo.getTranslation(geom.position(area.x, area.y)));
b930fa64c684 scalerImgLoaded sets up img trafo
robcast
parents: 619
diff changeset
570 trafo.concat(trafo.getScale(geom.size(1/area.width, 1/area.height)));
b930fa64c684 scalerImgLoaded sets up img trafo
robcast
parents: 619
diff changeset
571 // scale to screen size
b930fa64c684 scalerImgLoaded sets up img trafo
robcast
parents: 619
diff changeset
572 trafo.concat(trafo.getScale(picrect));
b930fa64c684 scalerImgLoaded sets up img trafo
robcast
parents: 619
diff changeset
573 trafo.concat(trafo.getTranslation(picrect));
b930fa64c684 scalerImgLoaded sets up img trafo
robcast
parents: 619
diff changeset
574 data.imgTrafo = trafo;
b930fa64c684 scalerImgLoaded sets up img trafo
robcast
parents: 619
diff changeset
575 // display marks
626
e9493573e5d8 rendering marks works now
robcast
parents: 624
diff changeset
576 renderMarks(data);
620
b930fa64c684 scalerImgLoaded sets up img trafo
robcast
parents: 619
diff changeset
577 //digilib.showBirdDiv(isBirdDivVisible);
b930fa64c684 scalerImgLoaded sets up img trafo
robcast
parents: 619
diff changeset
578 //digilib.showArrows(); // show arrow overlays for zoom navigation
b930fa64c684 scalerImgLoaded sets up img trafo
robcast
parents: 619
diff changeset
579
606
d08d095430c3 keeping img tag for embedded mode seems to work now
robcast
parents: 605
diff changeset
580 };
d08d095430c3 keeping img tag for embedded mode seems to work now
robcast
parents: 605
diff changeset
581 };
626
e9493573e5d8 rendering marks works now
robcast
parents: 624
diff changeset
582
e9493573e5d8 rendering marks works now
robcast
parents: 624
diff changeset
583 // place marks on the image
e9493573e5d8 rendering marks works now
robcast
parents: 624
diff changeset
584 var renderMarks = function (data) {
e9493573e5d8 rendering marks works now
robcast
parents: 624
diff changeset
585 var $elem = data.target;
e9493573e5d8 rendering marks works now
robcast
parents: 624
diff changeset
586 var marks = data.settings.marks;
e9493573e5d8 rendering marks works now
robcast
parents: 624
diff changeset
587 for (var i = 0; i < marks.length; i++) {
e9493573e5d8 rendering marks works now
robcast
parents: 624
diff changeset
588 var mark = marks[i];
e9493573e5d8 rendering marks works now
robcast
parents: 624
diff changeset
589 if (data.settings.zoomArea.containsPosition(mark)) {
e9493573e5d8 rendering marks works now
robcast
parents: 624
diff changeset
590 var mpos = data.imgTrafo.transform(mark);
e9493573e5d8 rendering marks works now
robcast
parents: 624
diff changeset
591 // create mark
e9493573e5d8 rendering marks works now
robcast
parents: 624
diff changeset
592 var html = '<div class="mark">'+(i+1)+'</div>';
e9493573e5d8 rendering marks works now
robcast
parents: 624
diff changeset
593 var $mark = $(html);
e9493573e5d8 rendering marks works now
robcast
parents: 624
diff changeset
594 $elem.append($mark);
e9493573e5d8 rendering marks works now
robcast
parents: 624
diff changeset
595 $mark.offset({ left : mpos.x, top : mpos.y});
e9493573e5d8 rendering marks works now
robcast
parents: 624
diff changeset
596 }
e9493573e5d8 rendering marks works now
robcast
parents: 624
diff changeset
597 }
e9493573e5d8 rendering marks works now
robcast
parents: 624
diff changeset
598 };
624
6b1b4d269967 more work on initialisation
robcast
parents: 622
diff changeset
599
6b1b4d269967 more work on initialisation
robcast
parents: 622
diff changeset
600 // auxiliary function to crop senseless precision
6b1b4d269967 more work on initialisation
robcast
parents: 622
diff changeset
601 var cropFloat = function (x) {
6b1b4d269967 more work on initialisation
robcast
parents: 622
diff changeset
602 return parseInt(10000 * x) / 10000;
6b1b4d269967 more work on initialisation
robcast
parents: 622
diff changeset
603 };
6b1b4d269967 more work on initialisation
robcast
parents: 622
diff changeset
604
598
81723e7efe82 next version zero of jquery.digilib
robcast
parents: 597
diff changeset
605 // hook plugin into jquery
81723e7efe82 next version zero of jquery.digilib
robcast
parents: 597
diff changeset
606 $.fn.digilib = function(method) {
81723e7efe82 next version zero of jquery.digilib
robcast
parents: 597
diff changeset
607 if (methods[method]) {
81723e7efe82 next version zero of jquery.digilib
robcast
parents: 597
diff changeset
608 return methods[method].apply(this, Array.prototype.slice.call(arguments, 1));
81723e7efe82 next version zero of jquery.digilib
robcast
parents: 597
diff changeset
609 } else if (typeof(method) === 'object' || !method) {
81723e7efe82 next version zero of jquery.digilib
robcast
parents: 597
diff changeset
610 return methods.init.apply(this, arguments);
81723e7efe82 next version zero of jquery.digilib
robcast
parents: 597
diff changeset
611 } else {
81723e7efe82 next version zero of jquery.digilib
robcast
parents: 597
diff changeset
612 $.error( 'Method ' + method + ' does not exist on jQuery.digilib' );
81723e7efe82 next version zero of jquery.digilib
robcast
parents: 597
diff changeset
613 }
81723e7efe82 next version zero of jquery.digilib
robcast
parents: 597
diff changeset
614 };
597
33605dd3e9c6 version zero of jquery.digilib
robcast
parents:
diff changeset
615
33605dd3e9c6 version zero of jquery.digilib
robcast
parents:
diff changeset
616 })(jQuery);