annotate client/digitallibrary/dllib.js @ 313:152ad1e1ca27

big autumn cleaning :-) - finally digilib.jsp uses the new javascript code - dito digicat.jsp - all files corresponding to the old frontend moved into /oldskin - all icons moved into /img
author robcast
date Thu, 28 Oct 2004 22:25:59 +0200
parents 2f4764230089
children e83a18520279
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
239
2f4764230089 new digimage with red triangles for moving the zoomed area
robcast
parents: 235
diff changeset
1 /* Copyright (C) 2003,2004 IT-Group MPIWG, WTWG Uni Bern and others
233
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
2
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
3 This program is free software; you can redistribute it and/or
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
4 modify it under the terms of the GNU General Public License
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
5 as published by the Free Software Foundation; either version 2
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
6 of the License, or (at your option) any later version.
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
7
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
8 This program is distributed in the hope that it will be useful,
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
9 but WITHOUT ANY WARRANTY; without even the implied warranty of
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
10 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
11 GNU General Public License for more details.
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
12
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
13 You should have received a copy of the GNU General Public License
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
14 along with this program; if not, write to the Free Software
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
15 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
16
239
2f4764230089 new digimage with red triangles for moving the zoomed area
robcast
parents: 235
diff changeset
17 Authors:
2f4764230089 new digimage with red triangles for moving the zoomed area
robcast
parents: 235
diff changeset
18 Christian Luginbuehl, 01.05.2003 (first version)
2f4764230089 new digimage with red triangles for moving the zoomed area
robcast
parents: 235
diff changeset
19 DW 24.03.2004 (Changed for digiLib in Zope)
313
152ad1e1ca27 big autumn cleaning :-)
robcast
parents: 239
diff changeset
20 Robert Casties, 27.10.2004
233
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
21
239
2f4764230089 new digimage with red triangles for moving the zoomed area
robcast
parents: 235
diff changeset
22 ! Requires baselib.js !
233
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
23
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
24 */
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
25
313
152ad1e1ca27 big autumn cleaning :-)
robcast
parents: 239
diff changeset
26 var dlScriptVersion = "1.0b4";
152ad1e1ca27 big autumn cleaning :-)
robcast
parents: 239
diff changeset
27
152ad1e1ca27 big autumn cleaning :-)
robcast
parents: 239
diff changeset
28
152ad1e1ca27 big autumn cleaning :-)
robcast
parents: 239
diff changeset
29 function identify() {
152ad1e1ca27 big autumn cleaning :-)
robcast
parents: 239
diff changeset
30 // used for identifying a digilib instance
152ad1e1ca27 big autumn cleaning :-)
robcast
parents: 239
diff changeset
31 // Relato uses that function - lugi
152ad1e1ca27 big autumn cleaning :-)
robcast
parents: 239
diff changeset
32 return "Digilib 0.6";
152ad1e1ca27 big autumn cleaning :-)
robcast
parents: 239
diff changeset
33 }
152ad1e1ca27 big autumn cleaning :-)
robcast
parents: 239
diff changeset
34
233
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
35
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
36 /*
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
37 * more parameter handling
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
38 */
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
39
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
40 var dlArea = new Rectangle(0.0, 0.0, 1.0, 1.0);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
41 var dlMaxArea = new Rectangle(0.0, 0.0, 1.0, 1.0);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
42
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
43 function parseArea() {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
44 // returns area Rectangle from current parameters
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
45 return new Rectangle(getParameter("wx"), getParameter("wy"), getParameter("ww"), getParameter("wh"));
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
46 }
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
47
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
48 function setParamFromArea(rect) {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
49 // sets digilib wx etc. from rect
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
50 setParameter("wx", cropFloat(rect.x));
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
51 setParameter("wy", cropFloat(rect.y));
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
52 setParameter("ww", cropFloat(rect.width));
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
53 setParameter("wh", cropFloat(rect.height));
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
54 return true;
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
55 }
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
56
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
57 var dlTrafo = new Transform();
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
58
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
59 function parseTrafo(elem) {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
60 // returns Transform from current dlArea and picsize
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
61 var picsize = getElementRect(elem);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
62 var trafo = new Transform();
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
63 // subtract area offset and size
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
64 trafo.concat(getTranslation(new Position(-dlArea.x, -dlArea.y)));
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
65 trafo.concat(getScale(new Size(1/dlArea.width, 1/dlArea.height)));
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
66 // scale to screen size
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
67 trafo.concat(getScale(picsize));
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
68 trafo.concat(getTranslation(picsize));
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
69 // rotate
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
70 //trafo.concat(getRotation(- getParameter("rot"), new Position(0.5*picsize.width, 0.5*picsize.height)));
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
71 // mirror
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
72 //if (hasFlag("hmir")) {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
73 //trafo.m00 = - trafo.m00;
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
74 //}
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
75 //if (hasFlag("vmir")) {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
76 //trafo.m11 = - trafo.m11;
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
77 //}
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
78 return trafo;
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
79 }
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
80
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
81
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
82 var dlMarks = new Array();
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
83
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
84 function parseMarks() {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
85 // returns marks array from current parameters
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
86 var marks = new Array();
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
87 var ma;
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
88 var mk = getParameter("mk");
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
89 if (mk.indexOf(";") >= 0) {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
90 // old format with ";"
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
91 ma = mk.split(";");
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
92 } else {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
93 ma = mk.split(",");
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
94 }
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
95 for (var i = 0; i < ma.length ; i++) {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
96 var pos = ma[i].split("/");
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
97 if (pos.length > 1) {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
98 marks.push(new Position(pos[0], pos[1]));
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
99 }
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
100 }
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
101 return marks;
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
102 }
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
103
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
104 function getAllMarks() {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
105 // returns a string with all marks in query format
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
106 var marks = new Array();
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
107 for (var i = 0; i < dlMarks.length; i++) {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
108 marks.push(cropFloat(dlMarks[i].x) + "/" + cropFloat(dlMarks[i].y));
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
109 }
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
110 return marks.join(",");
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
111 }
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
112
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
113 function addMark(pos) {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
114 // add a mark
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
115 dlMarks.push(pos);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
116 setParameter("mk", getAllMarks());
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
117 return true;
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
118 }
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
119
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
120 function deleteMark() {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
121 // delete the last mark
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
122 dlMarks.pop();
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
123 setParameter("mk", getAllMarks());
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
124 return true;
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
125 }
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
126
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
127 var dlFlags = new Object();
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
128
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
129 function hasFlag(mode) {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
130 // returns if mode flag is set
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
131 return (dlFlags[mode]);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
132 }
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
133
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
134 function addFlag(mode) {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
135 // add a mode flag
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
136 dlFlags[mode] = mode;
235
37a7267bd2c7 new version with false setMark ;-)
robcast
parents: 234
diff changeset
137 setParameter("mo", getAllFlags());
233
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
138 return true;
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
139 }
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
140
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
141 function removeFlag(mode) {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
142 // remove a mode flag
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
143 if (dlFlags[mode]) {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
144 delete dlFlags[mode];
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
145 }
235
37a7267bd2c7 new version with false setMark ;-)
robcast
parents: 234
diff changeset
146 setParameter("mo", getAllFlags());
233
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
147 return true;
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
148 }
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
149
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
150 function toggleFlag(mode) {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
151 // change a mode flag
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
152 if (dlFlags[mode]) {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
153 delete dlFlags[mode];
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
154 } else {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
155 dlFlags[mode] = mode;
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
156 }
235
37a7267bd2c7 new version with false setMark ;-)
robcast
parents: 234
diff changeset
157 setParameter("mo", getAllFlags());
233
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
158 return true;
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
159 }
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
160
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
161 function getAllFlags() {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
162 // returns a string with all flags in query format
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
163 var fa = new Array();
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
164 for (var f in dlFlags) {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
165 if ((f != "")&&(dlFlags[f] != null)) {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
166 fa.push(f);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
167 }
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
168 }
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
169 return fa.join(",");
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
170 }
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
171
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
172 function parseFlags() {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
173 // sets dlFlags from the current parameters
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
174 var flags = new Object();
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
175 var fa = getParameter("mo").split(",");
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
176 for (var i = 0; i < fa.length ; i++) {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
177 var f = fa[i];
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
178 if (f != "") {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
179 flags[f] = f;
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
180 }
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
181 }
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
182 return flags;
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
183 }
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
184
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
185
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
186 function bestPicSize(elem, inset) {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
187 // returns a Size with the best image size for the given element
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
188 if (! defined(inset)) {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
189 inset = 25;
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
190 }
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
191 var ws = getWinSize();
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
192 var es = getElementPosition(elem);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
193 if (es) {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
194 ws.width = ws.width - es.x - inset;
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
195 ws.height = ws.height - es.y - inset;
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
196 }
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
197 return ws;
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
198 }
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
199
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
200
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
201 /* **********************************************
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
202 * digilib specific routines
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
203 * ******************************************** */
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
204
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
205 var elemScaler = null;
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
206 var picElem = null;
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
207
234
fd9b841cb976 initial parameter parsing now earlier
robcast
parents: 233
diff changeset
208
fd9b841cb976 initial parameter parsing now earlier
robcast
parents: 233
diff changeset
209 function dl_param_init() {
fd9b841cb976 initial parameter parsing now earlier
robcast
parents: 233
diff changeset
210 // parameter initialisation before onload
fd9b841cb976 initial parameter parsing now earlier
robcast
parents: 233
diff changeset
211
fd9b841cb976 initial parameter parsing now earlier
robcast
parents: 233
diff changeset
212 // put the query parameters (sans "?") in the parameters array
fd9b841cb976 initial parameter parsing now earlier
robcast
parents: 233
diff changeset
213 parseParameters(location.search.slice(1));
fd9b841cb976 initial parameter parsing now earlier
robcast
parents: 233
diff changeset
214 // treat special parameters
fd9b841cb976 initial parameter parsing now earlier
robcast
parents: 233
diff changeset
215 dlMarks = parseMarks();
fd9b841cb976 initial parameter parsing now earlier
robcast
parents: 233
diff changeset
216 dlArea = parseArea();
fd9b841cb976 initial parameter parsing now earlier
robcast
parents: 233
diff changeset
217 dlFlags = parseFlags();
fd9b841cb976 initial parameter parsing now earlier
robcast
parents: 233
diff changeset
218 }
fd9b841cb976 initial parameter parsing now earlier
robcast
parents: 233
diff changeset
219
fd9b841cb976 initial parameter parsing now earlier
robcast
parents: 233
diff changeset
220
233
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
221 function dl_init() {
234
fd9b841cb976 initial parameter parsing now earlier
robcast
parents: 233
diff changeset
222 // initalisation on load
233
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
223 elemScaler = getElement("scaler", true);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
224 picElem = getElement("pic", true);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
225 if (picElem == null && elemScaler) {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
226 // in N4 pic is in the scaler layer
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
227 picElem = elemScaler.document.images[0];
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
228 }
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
229 if ((!elemScaler)||(!picElem)) {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
230 alert("Sorry, zogilib doesn't work here!");
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
231 return false;
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
232 }
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
233 // give a name to the window containing digilib
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
234 if (defined(dlTarget)&&(dlTarget)) {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
235 window.name = dlTarget;
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
236 } else {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
237 window.name = "digilib";
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
238 }
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
239 // put the query parameters (sans "?") in the parameters array
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
240 parseParameters(location.search.slice(1));
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
241 // treat special parameters
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
242 dlMarks = parseMarks();
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
243 dlArea = parseArea();
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
244 dlFlags = parseFlags();
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
245 // wait for image to load and display marks
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
246 renderMarks();
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
247 // done
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
248 focus();
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
249 return;
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
250 }
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
251
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
252
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
253 function display(detail) {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
254 // redisplay the page
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
255 if (! detail) {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
256 detail = 9;
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
257 }
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
258 var queryString = getAllParameters(detail);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
259 location.href = location.protocol + "//" + location.host + location.pathname + "?" + queryString;
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
260 }
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
261
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
262
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
263 /* **********************************************
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
264 * interactive digilib functions
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
265 * ******************************************** */
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
266
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
267
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
268 function renderMarks() {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
269 // put the visible marks on the image
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
270 var mark_count = dlMarks.length;
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
271 // make shure the image is loaded so we know its size
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
272 if (defined(picElem.complete) && picElem.complete == false && ! browserType.isN4 ) {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
273 setTimeout("renderMarks()", 100);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
274 } else {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
275 dlTrafo = parseTrafo(picElem);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
276 for (var i = 0; i < 8; i++) {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
277 var me = getElement("dot"+i);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
278 if (i < mark_count) {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
279 if (dlArea.containsPosition(dlMarks[i])) {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
280 var mpos = dlTrafo.transform(dlMarks[i]);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
281 // suboptimal to place -5 pixels and not half size of mark-image
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
282 mpos.x = mpos.x -5;
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
283 mpos.y = mpos.y -5;
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
284 moveElement(me, mpos);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
285 showElement(me, true);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
286 }
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
287 } else {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
288 // hide the other marks
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
289 showElement(me, false);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
290 }
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
291 }
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
292 }
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
293 }
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
294
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
295
235
37a7267bd2c7 new version with false setMark ;-)
robcast
parents: 234
diff changeset
296 function setMark(reload) {
233
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
297 // add a mark where clicked
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
298 if ( dlMarks.length > 7 ) {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
299 alert("Only 8 marks are possible at the moment!");
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
300 return;
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
301 }
313
152ad1e1ca27 big autumn cleaning :-)
robcast
parents: 239
diff changeset
302 window.focus();
233
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
303
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
304 function markEvent(evt) {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
305 // event handler adding a new mark
239
2f4764230089 new digimage with red triangles for moving the zoomed area
robcast
parents: 235
diff changeset
306 unregisterEvent("mousedown", elemScaler, markEvent);
233
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
307 var p = dlTrafo.invtransform(evtPosition(evt));
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
308 addMark(p);
235
37a7267bd2c7 new version with false setMark ;-)
robcast
parents: 234
diff changeset
309 if (defined(reload)&&(!reload)) {
37a7267bd2c7 new version with false setMark ;-)
robcast
parents: 234
diff changeset
310 // don't redisplay
37a7267bd2c7 new version with false setMark ;-)
robcast
parents: 234
diff changeset
311 renderMarks();
37a7267bd2c7 new version with false setMark ;-)
robcast
parents: 234
diff changeset
312 return;
37a7267bd2c7 new version with false setMark ;-)
robcast
parents: 234
diff changeset
313 }
233
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
314 display();
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
315 }
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
316
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
317 // starting event capture
239
2f4764230089 new digimage with red triangles for moving the zoomed area
robcast
parents: 235
diff changeset
318 registerEvent("mousedown", elemScaler, markEvent);
233
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
319 }
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
320
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
321
235
37a7267bd2c7 new version with false setMark ;-)
robcast
parents: 234
diff changeset
322 function removeMark(reload) {
37a7267bd2c7 new version with false setMark ;-)
robcast
parents: 234
diff changeset
323 // remove the last mark
37a7267bd2c7 new version with false setMark ;-)
robcast
parents: 234
diff changeset
324 deleteMark();
37a7267bd2c7 new version with false setMark ;-)
robcast
parents: 234
diff changeset
325 if (defined(reload)&&(!reload)) {
37a7267bd2c7 new version with false setMark ;-)
robcast
parents: 234
diff changeset
326 // don't redisplay
37a7267bd2c7 new version with false setMark ;-)
robcast
parents: 234
diff changeset
327 renderMarks();
37a7267bd2c7 new version with false setMark ;-)
robcast
parents: 234
diff changeset
328 return;
37a7267bd2c7 new version with false setMark ;-)
robcast
parents: 234
diff changeset
329 }
37a7267bd2c7 new version with false setMark ;-)
robcast
parents: 234
diff changeset
330 display();
37a7267bd2c7 new version with false setMark ;-)
robcast
parents: 234
diff changeset
331 }
37a7267bd2c7 new version with false setMark ;-)
robcast
parents: 234
diff changeset
332
37a7267bd2c7 new version with false setMark ;-)
robcast
parents: 234
diff changeset
333
233
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
334 function zoomArea() {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
335 var click = 1;
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
336 var pt1, pt2;
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
337 var eck1pos, eck2pos, eck3pos, eck4pos;
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
338 window.focus();
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
339 var eck1 = getElement("eck1");
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
340 var eck2 = getElement("eck2");
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
341 var eck3 = getElement("eck3");
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
342 var eck4 = getElement("eck4");
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
343
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
344 function zoomClick(evt) {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
345 // mouse click handler
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
346 if (click == 1) {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
347 // first click -- start moving
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
348 click = 2;
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
349 pt1 = evtPosition(evt);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
350 pt2 = pt1;
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
351 eck1pos = pt1;
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
352 eck2pos = new Position(pt1.x - 12, pt1.y);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
353 eck3pos = new Position(pt1.x, pt1.y - 12);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
354 eck4pos = new Position(pt1.y - 12, pt1.y - 12);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
355 moveElement(eck1, eck1pos);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
356 moveElement(eck2, eck2pos);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
357 moveElement(eck3, eck3pos);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
358 moveElement(eck4, eck4pos);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
359 showElement(eck1, true);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
360 showElement(eck2, true);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
361 showElement(eck3, true);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
362 showElement(eck4, true);
239
2f4764230089 new digimage with red triangles for moving the zoomed area
robcast
parents: 235
diff changeset
363 // show moving
2f4764230089 new digimage with red triangles for moving the zoomed area
robcast
parents: 235
diff changeset
364 registerEvent("mousemove", elemScaler, zoomMove);
2f4764230089 new digimage with red triangles for moving the zoomed area
robcast
parents: 235
diff changeset
365 registerEvent("mousemove", eck4, zoomMove);
2f4764230089 new digimage with red triangles for moving the zoomed area
robcast
parents: 235
diff changeset
366 // enable drag-to-zoom
2f4764230089 new digimage with red triangles for moving the zoomed area
robcast
parents: 235
diff changeset
367 registerEvent("mouseup", elemScaler, zoomClick);
2f4764230089 new digimage with red triangles for moving the zoomed area
robcast
parents: 235
diff changeset
368 registerEvent("mouseup", eck4, zoomClick);
233
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
369 } else {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
370 // second click -- end moving
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
371 pt2 = evtPosition(evt);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
372 showElement(eck1, false);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
373 showElement(eck2, false);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
374 showElement(eck3, false);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
375 showElement(eck4, false);
239
2f4764230089 new digimage with red triangles for moving the zoomed area
robcast
parents: 235
diff changeset
376 unregisterEvent("mousemove", elemScaler, zoomMove);
2f4764230089 new digimage with red triangles for moving the zoomed area
robcast
parents: 235
diff changeset
377 unregisterEvent("mousemove", eck4, zoomMove);
2f4764230089 new digimage with red triangles for moving the zoomed area
robcast
parents: 235
diff changeset
378 unregisterEvent("mousedown", elemScaler, zoomClick);
2f4764230089 new digimage with red triangles for moving the zoomed area
robcast
parents: 235
diff changeset
379 unregisterEvent("mousedown", eck4, zoomClick);
233
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
380 var p1 = dlTrafo.invtransform(pt1);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
381 var p2 = dlTrafo.invtransform(pt2);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
382 var ww = p2.x-p1.x;
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
383 var wh = p2.y-p1.y;
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
384 if ((ww > 0)&&(wh > 0)) {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
385 setParameter("wx", cropFloat(p1.x));
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
386 setParameter("wy", cropFloat(p1.y));
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
387 setParameter("ww", cropFloat(ww));
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
388 setParameter("wh", cropFloat(wh));
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
389 parseArea();
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
390 // zoomed is always fit
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
391 setParameter("ws", 1);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
392 display();
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
393 }
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
394 }
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
395 }
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
396
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
397 function zoomMove(evt) {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
398 // mouse move handler
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
399 pt2 = evtPosition(evt);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
400 // restrict marks to move right and down
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
401 eck1pos = pt1;
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
402 eck2pos = new Position(Math.max(pt1.x, pt2.x)-12, pt1.y);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
403 eck3pos = new Position(pt1.x, Math.max(pt1.y, pt2.y)-12);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
404 eck4pos = new Position(Math.max(pt1.x, pt2.x)-12, Math.max(pt1.y, pt2.y)-12);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
405 moveElement(eck1, eck1pos);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
406 moveElement(eck2, eck2pos);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
407 moveElement(eck3, eck3pos);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
408 moveElement(eck4, eck4pos);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
409 }
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
410
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
411 // starting event capture
239
2f4764230089 new digimage with red triangles for moving the zoomed area
robcast
parents: 235
diff changeset
412 registerEvent("mousedown", elemScaler, zoomClick);
2f4764230089 new digimage with red triangles for moving the zoomed area
robcast
parents: 235
diff changeset
413 registerEvent("mousedown", eck4, zoomClick);
233
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
414 }
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
415
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
416 var ZOOMFACTOR = Math.sqrt(2);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
417
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
418 function zoomBy(factor) {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
419 // zooms by the given factor
235
37a7267bd2c7 new version with false setMark ;-)
robcast
parents: 234
diff changeset
420 var newarea = dlArea.copy();
233
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
421 newarea.width /= factor;
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
422 newarea.height /= factor;
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
423 newarea.x -= 0.5 * (newarea.width - dlArea.width);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
424 newarea.y -= 0.5 * (newarea.height - dlArea.height);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
425 newarea = dlMaxArea.fit(newarea);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
426 setParamFromArea(newarea);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
427 display();
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
428 }
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
429
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
430
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
431 function zoomFullpage() {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
432 // zooms out to show the whole image
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
433 setParameter("wx", 0.0);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
434 setParameter("wy", 0.0);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
435 setParameter("ww", 1.0);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
436 setParameter("wh", 1.0);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
437 display();
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
438 }
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
439
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
440
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
441 function moveCenter() {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
442 // move visible area so that it's centered around the clicked point
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
443 if ( (dlArea.width == 1.0) && (dlArea.height == 1.0) ) {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
444 // noting to do
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
445 return;
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
446 }
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
447 window.focus();
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
448
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
449 function moveCenterEvent(evt) {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
450 // move to handler
239
2f4764230089 new digimage with red triangles for moving the zoomed area
robcast
parents: 235
diff changeset
451 unregisterEvent("mousedown", elemScaler, moveCenterEvent);
233
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
452 var pt = dlTrafo.invtransform(evtPosition(evt));
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
453 var newarea = new Rectangle(pt.x-0.5*dlArea.width, pt.y-0.5*dlArea.height, dlArea.width, dlArea.height);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
454 newarea = dlMaxArea.fit(newarea);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
455 // set parameters
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
456 setParamFromArea(newarea);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
457 parseArea();
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
458 display();
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
459 }
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
460
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
461 // starting event capture
239
2f4764230089 new digimage with red triangles for moving the zoomed area
robcast
parents: 235
diff changeset
462 registerEvent("mousedown", elemScaler, moveCenterEvent);
233
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
463 }
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
464
239
2f4764230089 new digimage with red triangles for moving the zoomed area
robcast
parents: 235
diff changeset
465 function moveBy(movx, movy) {
2f4764230089 new digimage with red triangles for moving the zoomed area
robcast
parents: 235
diff changeset
466 // move visible area by movx and movy (in units of dw, dh)
2f4764230089 new digimage with red triangles for moving the zoomed area
robcast
parents: 235
diff changeset
467 if ((dlArea.width == 1.0)&&(dlArea.height == 1.0)) {
2f4764230089 new digimage with red triangles for moving the zoomed area
robcast
parents: 235
diff changeset
468 // nothing to do
2f4764230089 new digimage with red triangles for moving the zoomed area
robcast
parents: 235
diff changeset
469 return;
2f4764230089 new digimage with red triangles for moving the zoomed area
robcast
parents: 235
diff changeset
470 }
2f4764230089 new digimage with red triangles for moving the zoomed area
robcast
parents: 235
diff changeset
471 var newarea = dlArea.copy();
2f4764230089 new digimage with red triangles for moving the zoomed area
robcast
parents: 235
diff changeset
472 newarea.x += parseFloat(movx)*dlArea.width;
2f4764230089 new digimage with red triangles for moving the zoomed area
robcast
parents: 235
diff changeset
473 newarea.y += parseFloat(movy)*dlArea.height;
2f4764230089 new digimage with red triangles for moving the zoomed area
robcast
parents: 235
diff changeset
474 newarea = dlMaxArea.fit(newarea);
2f4764230089 new digimage with red triangles for moving the zoomed area
robcast
parents: 235
diff changeset
475 // set parameters
2f4764230089 new digimage with red triangles for moving the zoomed area
robcast
parents: 235
diff changeset
476 setParamFromArea(newarea);
2f4764230089 new digimage with red triangles for moving the zoomed area
robcast
parents: 235
diff changeset
477 parseArea();
2f4764230089 new digimage with red triangles for moving the zoomed area
robcast
parents: 235
diff changeset
478 display();
2f4764230089 new digimage with red triangles for moving the zoomed area
robcast
parents: 235
diff changeset
479 }
2f4764230089 new digimage with red triangles for moving the zoomed area
robcast
parents: 235
diff changeset
480
2f4764230089 new digimage with red triangles for moving the zoomed area
robcast
parents: 235
diff changeset
481
233
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
482
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
483
234
fd9b841cb976 initial parameter parsing now earlier
robcast
parents: 233
diff changeset
484 function getRef() {
233
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
485 // returns a reference to the current digilib set
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
486 if (! baseUrl) {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
487 var baseUrl = location.protocol + "//" + location.host + location.pathname;
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
488 }
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
489 var hyperlinkRef = baseUrl;
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
490 var par = getAllParameters(9);
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
491 if (par.length > 0) {
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
492 hyperlinkRef += "?" + par;
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
493 }
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
494 return hyperlinkRef;
2ef02ca79079 new javascript code for digilib
robcast
parents:
diff changeset
495 }
313
152ad1e1ca27 big autumn cleaning :-)
robcast
parents: 239
diff changeset
496
152ad1e1ca27 big autumn cleaning :-)
robcast
parents: 239
diff changeset
497 function getRefWin(type, msg) {
152ad1e1ca27 big autumn cleaning :-)
robcast
parents: 239
diff changeset
498 // shows an alert with a reference to the current digilib set
152ad1e1ca27 big autumn cleaning :-)
robcast
parents: 239
diff changeset
499 if (! msg) {
152ad1e1ca27 big autumn cleaning :-)
robcast
parents: 239
diff changeset
500 msg = "Link for HTML documents";
152ad1e1ca27 big autumn cleaning :-)
robcast
parents: 239
diff changeset
501 }
152ad1e1ca27 big autumn cleaning :-)
robcast
parents: 239
diff changeset
502 prompt(msg, getRef());
152ad1e1ca27 big autumn cleaning :-)
robcast
parents: 239
diff changeset
503 }