annotate client/digitallibrary/jquery/jquery.digilib.js @ 634:3223fabd53bc jquery

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