annotate client/digitallibrary/greyskin/dllib.js @ 430:fc5b8cade32f

bug fixes; added saving status in cookie; added basic screen calibration functionality;
author hertzhaft
date Mon, 09 Jan 2006 17:53:03 +0100
parents ab2557f079fc
children a6af40003a38
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
396
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
1 /* Copyright (C) 2003,2004 IT-Group MPIWG, WTWG Uni Bern and others
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
2
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
3 This program is free software; you can redistribute it and/or
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
4 modify it under the terms of the GNU General Public License
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
5 as published by the Free Software Foundation; either version 2
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
6 of the License, or (at your option) any later version.
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
7
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
8 This program is distributed in the hope that it will be useful,
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
9 but WITHOUT ANY WARRANTY; without even the implied warranty of
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
10 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
11 GNU General Public License for more details.
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
12
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
13 You should have received a copy of the GNU General Public License
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
14 along with this program; if not, write to the Free Software
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
15 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
16
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
17 Authors:
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
18 Christian Luginbuehl, 01.05.2003 (first version)
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
19 DW 24.03.2004 (Changed for digiLib in Zope)
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
20 Robert Casties, 8.11.2005
407
21540fe26235 some general refactoring;
hertzhaft
parents: 397
diff changeset
21 Martin Raspe <hertzhaft@biblhertz.it>, 12.12.2005
396
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
22
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
23 ! Requires baselib.js !
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
24
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
25 */
407
21540fe26235 some general refactoring;
hertzhaft
parents: 397
diff changeset
26 digilibVersion = "Digilib NG";
430
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
27 dllibVersion = "2.027";
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
28 isDigilibInitialized = false; // gets set to true in dl_param_init
425
ab2557f079fc added showArrows() function (navigation arrows overlay)
hertzhaft
parents: 412
diff changeset
29 reloadPage = true; // reload the page when parameters are changed, otherwise update only "src" attribute of scaler img
ab2557f079fc added showArrows() function (navigation arrows overlay)
hertzhaft
parents: 412
diff changeset
30
ab2557f079fc added showArrows() function (navigation arrows overlay)
hertzhaft
parents: 412
diff changeset
31 // global variables
ab2557f079fc added showArrows() function (navigation arrows overlay)
hertzhaft
parents: 412
diff changeset
32 dlTrafo = new Transform();
ab2557f079fc added showArrows() function (navigation arrows overlay)
hertzhaft
parents: 412
diff changeset
33 dlMaxArea = new Rectangle(0.0, 0.0, 1.0, 1.0);
ab2557f079fc added showArrows() function (navigation arrows overlay)
hertzhaft
parents: 412
diff changeset
34 dlArea = null;
ab2557f079fc added showArrows() function (navigation arrows overlay)
hertzhaft
parents: 412
diff changeset
35 dlMarks = null;
ab2557f079fc added showArrows() function (navigation arrows overlay)
hertzhaft
parents: 412
diff changeset
36 dlFlags = null;
ab2557f079fc added showArrows() function (navigation arrows overlay)
hertzhaft
parents: 412
diff changeset
37
ab2557f079fc added showArrows() function (navigation arrows overlay)
hertzhaft
parents: 412
diff changeset
38 // global elements
430
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
39 scalerDiv = null;
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
40 scalerImg = null;
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
41
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
42 // flags for parameter sets
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
43 PARAM_FILE = 1;
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
44 PARAM_MODE = 2;
430
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
45 PARAM_DIM = 4;
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
46 PARAM_IMAGE = 8;
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
47 PARAM_DPI = 16;
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
48 PARAM_MARK = 32;
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
49 PARAM_PAGES = 64;
430
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
50 PARAM_SIZE = 128;
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
51 PARAM_ALL = PARAM_FILE | PARAM_MODE | PARAM_DIM | PARAM_IMAGE | PARAM_DPI | PARAM_MARK | PARAM_PAGES | PARAM_SIZE;
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
52
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
53 // mouse drag area that counts as one click
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
54 MIN_AREA_SIZE = 3 * 3 + 1;
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
55
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
56 // standard zoom factor
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
57 ZOOMFACTOR = Math.sqrt(2);
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
58
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
59 // bird's eye view dimensions
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
60 BIRD_MAXX = 100;
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
61 BIRD_MAXY = 100;
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
62
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
63 // with of arrow bars
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
64 ARROW_WIDTH = 32;
396
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
65
430
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
66 // with of calibration bar
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
67 CALIBRATION_WIDTH = 64;
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
68
396
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
69 function identify() {
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
70 // used for identifying a digilib instance
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
71 // Relato uses that function - lugi
407
21540fe26235 some general refactoring;
hertzhaft
parents: 397
diff changeset
72 return digilibVersion;
396
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
73 }
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
74 /*
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
75 * more parameter handling
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
76 */
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
77
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
78 function initParameters() {
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
79 // file
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
80 newParameter('fn', '', PARAM_FILE);
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
81 newParameter('pn', '1', PARAM_FILE);
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
82 // mode
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
83 newParameter('mo', '', PARAM_MODE);
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
84 // relative dimensions of zoomed image
430
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
85 newParameter('wx', '0.0', PARAM_DIM);
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
86 newParameter('wy', '0.0', PARAM_DIM);
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
87 newParameter('ww', '1.0', PARAM_DIM);
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
88 newParameter('wh', '1.0', PARAM_DIM);
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
89 // image manipulation
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
90 newParameter('brgt', '0.0', PARAM_IMAGE);
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
91 newParameter('cont', '0.0', PARAM_IMAGE);
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
92 newParameter('rot', '0.0', PARAM_IMAGE);
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
93 newParameter('rgba', '', PARAM_IMAGE);
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
94 newParameter('rgbm', '', PARAM_IMAGE);
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
95 // resolution
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
96 newParameter('ddpi', '', PARAM_DPI);
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
97 newParameter('ddpix', '', PARAM_DPI);
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
98 newParameter('ddpiy', '', PARAM_DPI);
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
99 // marks
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
100 newParameter('mk', '', PARAM_MARK);
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
101 // pages total
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
102 newParameter('pt', '0', PARAM_PAGES);
430
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
103 // size
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
104 newParameter('ws', '1.0', PARAM_SIZE);
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
105 }
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
106
396
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
107 function parseArea() {
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
108 // returns area Rectangle from current parameters
407
21540fe26235 some general refactoring;
hertzhaft
parents: 397
diff changeset
109 return new Rectangle(
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
110 getParameter("wx"),
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
111 getParameter("wy"),
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
112 getParameter("ww"),
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
113 getParameter("wh"));
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
114 }
396
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
115
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
116 function setParamFromArea(rect) {
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
117 // sets digilib wx etc. from rect
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
118 setParameter("wx", cropFloat(rect.x));
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
119 setParameter("wy", cropFloat(rect.y));
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
120 setParameter("ww", cropFloat(rect.width));
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
121 setParameter("wh", cropFloat(rect.height));
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
122 return true;
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
123 }
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
124
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
125 /* **********************************************
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
126 * parse parameters routines
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
127 * ******************************************** */
396
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
128
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
129 function parseTrafo(elem) {
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
130 // returns Transform from current dlArea and picsize
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
131 var picsize = getElementRect(elem);
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
132 var trafo = new Transform();
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
133 // subtract area offset and size
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
134 trafo.concat(getTranslation(new Position(-dlArea.x, -dlArea.y)));
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
135 trafo.concat(getScale(new Size(1/dlArea.width, 1/dlArea.height)));
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
136 // scale to screen size
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
137 trafo.concat(getScale(picsize));
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
138 trafo.concat(getTranslation(picsize));
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
139 // FIX ME: Robert, kannst Du mal nachsehen, ob das folgende tut, was es soll?
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
140 // oder gibt es dafür neuen Code?
396
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
141 // rotate
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
142 var rot = getRotation(- getParameter("rot"), new Position(0.5*picsize.width, 0.5*picsize.height));
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
143 trafo.concat(rot);
396
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
144 // mirror
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
145 if (hasFlag("hmir")) trafo.m00 = - trafo.m00; // ??
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
146 if (hasFlag("vmir")) trafo.m11 = - trafo.m11; // ??
396
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
147 return trafo;
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
148 }
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
149
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
150 function parseMarks() {
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
151 // returns marks array from current parameters
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
152 var marks = new Array();
407
21540fe26235 some general refactoring;
hertzhaft
parents: 397
diff changeset
153 var param = getParameter("mk");
21540fe26235 some general refactoring;
hertzhaft
parents: 397
diff changeset
154 var pairs = (param.indexOf(";") >= 0)
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
155 ? param.split(";") // old format with ";"
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
156 : param.split(","); // new format
407
21540fe26235 some general refactoring;
hertzhaft
parents: 397
diff changeset
157 for (var i = 0; i < pairs.length ; i++) {
21540fe26235 some general refactoring;
hertzhaft
parents: 397
diff changeset
158 var pos = pairs[i].split("/");
21540fe26235 some general refactoring;
hertzhaft
parents: 397
diff changeset
159 if (pos.length > 1) marks.push(new Position(pos[0], pos[1]));
21540fe26235 some general refactoring;
hertzhaft
parents: 397
diff changeset
160 }
21540fe26235 some general refactoring;
hertzhaft
parents: 397
diff changeset
161 return marks;
396
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
162 }
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
163
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
164 /* **********************************************
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
165 * marks routines
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
166 * ******************************************** */
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
167
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
168 function getAllMarks() {
396
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
169 // returns a string with all marks in query format
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
170 var marks = new Array();
407
21540fe26235 some general refactoring;
hertzhaft
parents: 397
diff changeset
171 for (var i = 0; i < dlMarks.length; i++)
396
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
172 marks.push(cropFloat(dlMarks[i].x) + "/" + cropFloat(dlMarks[i].y));
407
21540fe26235 some general refactoring;
hertzhaft
parents: 397
diff changeset
173 return marks.join(",");
396
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
174 }
407
21540fe26235 some general refactoring;
hertzhaft
parents: 397
diff changeset
175
21540fe26235 some general refactoring;
hertzhaft
parents: 397
diff changeset
176 getMarksQueryString = getAllMarks;
396
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
177
407
21540fe26235 some general refactoring;
hertzhaft
parents: 397
diff changeset
178 function addMark(evt) {
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
179 // add a mark
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
180 var pos = dlTrafo.invtransform(evtPosition(evt));
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
181 dlMarks.push(pos)
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
182 setParameter("mk", getAllMarks());
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
183 return true;
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
184 }
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
185
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
186 function deleteMark() {
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
187 // delete the last mark
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
188 var mark = dlMarks.pop();
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
189 setParameter("mk", getAllMarks());
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
190 return true;
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
191 }
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
192
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
193 function deleteAllMarks() {
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
194 // delete all marks and mk parameters
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
195 dlMarks.length = 0;
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
196 resetParameter("mk");
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
197 return true;
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
198 }
407
21540fe26235 some general refactoring;
hertzhaft
parents: 397
diff changeset
199
21540fe26235 some general refactoring;
hertzhaft
parents: 397
diff changeset
200 function createMarkDiv(index) {
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
201 var div = document.createElement("div");
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
202 div.className = "mark";
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
203 div.id = "mark" + index;
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
204 div.innerHTML = index + 1;
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
205 document.body.appendChild(div);
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
206 return div;
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
207 }
396
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
208
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
209 /* **********************************************
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
210 * flag routines
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
211 * ******************************************** */
396
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
212
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
213 function hasFlag(mode) {
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
214 // returns if mode flag is set
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
215 return (dlFlags[mode]);
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
216 }
396
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
217
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
218 function addFlag(mode) {
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
219 // add a mode flag
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
220 dlFlags[mode] = mode;
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
221 setParameter("mo", getAllFlags());
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
222 return true;
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
223 }
396
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
224
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
225 function removeFlag(mode) {
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
226 // remove a mode flag
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
227 if (dlFlags[mode]) delete dlFlags[mode];
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
228 setParameter("mo", getAllFlags());
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
229 return true;
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
230 }
396
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
231
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
232 function toggleFlag(mode) {
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
233 // change a mode flag
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
234 if (dlFlags[mode]) {
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
235 delete dlFlags[mode];
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
236 } else {
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
237 dlFlags[mode] = mode;
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
238 }
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
239 setParameter("mo", getAllFlags());
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
240 return true;
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
241 }
396
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
242
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
243 function getAllFlags() {
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
244 // returns a string with all flags in query format
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
245 var fa = new Array();
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
246 for (var f in dlFlags) {
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
247 if ((f != "")&&(dlFlags[f] != null)) {
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
248 fa.push(f);
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
249 }
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
250 }
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
251 return fa.join(",");
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
252 }
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
253
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
254 function parseFlags() {
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
255 // sets dlFlags from the current parameters
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
256 var flags = new Object();
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
257 var fa = getParameter("mo").split(",");
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
258 for (var i = 0; i < fa.length ; i++) {
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
259 var f = fa[i];
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
260 if (f != "") {
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
261 flags[f] = f;
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
262 }
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
263 }
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
264 return flags;
407
21540fe26235 some general refactoring;
hertzhaft
parents: 397
diff changeset
265 }
396
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
266
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
267
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
268 function bestPicSize(elem, inset) {
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
269 // returns a Size with the best image size for the given element
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
270 if (! defined(inset)) {
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
271 inset = 25;
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
272 }
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
273 var ws = getWinSize();
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
274 var es = getElementPosition(elem);
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
275 if (es) {
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
276 ws.width = ws.width - es.x - inset;
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
277 ws.height = ws.height - es.y - inset;
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
278 }
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
279 return ws;
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
280 }
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
281
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
282 function setDLParam(e, s, relative) {
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
283 // sets parameter based on HTML event
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
284 var nam;
396
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
285 var val;
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
286 if (s.type && (s.type == "select-one")) {
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
287 nam = s.name;
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
288 val = s.options[s.selectedIndex].value;
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
289 } else if (s.name && s.value) {
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
290 nam = s.name;
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
291 val = s.value;
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
292 }
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
293 if (nam && val) {
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
294 setParameter(nam, val, relative);
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
295 display();
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
296 } else {
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
297 alert("ERROR: unable to process event!");
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
298 }
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
299 return true;
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
300 }
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
301
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
302
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
303 /* **********************************************
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
304 * digilib specific routines
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
305 * ******************************************** */
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
306
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
307
407
21540fe26235 some general refactoring;
hertzhaft
parents: 397
diff changeset
308 function parseAllParameters() {
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
309 // put the query parameters (sans "?") in the parameters array
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
310 parseParameters(location.search.slice(1));
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
311 // treat special parameters
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
312 dlMarks = parseMarks();
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
313 dlArea = parseArea();
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
314 dlFlags = parseFlags();
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
315 }
407
21540fe26235 some general refactoring;
hertzhaft
parents: 397
diff changeset
316
396
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
317 function dl_param_init() {
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
318 // initialisation before onload
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
319 if (!baseLibVersion) alert("ERROR: baselib.js not loaded!");
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
320 if (isDigilibInitialized) return false; // dl_param_init was already run
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
321 // dlArea = new Rectangle(0.0, 0.0, 1.0, 1.0); // overwritten by parseAllParameters() below
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
322 // dlMarks = new Array(); // dito
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
323 // dlFlags = new Object(); // dito
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
324 // parse parameters
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
325 parseAllParameters();
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
326 isDigilibInitialized = true;
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
327 return true;
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
328 }
396
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
329
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
330 function dl_init() {
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
331 // initalisation on load
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
332 if (!isDigilibInitialized) dl_param_init();
430
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
333 scalerDiv = getElement("scaler");
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
334 scalerImg = getElement("pic", true);
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
335 // in N4 pic is in the scaler layer
430
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
336 if (scalerImg == null && scalerDiv) {
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
337 scalerImg = scalerDiv.document.images[0];
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
338 }
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
339 // give a name to the window containing digilib
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
340 window.name = defined(dlTarget) && dlTarget
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
341 ? dlTarget
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
342 : "digilib";
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
343 // put the query parameters (sans "?") in the parameters array
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
344 // parseAllParameters(); // has already been called in dl_param_init()
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
345 // wait for image to load and display marks
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
346 renderMarks();
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
347 // done
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
348 focus();
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
349 }
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
350
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
351 initScaler = dl_init;
396
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
352
407
21540fe26235 some general refactoring;
hertzhaft
parents: 397
diff changeset
353 function loadScalerImage(detail) {
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
354 var pic = getElement('pic');
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
355 var scaler = getElement('scaler');
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
356 var zoomdiv = getElement("zoom"); // test for presence only
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
357 var overlay = getElement("overlay"); // test for presence only
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
358 var about = getElement("bird"); // test for presence only
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
359 var bird = getElement("bird"); // test for presence only
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
360 var picsize = bestPicSize(scaler, 50);
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
361 var src = "../servlet/Scaler?"
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
362 + getQueryString()
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
363 + "&dw=" + picsize.width
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
364 + "&dh=" + picsize.height;
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
365 // debug(src);
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
366 pic.src = src;
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
367 initScaler(); // dl_init braucht die endgültigen Maße des pic Elements
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
368 }
396
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
369
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
370 function display(detail) {
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
371 // redisplay the page
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
372 if (! detail) detail = PARAM_ALL;
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
373 var queryString = getAllParameters(detail);
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
374 if (reloadPage) {
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
375 location.href
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
376 = location.protocol + "//"
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
377 + location.host
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
378 + location.pathname
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
379 + "?" + queryString;
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
380 } else {
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
381 loadScalerImage();
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
382 }
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
383 }
396
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
384
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
385 /* **********************************************
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
386 * interactive digilib functions
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
387 * ******************************************** */
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
388 function renderMarks() {
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
389 // make sure the image is loaded so we know its size
430
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
390 if (defined(scalerImg.complete) && !scalerImg.complete && !browserType.isN4 ) {
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
391 setTimeout("renderMarks()", 100);
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
392 return;
396
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
393 }
407
21540fe26235 some general refactoring;
hertzhaft
parents: 397
diff changeset
394 // put the visible marks on the image
430
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
395 dlTrafo = parseTrafo(scalerImg);
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
396 // debugProps(dlArea, "dlArea");
407
21540fe26235 some general refactoring;
hertzhaft
parents: 397
diff changeset
397 for (var i = 0; i < dlMarks.length; i++) {
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
398 var div = document.getElementById("mark" + i) || createMarkDiv(i);
407
21540fe26235 some general refactoring;
hertzhaft
parents: 397
diff changeset
399 var mark = dlMarks[i];
425
ab2557f079fc added showArrows() function (navigation arrows overlay)
hertzhaft
parents: 412
diff changeset
400 // debugProps(mark, "mark");
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
401 if (dlArea.containsPosition(mark)) {
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
402 var mpos = dlTrafo.transform(mark); // FIX ME: transform does not change anything
425
ab2557f079fc added showArrows() function (navigation arrows overlay)
hertzhaft
parents: 412
diff changeset
403 // debugProps(mark, "mpos");
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
404 // suboptimal to place -5 pixels and not half size of mark-image
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
405 // better not hide the marked spot (MR)
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
406 // mpos.x = mpos.x -5;
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
407 // mpos.y = mpos.y -5;
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
408 moveElement(div, mpos);
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
409 showElement(div, true);
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
410 } else {
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
411 // hide the other marks
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
412 showElement(div, false);
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
413 }
396
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
414 }
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
415 }
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
416
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
417 function setMark(reload) {
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
418
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
419 function markEvent(evt) {
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
420 // event handler adding a new mark
430
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
421 unregisterEvent("mousedown", scalerDiv, markEvent);
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
422 addMark(evt);
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
423 if ( defined(reload) && !reload ) {
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
424 // don't redisplay
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
425 renderMarks();
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
426 return;
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
427 }
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
428 display();
430
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
429 return stopEvent(evt);
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
430 }
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
431
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
432 // add a mark where clicked
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
433 window.focus();
430
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
434 moveCenter(false);
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
435 // start event capturing
430
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
436 registerEvent("mousedown", scalerDiv, markEvent);
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
437 }
396
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
438
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
439 function removeMark(reload) {
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
440 // remove the last mark
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
441 deleteMark();
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
442 if (defined(reload)&&(!reload)) {
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
443 // don't redisplay
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
444 renderMarks();
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
445 return;
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
446 }
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
447 display();
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
448 }
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
449
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
450 function zoomArea() {
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
451 var pt1, pt2;
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
452 var zoomdiv = getElement("zoom");
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
453 var overlay = getElement("overlay");
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
454 // use overlay div to avoid <img> mousemove problems
430
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
455 var picRect = getElementRect(scalerImg);
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
456 // FIX ME: is there a way to query the border width from CSS info?
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
457 // rect.x -= 2; // account for overlay borders
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
458 // rect.y -= 2;
430
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
459 moveElement(overlay, picRect);
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
460 showElement(overlay, true);
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
461 // start event capturing
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
462 registerEvent("mousedown", overlay, zoomStart);
430
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
463 registerEvent("mousedown", scalerImg, zoomStart);
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
464 window.focus();
396
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
465
407
21540fe26235 some general refactoring;
hertzhaft
parents: 397
diff changeset
466 // mousedown handler: start moving
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
467 function zoomStart(evt) {
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
468 pt1 = evtPosition(evt);
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
469 unregisterEvent("mousedown", overlay, zoomStart);
430
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
470 unregisterEvent("mousedown", scalerImg, zoomStart);
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
471 // setup and show zoom div
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
472 moveElement(zoomdiv, Rectangle(pt1.x, pt1.y, 0, 0));
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
473 showElement(zoomdiv, true);
430
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
474 // register events
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
475 registerEvent("mousemove", document, zoomMove);
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
476 registerEvent("mouseup", document, zoomEnd);
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
477 return stopEvent(evt);
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
478 }
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
479
407
21540fe26235 some general refactoring;
hertzhaft
parents: 397
diff changeset
480 // mouseup handler: end moving
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
481 function zoomEnd(evt) {
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
482 pt2 = evtPosition(evt);
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
483 // assume a click if the area is too small (up to 3 x 3 pixel)
430
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
484 var clickRect = getRect(pt1, pt2);
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
485 if (clickRect.getArea() <= MIN_AREA_SIZE) return stopEvent(evt);
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
486 // hide zoom div
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
487 showElement(zoomdiv, false);
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
488 showElement(overlay, false);
430
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
489 // unregister events
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
490 unregisterEvent("mousemove", document, zoomMove);
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
491 unregisterEvent("mouseup", document, zoomMove);
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
492 // calc offsets
430
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
493 clickRect.clipTo(picRect);
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
494 var area = getRect(
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
495 // FIX ME: liefert negative x/y Werte, wenn hmir/vmir=1
430
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
496 dlTrafo.invtransform(clickRect.getPt1()),
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
497 dlTrafo.invtransform(clickRect.getPt2())
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
498 );
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
499 setParameter("wx", cropFloat(area.x));
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
500 setParameter("wy", cropFloat(area.y));
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
501 setParameter("ww", cropFloat(area.width));
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
502 setParameter("wh", cropFloat(area.height));
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
503 // parseArea(); // why?
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
504 // zoomed is always fit
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
505 setParameter("ws", 1);
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
506 display();
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
507 return stopEvent(evt);
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
508 }
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
509
407
21540fe26235 some general refactoring;
hertzhaft
parents: 397
diff changeset
510 // mouse move handler
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
511 function zoomMove(evt) {
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
512 pt2 = evtPosition(evt);
430
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
513 var rect = getRect(pt1, pt2);
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
514 rect.clipTo(picRect);
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
515 // update zoom div
430
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
516 moveElement(zoomdiv, rect);
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
517 return stopEvent(evt);
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
518 }
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
519
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
520 // get a rectangle from two points
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
521 function getRect(p1, p2) {
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
522 return new Rectangle(
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
523 Math.min(p1.x, p2.x),
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
524 Math.min(p1.y, p2.y),
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
525 Math.abs(p1.x - p2.x),
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
526 Math.abs(p1.y - p2.y)
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
527 );
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
528 }
396
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
529 }
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
530
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
531 function zoomBy(factor) {
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
532 // zooms by the given factor
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
533 var newarea = dlArea.copy();
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
534 newarea.width /= factor;
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
535 newarea.height /= factor;
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
536 newarea.x -= 0.5 * (newarea.width - dlArea.width);
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
537 newarea.y -= 0.5 * (newarea.height - dlArea.height);
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
538 newarea = dlMaxArea.fit(newarea);
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
539 setParamFromArea(newarea);
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
540 display();
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
541 }
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
542
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
543
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
544 function zoomFullpage() {
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
545 // zooms out to show the whole image
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
546 setParameter("wx", 0.0);
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
547 setParameter("wy", 0.0);
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
548 setParameter("ww", 1.0);
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
549 setParameter("wh", 1.0);
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
550 display();
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
551 }
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
552
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
553
430
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
554 function moveCenter(on) {
396
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
555 // move visible area so that it's centered around the clicked point
430
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
556 if (isFullArea()) return; // nothing to do
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
557 // starting event capture
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
558 if (on) registerEvent("mousedown", scalerImg, moveCenterEvent);
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
559 else unregisterEvent("mousedown", scalerImg, moveCenterEvent);
396
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
560 window.focus();
430
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
561 }
396
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
562
430
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
563 function moveCenterEvent(evt) {
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
564 // move to handler
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
565 var pt = dlTrafo.invtransform(evtPosition(evt));
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
566 var newarea = new Rectangle(
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
567 pt.x - 0.5 * dlArea.width,
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
568 pt.y - 0.5 * dlArea.height,
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
569 dlArea.width,
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
570 dlArea.height
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
571 );
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
572 newarea.stayInside(dlMaxArea);
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
573 // newarea = dlMaxArea.fit(newarea);
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
574 // debugProps(newarea, "newarea");
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
575 // debugProps(dlArea, "dlArea");
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
576 if (newarea.equals(dlArea)) return; // keep event handler
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
577 unregisterEvent("mousedown", scalerImg, moveCenterEvent);
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
578 // set parameters
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
579 setParamFromArea(newarea);
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
580 parseArea();
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
581 display();
396
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
582 }
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
583
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
584 function isFullArea(area) {
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
585 if (!area) area = dlArea;
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
586 return ((area.width == 1.0) && (area.height == 1.0));
430
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
587 }
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
588
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
589 function canMove(movx, movy) {
425
ab2557f079fc added showArrows() function (navigation arrows overlay)
hertzhaft
parents: 412
diff changeset
590 if (isFullArea()) return false;
430
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
591 var x2 = dlArea.x + dlArea.width;
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
592 var y2 = dlArea.y + dlArea.height;
425
ab2557f079fc added showArrows() function (navigation arrows overlay)
hertzhaft
parents: 412
diff changeset
593 // debugProps(dlArea);
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
594 return ((movx < 0) && (dlArea.x > 0))
430
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
595 || ((movx > 0) && (x2 < 1.0))
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
596 || ((movy < 0) && (dlArea.y > 0))
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
597 || ((movy > 0) && (y2 < 1.0))
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
598 }
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
599
396
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
600 function moveBy(movx, movy) {
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
601 // move visible area by movx and movy (in units of ww, wh)
425
ab2557f079fc added showArrows() function (navigation arrows overlay)
hertzhaft
parents: 412
diff changeset
602 if (!canMove(movx, movy)) return; // nothing to do
396
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
603 var newarea = dlArea.copy();
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
604 newarea.x += parseFloat(movx)*dlArea.width;
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
605 newarea.y += parseFloat(movy)*dlArea.height;
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
606 newarea = dlMaxArea.fit(newarea);
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
607 // set parameters
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
608 setParamFromArea(newarea);
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
609 parseArea();
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
610 display();
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
611 }
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
612
407
21540fe26235 some general refactoring;
hertzhaft
parents: 397
diff changeset
613 function getRef(baseURL) {
396
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
614 // returns a reference to the current digilib set
425
ab2557f079fc added showArrows() function (navigation arrows overlay)
hertzhaft
parents: 412
diff changeset
615 if (!baseUrl) baseUrl
ab2557f079fc added showArrows() function (navigation arrows overlay)
hertzhaft
parents: 412
diff changeset
616 = location.protocol
ab2557f079fc added showArrows() function (navigation arrows overlay)
hertzhaft
parents: 412
diff changeset
617 + "//"
ab2557f079fc added showArrows() function (navigation arrows overlay)
hertzhaft
parents: 412
diff changeset
618 + location.host
ab2557f079fc added showArrows() function (navigation arrows overlay)
hertzhaft
parents: 412
diff changeset
619 + location.pathname;
396
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
620 var hyperlinkRef = baseUrl;
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
621 var params = getAllParameters(PARAM_ALL & ~(PARAM_DPI | PARAM_PAGES)); // all without ddpi, pt
407
21540fe26235 some general refactoring;
hertzhaft
parents: 397
diff changeset
622 if (params.length > 0) hyperlinkRef += "?" + params;
21540fe26235 some general refactoring;
hertzhaft
parents: 397
diff changeset
623 return hyperlinkRef;
396
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
624 }
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
625
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
626 function getRefWin(type, msg) {
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
627 // shows an alert with a reference to the current digilib set
407
21540fe26235 some general refactoring;
hertzhaft
parents: 397
diff changeset
628 if (! msg) msg = "URL reference to the current view";
21540fe26235 some general refactoring;
hertzhaft
parents: 397
diff changeset
629 prompt(msg, getRef());
396
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
630 }
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
631
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
632 function getQuality() {
407
21540fe26235 some general refactoring;
hertzhaft
parents: 397
diff changeset
633 // returns the current q setting
396
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
634 for (var i = 0; i < 3; i++) {
407
21540fe26235 some general refactoring;
hertzhaft
parents: 397
diff changeset
635 if (hasFlag("q"+i)) return i;
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
636 }
407
21540fe26235 some general refactoring;
hertzhaft
parents: 397
diff changeset
637 return 1
396
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
638 }
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
639
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
640 function setQuality(qual) {
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
641 // set the image quality
407
21540fe26235 some general refactoring;
hertzhaft
parents: 397
diff changeset
642 for (var i = 0; i < 3; i++) removeFlag("q" + i);
21540fe26235 some general refactoring;
hertzhaft
parents: 397
diff changeset
643 if (qual > 2) return alert("Quality number not supported");
21540fe26235 some general refactoring;
hertzhaft
parents: 397
diff changeset
644 addFlag("q" + i);
396
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
645 setParameter("mo", getAllFlags());
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
646 display();
407
21540fe26235 some general refactoring;
hertzhaft
parents: 397
diff changeset
647 }
396
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
648
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
649 function setQualityWin(msg) {
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
650 // dialog for setting quality
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
651 if (! msg) msg = "Quality (0..2)";
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
652 var q = getQuality();
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
653 var newq = window.prompt(msg, q);
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
654 if (newq) setQuality(newq);
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
655 }
396
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
656
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
657 function mirror(dir) {
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
658 // mirror the image horizontally or vertically
425
ab2557f079fc added showArrows() function (navigation arrows overlay)
hertzhaft
parents: 412
diff changeset
659 toggleFlag(dir == "h"
ab2557f079fc added showArrows() function (navigation arrows overlay)
hertzhaft
parents: 412
diff changeset
660 ? "hmir"
ab2557f079fc added showArrows() function (navigation arrows overlay)
hertzhaft
parents: 412
diff changeset
661 : "vmir"
ab2557f079fc added showArrows() function (navigation arrows overlay)
hertzhaft
parents: 412
diff changeset
662 );
396
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
663 setParameter("mo", getAllFlags());
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
664 display();
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
665 }
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
666
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
667 function gotoPage(gopage, keep) {
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
668 // goto given page nr (+/-: relative)
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
669 var oldpn = parseInt(getParameter("pn"));
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
670 setParameter("pn", gopage, true);
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
671 var pn = parseInt(getParameter("pn"));
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
672 if (pn < 1) {
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
673 alert("No such page! (Page number too low)");
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
674 setParameter("pn", oldpn);
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
675 return;
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
676 }
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
677 if (hasParameter("pt")) {
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
678 pt = parseInt(getParameter("pt"))
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
679 if (pn > pt) {
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
680 alert("No such page! (Page number too high)");
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
681 setParameter("pn", oldpn);
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
682 return;
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
683 }
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
684 }
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
685 if (keep) {
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
686 display(PARAM_ALL & ~PARAM_MARK); // all, no mark
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
687 } else {
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
688 display(PARAM_FILE | PARAM_MODE | PARAM_PAGES); // fn, pn, ws, mo + pt
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
689 // FIX ME: currently the mirror status gets propagated to the other pages
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
690 // hmir and vmir should not be mode flags, but boolean params!!!
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
691 }
396
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
692 }
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
693
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
694 function gotoPageWin() {
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
695 // dialog to ask for new page nr
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
696 var pn = getParameter("pn");
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
697 var gopage = window.prompt("Go to page", pn);
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
698 if (gopage) gotoPage(gopage);
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
699 }
396
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
700
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
701 function setParamWin(param, text, relative) {
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
702 // dialog to ask for new parameter value
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
703 var val = getParameter(param);
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
704 var newval = window.prompt(text, val);
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
705 if (newval) {
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
706 setParameter(param, newval, relative);
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
707 display();
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
708 }
396
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
709 }
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
710
fa84aff8190b simplyfications
hertzhaft
parents:
diff changeset
711 function showOptions(show) {
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
712 // show or hide option div
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
713 var elem = getElement("dloptions");
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
714 showElement(elem, show);
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
715 // FIX ME: get rid of the dotted line around the buttons when focused
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
716 }
407
21540fe26235 some general refactoring;
hertzhaft
parents: 397
diff changeset
717
21540fe26235 some general refactoring;
hertzhaft
parents: 397
diff changeset
718 function showAboutDiv(show) {
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
719 // show or hide "about" div
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
720 var elem = getElement("about");
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
721 if (elem == null) {
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
722 if (!show) return;
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
723 alert("About Digilib - dialog missing in HTML code!"
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
724 + "\nDigilib Version: " + digilibVersion
430
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
725 + "\JSP Version: " + jspVersion
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
726 + "\ndlLib Version: " + dllibVersion
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
727 + "\nbaseLib Version: " + baseLibVersion);
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
728 return;
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
729 }
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
730 document.getElementById("digilib-version").innerHTML = "Digilib Version: " + digilibVersion;
430
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
731 document.getElementById("jsp-version").innerHTML = "JSP Version: " + jspVersion;
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
732 document.getElementById("baselib-version").innerHTML = "baseLib Version: " + baseLibVersion;
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
733 document.getElementById("dllib-version").innerHTML = "dlLib Version: " + dllibVersion;
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
734 showElement(elem, show);
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
735 }
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
736
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
737 function loadBirdImage() {
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
738 var img = getElement("bird-image");
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
739 var src = "../servlet/Scaler?"
430
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
740 + getQueryString(PARAM_FILE)
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
741 + "&dw=" + BIRD_MAXX
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
742 + "&dh=" + BIRD_MAXY;
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
743 img.src = src;
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
744 }
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
745
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
746 function showBirdDiv(show) {
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
747 // show or hide "bird's eye" div
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
748 var startPos; // anchor for dragging
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
749 var newRect; // position after drag
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
750 var birdImg = getElement("bird-image");
430
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
751 var birdArea = getElement("bird-area");
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
752 var overlay = getElement("overlay");
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
753 showElement(birdImg, show);
430
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
754 // dont show selector if area has full size
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
755 if (!show || isFullArea()) {
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
756 // hide area
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
757 showElement(birdArea, false);
430
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
758 showElement(overlay, false);
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
759 return;
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
760 };
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
761 var birdImgRect = getElementRect(birdImg);
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
762 var area = parseArea();
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
763 // scale area down to img size
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
764 var birdAreaRect = new Rectangle(
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
765 // what about borders ??
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
766 birdImgRect.x + birdImgRect.width * area.x,
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
767 birdImgRect.y + birdImgRect.height * area.y,
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
768 birdImgRect.width * area.width,
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
769 birdImgRect.height * area.height
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
770 );
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
771 moveElement(birdArea, birdAreaRect);
430
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
772 showElement(birdArea, true);
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
773 moveElement(overlay, birdImgRect);
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
774 showElement(overlay, true);
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
775 registerEvent("mousedown", overlay, birdAreaStartDrag);
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
776 registerEvent("mousedown", birdImg, birdAreaStartDrag);
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
777
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
778 function birdAreaStartDrag(evt) {
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
779 // mousedown handler: start drag
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
780 startPos = evtPosition(evt);
430
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
781 unregisterEvent("mousedown", overlay, birdAreaStartDrag);
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
782 unregisterEvent("mousedown", birdImg, birdAreaStartDrag);
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
783 registerEvent("mousemove", document, birdAreaMove);
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
784 registerEvent("mouseup", document, birdAreaEndDrag);
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
785 // debugProps(getElementRect(bird))
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
786 return stopEvent(evt);
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
787 }
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
788
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
789 function birdAreaMove(evt) {
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
790 // mousemove handler: drag
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
791 var pos = evtPosition(evt);
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
792 var dx = pos.x - startPos.x;
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
793 var dy = pos.y - startPos.y;
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
794 // move birdArea div, keeping size
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
795 newRect = new Rectangle(
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
796 birdAreaRect.x + dx,
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
797 birdAreaRect.y + dy,
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
798 birdAreaRect.width,
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
799 birdAreaRect.height);
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
800 // stay within image
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
801 newRect.stayInside(birdImgRect);
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
802 moveElement(birdArea, newRect);
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
803 showElement(birdArea, true);
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
804 return stopEvent(evt);
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
805 }
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
806
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
807 function birdAreaEndDrag(evt) {
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
808 // mouseup handler: reload page
430
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
809 unregisterEvent("mousemove", document, birdAreaMove);
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
810 unregisterEvent("mouseup", document, birdAreaEndDrag);
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
811 showElement(overlay, false);
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
812 if (newRect == null) { // no movement happened
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
813 startPos = birdAreaRect.getCenter();
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
814 birdAreaMove(evt); // set center to click position
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
815 }
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
816 setParameter("wx", cropFloat((newRect.x - birdImgRect.x) / birdImgRect.width));
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
817 setParameter("wy", cropFloat((newRect.y - birdImgRect.y) / birdImgRect.height));
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
818 // zoomed is always fit
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
819 setParameter("ws", 1);
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
820 display();
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
821 return stopEvent(evt);
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
822 }
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
823 }
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
824
425
ab2557f079fc added showArrows() function (navigation arrows overlay)
hertzhaft
parents: 412
diff changeset
825 function showArrow(name, rect, show) {
ab2557f079fc added showArrows() function (navigation arrows overlay)
hertzhaft
parents: 412
diff changeset
826 var arrow = getElement(name);
ab2557f079fc added showArrows() function (navigation arrows overlay)
hertzhaft
parents: 412
diff changeset
827 moveElement(arrow, rect);
ab2557f079fc added showArrows() function (navigation arrows overlay)
hertzhaft
parents: 412
diff changeset
828 showElement(arrow, show);
ab2557f079fc added showArrows() function (navigation arrows overlay)
hertzhaft
parents: 412
diff changeset
829 }
ab2557f079fc added showArrows() function (navigation arrows overlay)
hertzhaft
parents: 412
diff changeset
830
ab2557f079fc added showArrows() function (navigation arrows overlay)
hertzhaft
parents: 412
diff changeset
831 function showArrows() {
430
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
832 if (defined(scalerImg.complete) && !scalerImg.complete && !browserType.isN4 ) {
425
ab2557f079fc added showArrows() function (navigation arrows overlay)
hertzhaft
parents: 412
diff changeset
833 setTimeout("showArrows()", 100);
ab2557f079fc added showArrows() function (navigation arrows overlay)
hertzhaft
parents: 412
diff changeset
834 return;
ab2557f079fc added showArrows() function (navigation arrows overlay)
hertzhaft
parents: 412
diff changeset
835 }
430
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
836 var r = getElementRect(scalerImg);
425
ab2557f079fc added showArrows() function (navigation arrows overlay)
hertzhaft
parents: 412
diff changeset
837 showArrow('up',
ab2557f079fc added showArrows() function (navigation arrows overlay)
hertzhaft
parents: 412
diff changeset
838 new Rectangle(r.x, r.y, r.width, ARROW_WIDTH),
ab2557f079fc added showArrows() function (navigation arrows overlay)
hertzhaft
parents: 412
diff changeset
839 canMove(0, -1)
ab2557f079fc added showArrows() function (navigation arrows overlay)
hertzhaft
parents: 412
diff changeset
840 );
ab2557f079fc added showArrows() function (navigation arrows overlay)
hertzhaft
parents: 412
diff changeset
841 showArrow('down',
ab2557f079fc added showArrows() function (navigation arrows overlay)
hertzhaft
parents: 412
diff changeset
842 new Rectangle(r.x, r.y + r.height - ARROW_WIDTH, r.width, ARROW_WIDTH),
ab2557f079fc added showArrows() function (navigation arrows overlay)
hertzhaft
parents: 412
diff changeset
843 canMove(0, 1)
ab2557f079fc added showArrows() function (navigation arrows overlay)
hertzhaft
parents: 412
diff changeset
844 );
ab2557f079fc added showArrows() function (navigation arrows overlay)
hertzhaft
parents: 412
diff changeset
845 showArrow('left',
ab2557f079fc added showArrows() function (navigation arrows overlay)
hertzhaft
parents: 412
diff changeset
846 new Rectangle(r.x, r.y, ARROW_WIDTH, r.height),
ab2557f079fc added showArrows() function (navigation arrows overlay)
hertzhaft
parents: 412
diff changeset
847 canMove(-1, 0)
ab2557f079fc added showArrows() function (navigation arrows overlay)
hertzhaft
parents: 412
diff changeset
848 );
ab2557f079fc added showArrows() function (navigation arrows overlay)
hertzhaft
parents: 412
diff changeset
849 showArrow('right',
ab2557f079fc added showArrows() function (navigation arrows overlay)
hertzhaft
parents: 412
diff changeset
850 new Rectangle(r.x + r.width - ARROW_WIDTH, r.y, ARROW_WIDTH, r.height),
ab2557f079fc added showArrows() function (navigation arrows overlay)
hertzhaft
parents: 412
diff changeset
851 canMove(1, 0)
ab2557f079fc added showArrows() function (navigation arrows overlay)
hertzhaft
parents: 412
diff changeset
852 );
ab2557f079fc added showArrows() function (navigation arrows overlay)
hertzhaft
parents: 412
diff changeset
853 }
412
e2bc7587aee1 added constants for parameter sets;
hertzhaft
parents: 407
diff changeset
854
430
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
855 function calibrate(direction) {
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
856 // calibrate screen
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
857 var startPos; // anchor for dragging
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
858 var newRect; // position after drag
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
859 var calDiv = getElement("calibration");
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
860 var overlay = getElement("overlay");
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
861 moveElement(overlay, getWinRect());
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
862 showElement(overlay, true);
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
863 var xDir = direction == "x";
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
864 moveCenter(false);
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
865 registerEvent("mousedown", document, calibrationStartDrag);
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
866
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
867 function calibrationStartDrag(evt) {
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
868 // mousedown handler: start drag
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
869 startPos = evtPosition(evt);
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
870 unregisterEvent("mousedown", document, calibrationStartDrag);
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
871 registerEvent("mousemove", document, calibrationMove);
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
872 registerEvent("mouseup", document, calibrationEndDrag);
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
873 registerEvent("mousemove", calDiv, calibrationMove);
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
874 registerEvent("mouseup", calDiv, calibrationEndDrag);
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
875 newRect = new Rectangle(
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
876 startPos.x,
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
877 startPos.y,
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
878 xDir ? 1 : CALIBRATION_WIDTH,
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
879 xDir ? CALIBRATION_WIDTH : 1
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
880 );
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
881 // stay within image
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
882 moveElement(calDiv, newRect);
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
883 showElement(calDiv, true);
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
884 // debugProps(getElementRect(bird))
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
885 return stopEvent(evt);
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
886 }
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
887
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
888 function calibrationMove(evt) {
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
889 // mousemove handler: drag
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
890 var pos = evtPosition(evt);
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
891 var dx = (xDir) ? pos.x - startPos.x : CALIBRATION_WIDTH;
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
892 var dy = (xDir) ? CALIBRATION_WIDTH : pos.y - startPos.y;
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
893 // move birdArea div, keeping size
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
894 newRect = new Rectangle(startPos.x, startPos.y, dx, dy);
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
895 // stay within image
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
896 moveElement(calDiv, newRect);
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
897 showElement(calDiv, true);
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
898 return stopEvent(evt);
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
899 }
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
900
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
901 function calibrationEndDrag(evt) {
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
902 // mouseup handler: calibrate
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
903 unregisterEvent("mousemove", document, calibrationMove);
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
904 unregisterEvent("mouseup", document, calibrationEndDrag);
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
905 unregisterEvent("mousemove", calDiv, calibrationMove);
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
906 unregisterEvent("mouseup", calDiv, calibrationEndDrag);
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
907 showElement(calDiv, false);
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
908 showElement(overlay, false);
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
909 moveCenter(true);
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
910
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
911 // TODO: calculate ...
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
912 return stopEvent(evt);
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
913 }
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
914 }
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
915
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
916 // :tabSize=4:indentSize=4:noTabs=true:
fc5b8cade32f bug fixes;
hertzhaft
parents: 425
diff changeset
917