annotate client/digitallibrary/dllib.js @ 332:d14782908c37

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