annotate client/digitallibrary/baselib.js @ 280:eae751165555

Servlet version 1.22b1 - more fast searching (hopefully all working now) - some simple synchronisation - some reshuffling of methods to eliminate cruft
author robcast
date Fri, 15 Oct 2004 16:59:47 +0200
parents 4caec1a85233
children d7f0045384f5
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
242
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
1 /* Copyright (C) 2003,2004 IT-Group MPIWG, WTWG Uni Bern and others
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
2
237
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
242
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
17 Authors:
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
18 Christian Luginbuehl, 01.05.2003 (first version)
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
19 DW 24.03.2004 (Changed for digiLib in Zope)
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
20 Robert Casties, 03.08.2004
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
21
237
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
22 */
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
23
249
4caec1a85233 added identify function to make relato work again
luginbue
parents: 242
diff changeset
24 function identify() {
4caec1a85233 added identify function to make relato work again
luginbue
parents: 242
diff changeset
25 // used for identifying a digilib instance
4caec1a85233 added identify function to make relato work again
luginbue
parents: 242
diff changeset
26 // Relato uses that function - lugi
4caec1a85233 added identify function to make relato work again
luginbue
parents: 242
diff changeset
27 return "Digilib 0.6";
4caec1a85233 added identify function to make relato work again
luginbue
parents: 242
diff changeset
28 }
4caec1a85233 added identify function to make relato work again
luginbue
parents: 242
diff changeset
29
241
bc30dea2bb2e *** empty log message ***
robcast
parents: 237
diff changeset
30 function getInt(n) {
237
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
31 // returns always an integer
241
bc30dea2bb2e *** empty log message ***
robcast
parents: 237
diff changeset
32 n = parseInt(n);
bc30dea2bb2e *** empty log message ***
robcast
parents: 237
diff changeset
33 if (isNaN(n)) return 0;
237
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
34 return n;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
35 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
36
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
37 function defined(x) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
38 // returns if x is defined
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
39 return (typeof arguments[0] != "undefined");
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
40 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
41
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
42 // auxiliary function to crop senseless precision
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
43 function cropFloat(x) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
44 return parseInt(10000*x)/10000;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
45 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
46
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
47 // browser sniffer
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
48 var browserType = Object();
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
49 browserType.doDHTML = false;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
50 browserType.versIE = 0;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
51
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
52 if ((! document.cssonly && document.layers) || document.all || document.getElementById) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
53 var vers = navigator.appVersion.split('MSIE ');
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
54 vers = vers[vers.length - 1];
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
55 browserType.versIE = getInt(vers);
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
56 browserType.isIE = navigator.userAgent.indexOf('MSIE') >= 0;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
57 browserType.isMac = navigator.platform.indexOf('Mac') >= 0;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
58 browserType.isWin = navigator.platform.indexOf('Win') >= 0;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
59 browserType.isN4 = (navigator.userAgent.indexOf('Mozilla/4.') >= 0) && ! browserType.isIE;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
60 browserType.isIEWin = browserType.versIE > 0 && browserType.isWin;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
61 if (navigator.appVersion.indexOf('MSIE') < 0 || ! browserType.isMac || browserType.versIE >= 5) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
62 browserType.doDHTML = true;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
63 browserType.isOpera = navigator.userAgent.indexOf(' Opera ') >= 0;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
64 browserType.isKonq = navigator.userAgent.indexOf(' Konqueror') >= 0;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
65 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
66 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
67
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
68 // fixes for javascript < 1.2
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
69 if (! Array.prototype.push) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
70 Array.prototype.push = function(val) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
71 this[this.length] = val;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
72 return this.length;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
73 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
74 Array.prototype.pop = function() {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
75 var val = this[this.length-1];
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
76 this.length -= 1;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
77 return val;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
78 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
79 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
80
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
81
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
82 /* **********************************************
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
83 * geometry classes
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
84 * ******************************************** */
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
85
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
86 /*
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
87 * Size class
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
88 */
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
89 function Size(w, h) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
90 this.width = parseFloat(w);
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
91 this.height = parseFloat(h);
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
92 return this;
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 /*
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
96 * Position class
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
97 */
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
98 function Position(x, y) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
99 this.x = parseFloat(x);
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
100 this.y = parseFloat(y);
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
101 return this;
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 /*
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
105 * Rectangle class
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
106 */
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
107 function Rectangle(x, y, w, h) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
108 this.x = parseFloat(x);
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
109 this.y = parseFloat(y);
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
110 this.width = parseFloat(w);
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
111 this.height = parseFloat(h);
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
112 return this;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
113 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
114 Rectangle.prototype.copy = function() {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
115 // returns a copy of this Rectangle
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
116 return new Rectangle(this.x, this.y, this.width, this.height);
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
117 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
118 Rectangle.prototype.getPosition = function() {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
119 // returns the position of this Rectangle
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
120 return new Position(this.x, this.y);
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
121 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
122 Rectangle.prototype.getSize = function() {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
123 // returns the size of this Rectangle
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
124 return new Size(this.width, this.height);
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
125 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
126 Rectangle.prototype.getArea = function() {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
127 // returns the area of this Rectangle
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
128 return (this.width * this.height);
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
129 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
130 Rectangle.prototype.containsPosition = function(pos) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
131 // returns if the given Position lies in this Rectangle
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
132 return ((pos.x >= this.x)&&(pos.y >= this.y)&&(pos.x <= this.x+this.width)&&(pos.y <= this.y+this.width));
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
133 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
134 Rectangle.prototype.intersect = function(rect) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
135 // returns the intersection of the given Rectangle and this one
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
136 var sec = rect.copy();
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
137 if (sec.x < this.x) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
138 sec.width = sec.width - (this.x - sec.x);
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
139 sec.x = this.x;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
140 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
141 if (sec.y < this.y) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
142 sec.height = sec.height - (this.y - sec.y);
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
143 sec.y = this.y;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
144 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
145 if (sec.x + sec.width > this.x + this.width) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
146 sec.width = (this.x + this.width) - sec.x;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
147 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
148 if (sec.y + sec.height > this.y + this.height) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
149 sec.height = (this.y + this.height) - sec.y;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
150 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
151 return sec;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
152 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
153 Rectangle.prototype.fit = function(rect) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
154 // returns a Rectangle that fits into this one (by moving first)
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
155 var sec = rect.copy();
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
156 sec.x = Math.max(sec.x, this.x);
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
157 sec.x = Math.max(sec.x, this.x);
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
158 if (sec.x + sec.width > this.x + this.width) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
159 sec.x = this.x + this.width - sec.width;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
160 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
161 if (sec.y + sec.height > this.y + this.height) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
162 sec.y = this.y + this.height - sec.height;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
163 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
164 return sec.intersect(this);
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
165 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
166
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
167 /*
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
168 * Transform class
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
169 *
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
170 * defines a class of affine transformations
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
171 */
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
172 function Transform() {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
173 this.m00 = 1.0;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
174 this.m01 = 0.0;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
175 this.m02 = 0.0;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
176 this.m10 = 0.0;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
177 this.m11 = 1.0;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
178 this.m12 = 0.0;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
179 this.m20 = 0.0;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
180 this.m21 = 0.0;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
181 this.m22 = 1.0;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
182 return this;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
183 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
184 Transform.prototype.concat = function(traf) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
185 // add Transform traf to this Transform
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
186 for (var i = 0; i < 3; i++) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
187 for (var j = 0; j < 3; j++) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
188 var c = 0.0;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
189 for (var k = 0; k < 3; k++) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
190 c += traf["m"+i+k] * this["m"+k+j];
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
191 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
192 this["m"+i+j] = c;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
193 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
194 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
195 return this;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
196 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
197 Transform.prototype.transform = function(rect) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
198 // returns transformed Rectangle or Position with this Transform applied
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
199 var x = this.m00 * rect.x + this.m01 * rect.y + this.m02;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
200 var y = this.m10 * rect.x + this.m11 * rect.y + this.m12;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
201 if (rect.width) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
202 var width = this.m00 * rect.width + this.m01 * rect.height;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
203 var height = this.m10 * rect.width + this.m11 * rect.height;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
204 return new Rectangle(x, y, width, height);
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
205 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
206 return new Position(x, y);
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
207 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
208 Transform.prototype.invtransform = function(pos) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
209 // returns transformed Position pos with the inverse of this Transform applied
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
210 var det = this.m00 * this.m11 - this.m01 * this.m10;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
211 var x = (this.m11 * pos.x - this.m01 * pos.y - this.m11 * this.m02 + this.m01 * this.m12) / det;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
212 var y = (- this.m10 * pos.x + this.m00 * pos.y + this.m10 * this.m02 - this.m00 * this.m12) / det;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
213 return new Position(x, y);
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
214 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
215 function getRotation(angle, pos) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
216 // returns a Transform that is a rotation by angle degrees around [pos.x, pos.y]
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
217 var traf = new Transform();
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
218 if (angle != 0) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
219 var t = 2.0 * Math.PI * parseFloat(angle) / 360.0;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
220 traf.m00 = Math.cos(t);
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
221 traf.m01 = - Math.sin(t);
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
222 traf.m10 = Math.sin(t);
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
223 traf.m11 = Math.cos(t);
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
224 traf.m02 = pos.x - pos.x * Math.cos(t) + pos.y * Math.sin(t);
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
225 traf.m12 = pos.y - pos.x * Math.sin(t) - pos.y * Math.cos(t);
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
226 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
227 return traf;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
228 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
229 function getTranslation(pos) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
230 // returns a Transform that is a translation by [pos.x, pos,y]
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
231 var traf = new Transform();
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
232 traf.m02 = pos.x;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
233 traf.m12 = pos.y;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
234 return traf;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
235 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
236 function getScale(size) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
237 // returns a Transform that is a scale by [size.width, size.height]
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
238 var traf = new Transform();
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
239 traf.m00 = size.width;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
240 traf.m11 = size.height;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
241 return traf;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
242 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
243
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
244
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
245 /* **********************************************
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
246 * parameter routines
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
247 * ******************************************** */
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
248
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
249 var dlParams = new Object();
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
250
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
251 function newParameter(name, defaultValue, detail) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
252 // create a new parameter with a name and a default value
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
253 if (defined(dlParams[name])) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
254 alert("Fatal: An object with name '" + name + "' already exists - cannot recreate!");
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
255 return false;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
256 } else {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
257 dlParams[name] = new Object();
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
258 dlParams[name].defaultValue = defaultValue;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
259 dlParams[name].hasValue = false;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
260 dlParams[name].value = defaultValue;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
261 dlParams[name].detail = detail;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
262 return dlParams[name];
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
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
266 function getParameter(name) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
267 // returns the named parameter value or its default value
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
268 if (defined(dlParams[name])) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
269 if (dlParams[name].hasValue) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
270 return dlParams[name].value;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
271 } else {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
272 return dlParams[name].defaultValue;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
273 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
274 } else {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
275 return null;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
276 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
277 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
278
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
279 function setParameter(name, value) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
280 // sets parameter value
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
281 if (defined(dlParams[name])) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
282 dlParams[name].value = value;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
283 dlParams[name].hasValue = true;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
284 return true;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
285 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
286 return false;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
287 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
288
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
289 function getAllParameters(detail) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
290 // returns a string of all parameters in query format
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
291 if (! detail) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
292 detail = 10;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
293 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
294 var params = new Array();
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
295 for ( param in dlParams ) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
296 if ((dlParams[param].detail <= detail)&&(dlParams[param].hasValue)) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
297 var val = getParameter(param);
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
298 if (val != "") {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
299 params.push(param + "=" + val);
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
300 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
301 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
302 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
303 return params.join("&");
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
304 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
305
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
306 function parseParameters(query) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
307 // gets parameter values from query format string
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
308 var params = query.split("&");
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
309 for (var i = 0; i < params.length; i++) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
310 var keyval = params[i].split("=");
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
311 if (keyval.length == 2) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
312 setParameter(keyval[0], keyval[1]);
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
313 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
314 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
315 }
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 /* **********************************************
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
319 * HTML/DOM routines
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 function getElement(tagid, quiet) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
323 // returns the element object with the id tagid
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
324 var e;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
325 if (document.getElementById) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
326 e = document.getElementById(tagid);
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
327 } else if (document.all) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
328 alert("document.all!");
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
329 e = document.all[tagid];
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
330 } else if (document.layers) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
331 e = document.layers[tagid];
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
332 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
333 if (e) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
334 return e;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
335 } else {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
336 if (! quiet) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
337 alert("unable to find element: "+tagid);
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
338 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
339 return null;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
340 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
341 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
342
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
343 function getElementPosition(elem) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
344 // returns a Position with the position of the element
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
345 var x = 0;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
346 var y = 0;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
347 if (defined(elem.offsetLeft)) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
348 var e = elem;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
349 while (e) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
350 if (defined(e.clientLeft)) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
351 // special for IE
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
352 if (browserType.isMac) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
353 if (e.offsetParent.tagName == "BODY") {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
354 // IE for Mac extraspecial
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
355 x += e.clientLeft;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
356 y += e.clientTop;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
357 break;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
358 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
359 } else {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
360 if ((e.tagName != "TABLE") && (e.tagName != "BODY")) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
361 x += e.clientLeft;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
362 y += e.clientTop;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
363 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
364 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
365 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
366 x += e.offsetLeft;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
367 y += e.offsetTop;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
368 e = e.offsetParent;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
369 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
370 } else if (defined(elem.x)) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
371 x = elem.x;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
372 y = elem.y;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
373 } else if (defined(elem.pageX)) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
374 x = elem.pageX;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
375 y = elem.pageY;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
376 } else {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
377 alert("unable to get position of "+elem+" (id:"+elem.id+")");
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
378 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
379 return new Position(getInt(x), getInt(y));
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
380 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
381
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
382 function getElementSize(elem) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
383 // returns a Rectangle with the size of the element
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
384 var width = 0;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
385 var height = 0;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
386 if (defined(elem.offsetWidth)) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
387 width = elem.offsetWidth;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
388 height = elem.offsetHeight;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
389 } else if (defined(elem.width)) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
390 width = elem.width;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
391 height = elem.height;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
392 } else if (defined(elem.clip.width)) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
393 width = elem.clip.width;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
394 height = elem.clip.height;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
395 } else {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
396 alert("unable to get size of "+elem+" (id:"+elem.id+")");
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
397 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
398 return new Size(getInt(width), getInt(height));
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
399 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
400
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
401 function getElementRect(elem) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
402 // returns a Rectangle with the size and position of the element
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
403 var pos = getElementPosition(elem);
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
404 var size = getElementSize(elem);
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
405 return new Rectangle(pos.x, pos.y, size.width, size.height);
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
406 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
407
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
408
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
409
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
410 function moveElement(elem, rect) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
411 // moves and sizes the element
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
412 if (elem.style) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
413 if (defined(rect.x)) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
414 elem.style.left = Math.round(rect.x) + "px";
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
415 elem.style.top = Math.round(rect.y) + "px";
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
416 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
417 if (defined(rect.width)) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
418 elem.style.width = Math.round(rect.width) + "px";
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
419 elem.style.height = Math.round(rect.height) + "px";
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
420 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
421 } else if (document.layers) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
422 if (defined(rect.x)) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
423 elem.pageX = getInt(rect.x);
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
424 elem.pageY = getInt(rect.y);
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
425 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
426 if (defined(rect.width)) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
427 elem.clip.width = getInt(rect.width);
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
428 elem.clip.height = getInt(rect.height);
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
429 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
430 } else {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
431 alert("moveelement: no style nor layer property!");
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
432 return false;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
433 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
434 return true;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
435 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
436
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
437 function showElement(elem, show) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
438 // shows or hides the element
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
439 if (elem.style) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
440 if (show) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
441 elem.style.visibility = "visible";
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
442 } else {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
443 elem.style.visibility = "hidden";
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
444 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
445 } else if (defined(elem.visibility)) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
446 if (show) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
447 elem.visibility = "show";
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
448 } else {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
449 elem.visibility = "hide";
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
450 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
451 } else {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
452 alert("showelement: no style nor layer property!");
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
453 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
454 return true;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
455 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
456
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
457 function evtPosition(evt) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
458 // returns the on-screen Position of the Event
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
459 var x;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
460 var y;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
461 evt = (evt) ? evt : window.event;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
462 if (!evt) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
463 alert("no event found! "+evt);
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
464 return;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
465 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
466 if (defined(evt.pageX)) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
467 x = parseInt(evt.pageX);
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
468 y = parseInt(evt.pageY);
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
469 } else if (defined(evt.clientX)) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
470 x = parseInt(document.body.scrollLeft+evt.clientX);
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
471 y = parseInt(document.body.scrollTop+evt.clientY);
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
472 } else {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
473 alert("evtPosition: don't know how to deal with "+evt);
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
474 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
475 return new Position(x, y);
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
476 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
477
242
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
478 function registerEvent(type, elem, handler) {
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
479 // register the given event handler on the indicated element
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
480 if (elem.addEventListener) {
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
481 elem.addEventListener(type, handler, false);
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
482 } else {
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
483 if (type = "mousedown") {
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
484 if (elem.captureEvents) {
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
485 elem.captureEvents(Event.MOUSEDOWN);
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
486 }
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
487 elem.onmousedown = handler;
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
488 } else if (type = "mouseup") {
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
489 if (elem.captureEvents) {
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
490 elem.captureEvents(Event.MOUSEUP);
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
491 }
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
492 elem.onmouseup = handler;
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
493 } else if (type = "mousemove") {
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
494 if (elem.captureEvents) {
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
495 elem.captureEvents(Event.MOUSEMOVE);
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
496 }
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
497 elem.onmousemove = handler;
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
498 } else if (type = "keypress") {
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
499 if (elem.captureEvents) {
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
500 elem.captureEvents(Event.KEYPRESS);
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
501 }
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
502 elem.onkeypress = handler;
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
503 } else {
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
504 alert("registerEvent: unknown event type "+type);
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
505 return false;
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
506 }
237
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
507 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
508 return true;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
509 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
510
242
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
511 function unregisterEvent(type, elem, handler) {
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
512 // unregister the given event handler from the indicated element
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
513 if (elem.removeEventListener) {
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
514 elem.removeEventListener(type, handler, false);
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
515 } else {
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
516 if (type = "mousedown") {
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
517 if (elem.releaseEvents) {
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
518 elem.releaseEvents(Event.MOUSEDOWN);
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
519 }
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
520 elem.onmousedown = null;
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
521 } else if (type = "mouseup") {
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
522 if (elem.releaseEvents) {
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
523 elem.releaseEvents(Event.MOUSEUP);
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
524 }
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
525 elem.onmouseup = null;
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
526 } else if (type = "mousemove") {
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
527 if (elem.releaseEvents) {
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
528 elem.releaseEvents(Event.MOUSEMOVE);
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
529 }
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
530 elem.onmousemove = null;
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
531 } else if (type = "keypress") {
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
532 if (elem.releaseEvents) {
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
533 elem.releaseEvents(Event.KEYPRESS);
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
534 }
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
535 elem.onkeypress = null;
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
536 } else {
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
537 alert("unregisterEvent: unknown event type "+type);
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
538 return false;
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
539 }
237
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
540 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
541 return true;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
542 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
543
242
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
544
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
545 // old registerXXYY API for compatibility
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
546 function registerMouseDown(elem, handler) {
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
547 return registerEvent("mousedown", elem, handler);
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
548 }
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
549 function unregisterMouseDown(elem, handler) {
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
550 return unregisterEvent("mousedown", elem, handler);
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
551 }
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
552 function registerMouseMove(elem, handler) {
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
553 return registerEvent("mousemove", elem, handler);
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
554 }
237
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
555 function unregisterMouseMove(elem, handler) {
242
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
556 return unregisterEvent("mousemove", elem, handler);
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
557 }
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
558 function registerKeyDown(handler) {
e2c455c2a0d0 new digimage with red triangles for moving the zoomed area
robcast
parents: 241
diff changeset
559 return registerEvent("keypress", elem, handler);
237
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
560 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
561
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
562
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
563 function getWinSize() {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
564 // returns a Size with the current window size (mostly from www.quirksmode.org)
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
565 var wsize = new Size(100, 100);
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
566 if (defined(self.innerHeight)) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
567 // all except Explorer
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
568 wsize.width = self.innerWidth;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
569 wsize.height = self.innerHeight;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
570 } else if (document.documentElement && document.documentElement.clientHeight) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
571 // Explorer 6 Strict Mode
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
572 wsize.width = document.documentElement.clientWidth;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
573 wsize.height = document.documentElement.clientHeight;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
574 } else if (document.body) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
575 // other Explorers
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
576 wsize.width = document.body.clientWidth;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
577 wsize.height = document.body.clientHeight;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
578 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
579 return wsize;
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
580 }
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
581
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
582 function openWin(url, title, params) {
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
583 // open browser window
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
584 var ow = window.open(url, title, params);
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
585 ow.focus();
786c27786281 new javascript code for digilib
robcast
parents:
diff changeset
586 }