annotate client/digitallibrary/navigation_n6.js @ 34:84a481a388bb

first update of new client-version
author luginbue
date Thu, 21 Feb 2002 02:27:06 +0100
parents d407cb901df4
children 930413351738
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
34
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
1 // this global variable has to be initialised before the frist use of the functions below
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
2 // to fill in the attributes you can use the function init provided below
20
d407cb901df4 Initial revision
robcast
parents:
diff changeset
3 // - array with all attributes
d407cb901df4 Initial revision
robcast
parents:
diff changeset
4 var att = new Array();
d407cb901df4 Initial revision
robcast
parents:
diff changeset
5
34
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
6 // fill in the values of the "att"-array
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
7 function init(fn, pn, ws, mo, mk, wx, wy, ww, wh) {
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
8
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
9 // debug window to check the parameters passed
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
10 //alert ("DEBUG message (parameters in init):\n\npu = " + pu + "\npn = " + pn + "\nws = " + ws + "\nmo = " + mo + "\nmk = " + mk + "\nwx = " + wx + "\nwy = " + wy + "\nww = " + ww + "\nwh = " + wh);
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
11
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
12 // attaching the values to the att-array
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
13 att[0] = fn;
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
14 att[1] = parseInt(pn);
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
15 att[2] = parseFloat(ws);
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
16 att[3] = mo;
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
17 att[4] = mk;
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
18 att[5] = parseFloat(wx);
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
19 att[6] = parseFloat(wy);
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
20 att[7] = parseFloat(ww);
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
21 att[8] = parseFloat(wh);
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
22
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
23 // compatablility issue
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
24 if (att[3].indexOf("f") > -1) {
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
25 att[3] = "fit";
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
26 }
20
d407cb901df4 Initial revision
robcast
parents:
diff changeset
27
34
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
28 // converts the old mark format (0-1000) to new format(0.0 - 1.0)
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
29 // could even be useless now
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
30 if (att[4] != "0/0") {
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
31 var tmp = att[4].split(";");
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
32
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
33 att[4] = "";
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
34
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
35 for (i = 0; i < tmp.length; i++) {
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
36 tmp[i] = tmp[i].split("/");
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
37
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
38 if (tmp[i][0] > 1 && tmp[i][1] > 1) {
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
39 tmp[i][0] /= 1000;
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
40 tmp[i][1] /= 1000;
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
41 }
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
42
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
43 att[4] += tmp[i][0] + "/" + tmp[i][1] + ";";
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
44 }
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
45 att[4] = att[4].slice(0, -1);
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
46 }
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
47
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
48 // initialisation stuff
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
49 // ====================
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
50
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
51 setMarks();
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
52
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
53 this.document.addEventListener('keypress', parseKeypress, true);
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
54 focus();
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
55
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
56 // give a name to the window containing digilib - this way one can test if there is already a
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
57 // digilib-window open and replace the contents of it (ex. digicat)
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
58 top.window.name = "digilib";
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
59 }
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
60
20
d407cb901df4 Initial revision
robcast
parents:
diff changeset
61
d407cb901df4 Initial revision
robcast
parents:
diff changeset
62 // function that launches the ScaleServlet
d407cb901df4 Initial revision
robcast
parents:
diff changeset
63 // the different detailGrades:
d407cb901df4 Initial revision
robcast
parents:
diff changeset
64 // 0 -> back, next, page
d407cb901df4 Initial revision
robcast
parents:
diff changeset
65 // 1 -> zoomout
d407cb901df4 Initial revision
robcast
parents:
diff changeset
66 // 2 -> zoomarea, zoompoint, moveto, scaledef
d407cb901df4 Initial revision
robcast
parents:
diff changeset
67
d407cb901df4 Initial revision
robcast
parents:
diff changeset
68 function loadPicture(detailGrade, keepArea) {
d407cb901df4 Initial revision
robcast
parents:
diff changeset
69
34
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
70 var newURL = "dlImage.jsp?"
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
71 newURL += "fn=" + att[0] + "&pn=" + att[1] + "&ws=" + att[2] + "&mo=" + att[3];
20
d407cb901df4 Initial revision
robcast
parents:
diff changeset
72
d407cb901df4 Initial revision
robcast
parents:
diff changeset
73 if (detailGrade == 0) {
d407cb901df4 Initial revision
robcast
parents:
diff changeset
74 att[4] = "0/0";
d407cb901df4 Initial revision
robcast
parents:
diff changeset
75 }
d407cb901df4 Initial revision
robcast
parents:
diff changeset
76
d407cb901df4 Initial revision
robcast
parents:
diff changeset
77 if ((detailGrade == 1) || (detailGrade == 0 && !keepArea)) {
d407cb901df4 Initial revision
robcast
parents:
diff changeset
78 att[5] = 0;
d407cb901df4 Initial revision
robcast
parents:
diff changeset
79 att[6] = 0;
d407cb901df4 Initial revision
robcast
parents:
diff changeset
80 att[7] = 1;
d407cb901df4 Initial revision
robcast
parents:
diff changeset
81 att[8] = 1;
d407cb901df4 Initial revision
robcast
parents:
diff changeset
82 }
34
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
83
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
84 newURL += "&mk=" + att[4] + "&wx=" + att[5] + "&wy=" + att[6] + "&ww=" + att[7] + "&wh=" + att[8];
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
85 newURL += "&dw=" + (innerWidth-30) + "&dh=" + (innerHeight-30);
20
d407cb901df4 Initial revision
robcast
parents:
diff changeset
86
34
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
87 // debug window - checking the parameters passed to the next image
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
88 //alert ("DEBUG MESSAGE (complete URL in loadPicture):\n\n" + newURL);
20
d407cb901df4 Initial revision
robcast
parents:
diff changeset
89
34
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
90 location.href = newURL;
20
d407cb901df4 Initial revision
robcast
parents:
diff changeset
91 }
d407cb901df4 Initial revision
robcast
parents:
diff changeset
92
d407cb901df4 Initial revision
robcast
parents:
diff changeset
93
34
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
94 function backPage(keepArea) {
20
d407cb901df4 Initial revision
robcast
parents:
diff changeset
95
d407cb901df4 Initial revision
robcast
parents:
diff changeset
96 att[1] = parseInt(att[1]) - 1;
d407cb901df4 Initial revision
robcast
parents:
diff changeset
97
d407cb901df4 Initial revision
robcast
parents:
diff changeset
98 if (att[1] > 0) {
d407cb901df4 Initial revision
robcast
parents:
diff changeset
99 loadPicture(0, keepArea);
d407cb901df4 Initial revision
robcast
parents:
diff changeset
100 } else {
d407cb901df4 Initial revision
robcast
parents:
diff changeset
101 att[1] = parseInt(att[1]) + 1;
d407cb901df4 Initial revision
robcast
parents:
diff changeset
102 alert("You are already on the first page!");
d407cb901df4 Initial revision
robcast
parents:
diff changeset
103 }
d407cb901df4 Initial revision
robcast
parents:
diff changeset
104 }
d407cb901df4 Initial revision
robcast
parents:
diff changeset
105
d407cb901df4 Initial revision
robcast
parents:
diff changeset
106
34
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
107 function nextPage(keepArea) {
20
d407cb901df4 Initial revision
robcast
parents:
diff changeset
108
d407cb901df4 Initial revision
robcast
parents:
diff changeset
109 att[1] = parseInt(att[1]) + 1;
d407cb901df4 Initial revision
robcast
parents:
diff changeset
110
34
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
111 loadPicture(0, keepArea);
20
d407cb901df4 Initial revision
robcast
parents:
diff changeset
112 }
d407cb901df4 Initial revision
robcast
parents:
diff changeset
113
d407cb901df4 Initial revision
robcast
parents:
diff changeset
114
34
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
115 function page(keepArea) {
20
d407cb901df4 Initial revision
robcast
parents:
diff changeset
116
d407cb901df4 Initial revision
robcast
parents:
diff changeset
117 do {
34
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
118 page = prompt("Goto Page:", 1);
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
119 } while ((page != null) && (page < 1));
20
d407cb901df4 Initial revision
robcast
parents:
diff changeset
120
d407cb901df4 Initial revision
robcast
parents:
diff changeset
121 if (page != null && page != att[1]) {
d407cb901df4 Initial revision
robcast
parents:
diff changeset
122 att[1] = page;
d407cb901df4 Initial revision
robcast
parents:
diff changeset
123 loadPicture(0, keepArea);
d407cb901df4 Initial revision
robcast
parents:
diff changeset
124 }
d407cb901df4 Initial revision
robcast
parents:
diff changeset
125 }
d407cb901df4 Initial revision
robcast
parents:
diff changeset
126
d407cb901df4 Initial revision
robcast
parents:
diff changeset
127
34
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
128 function digicat() {
20
d407cb901df4 Initial revision
robcast
parents:
diff changeset
129 var url = "http://" + location.host + "/docuserver/digitallibrary/digicat.html?" + att[0] + "+" + att[1];
d407cb901df4 Initial revision
robcast
parents:
diff changeset
130 win = window.open(url, "digicat");
d407cb901df4 Initial revision
robcast
parents:
diff changeset
131 win.focus();
d407cb901df4 Initial revision
robcast
parents:
diff changeset
132 }
d407cb901df4 Initial revision
robcast
parents:
diff changeset
133
d407cb901df4 Initial revision
robcast
parents:
diff changeset
134
34
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
135 function ref(refselect) {
20
d407cb901df4 Initial revision
robcast
parents:
diff changeset
136
d407cb901df4 Initial revision
robcast
parents:
diff changeset
137 var hyperlinkRef = "http://" + location.host + "/docuserver/digitallibrary/digilib.jsp?";
d407cb901df4 Initial revision
robcast
parents:
diff changeset
138 hyperlinkRef += att[0] + "+" + att[1] + "+" + att[2] + "+" + att[3] + "+" + att[4];
d407cb901df4 Initial revision
robcast
parents:
diff changeset
139
d407cb901df4 Initial revision
robcast
parents:
diff changeset
140 if ((att[5] != 0) || (att[6] != 0) || (att[7] != 1) || (att[8] != 1)) {
d407cb901df4 Initial revision
robcast
parents:
diff changeset
141 hyperlinkRef += "+" + att[5] + "+" + att[6] + "+" + att[7] + "+" + att[8];
d407cb901df4 Initial revision
robcast
parents:
diff changeset
142 }
d407cb901df4 Initial revision
robcast
parents:
diff changeset
143
d407cb901df4 Initial revision
robcast
parents:
diff changeset
144 if (refselect == 1) {
d407cb901df4 Initial revision
robcast
parents:
diff changeset
145 prompt("Link for HTML--documents", hyperlinkRef);
d407cb901df4 Initial revision
robcast
parents:
diff changeset
146 } else {
d407cb901df4 Initial revision
robcast
parents:
diff changeset
147 prompt("Link for LaTeX--documents", "\\href{" + hyperlinkRef + "}{TEXT}");
d407cb901df4 Initial revision
robcast
parents:
diff changeset
148 }
d407cb901df4 Initial revision
robcast
parents:
diff changeset
149 }
d407cb901df4 Initial revision
robcast
parents:
diff changeset
150
d407cb901df4 Initial revision
robcast
parents:
diff changeset
151
34
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
152 function mark() {
20
d407cb901df4 Initial revision
robcast
parents:
diff changeset
153
d407cb901df4 Initial revision
robcast
parents:
diff changeset
154 if (att[4].split(";").length > 7) {
d407cb901df4 Initial revision
robcast
parents:
diff changeset
155 alert("Only 8 marks are possible at the moment!");
d407cb901df4 Initial revision
robcast
parents:
diff changeset
156 return;
d407cb901df4 Initial revision
robcast
parents:
diff changeset
157 }
d407cb901df4 Initial revision
robcast
parents:
diff changeset
158
34
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
159 function markEvent(event) {
20
d407cb901df4 Initial revision
robcast
parents:
diff changeset
160
d407cb901df4 Initial revision
robcast
parents:
diff changeset
161 if ((att[4] != "") && (att[4] != "0/0")) {
d407cb901df4 Initial revision
robcast
parents:
diff changeset
162 att[4] += ";";
d407cb901df4 Initial revision
robcast
parents:
diff changeset
163 } else {
d407cb901df4 Initial revision
robcast
parents:
diff changeset
164 att[4] = "";
d407cb901df4 Initial revision
robcast
parents:
diff changeset
165 }
d407cb901df4 Initial revision
robcast
parents:
diff changeset
166
34
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
167 var markX = cropFloat(att[5]+att[7]*(event.pageX-parseInt(document.getElementById("lay1").style.left))/document.pic.offsetWidth);
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
168 var markY = cropFloat(att[6]+att[8]*(event.pageY-parseInt(document.getElementById("lay1").style.top))/document.pic.offsetHeight);
20
d407cb901df4 Initial revision
robcast
parents:
diff changeset
169
d407cb901df4 Initial revision
robcast
parents:
diff changeset
170 att[4] += markX + "/" + markY;
d407cb901df4 Initial revision
robcast
parents:
diff changeset
171
34
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
172 document.getElementById("lay1").removeEventListener("mousedown", markEvent, true);
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
173 setMarks();
20
d407cb901df4 Initial revision
robcast
parents:
diff changeset
174 }
d407cb901df4 Initial revision
robcast
parents:
diff changeset
175
34
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
176 document.getElementById("lay1").addEventListener("mousedown", markEvent, true);
20
d407cb901df4 Initial revision
robcast
parents:
diff changeset
177 }
d407cb901df4 Initial revision
robcast
parents:
diff changeset
178
d407cb901df4 Initial revision
robcast
parents:
diff changeset
179
34
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
180 function zoomArea() {
20
d407cb901df4 Initial revision
robcast
parents:
diff changeset
181 var state = 0;
d407cb901df4 Initial revision
robcast
parents:
diff changeset
182 var x1, y1, x2, y2;
d407cb901df4 Initial revision
robcast
parents:
diff changeset
183
34
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
184 function click(event) {
20
d407cb901df4 Initial revision
robcast
parents:
diff changeset
185
d407cb901df4 Initial revision
robcast
parents:
diff changeset
186 if (state == 0) {
d407cb901df4 Initial revision
robcast
parents:
diff changeset
187 state = 1;
d407cb901df4 Initial revision
robcast
parents:
diff changeset
188
d407cb901df4 Initial revision
robcast
parents:
diff changeset
189 x1 = event.pageX;
d407cb901df4 Initial revision
robcast
parents:
diff changeset
190 y1 = event.pageY;
d407cb901df4 Initial revision
robcast
parents:
diff changeset
191 x2 = x1;
d407cb901df4 Initial revision
robcast
parents:
diff changeset
192 y2 = y1;
d407cb901df4 Initial revision
robcast
parents:
diff changeset
193
34
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
194 document.getElementById("eck1").style.left = x1;
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
195 document.getElementById("eck1").style.top = y1;
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
196 document.getElementById("eck2").style.left = x2-12;
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
197 document.getElementById("eck2").style.top = y1;
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
198 document.getElementById("eck3").style.left = x1;
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
199 document.getElementById("eck3").style.top = y2-12;
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
200 document.getElementById("eck4").style.left = x2-12;
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
201 document.getElementById("eck4").style.top = y2-12;
20
d407cb901df4 Initial revision
robcast
parents:
diff changeset
202
34
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
203 document.getElementById("eck1").style.visibility="visible";
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
204 document.getElementById("eck2").style.visibility="visible";
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
205 document.getElementById("eck3").style.visibility="visible";
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
206 document.getElementById("eck4").style.visibility="visible";
20
d407cb901df4 Initial revision
robcast
parents:
diff changeset
207
34
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
208 document.getElementById("lay1").addEventListener("mousemove", move, true);
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
209 document.getElementById("eck4").addEventListener("mousemove", move, true);
20
d407cb901df4 Initial revision
robcast
parents:
diff changeset
210
d407cb901df4 Initial revision
robcast
parents:
diff changeset
211 } else {
d407cb901df4 Initial revision
robcast
parents:
diff changeset
212
34
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
213 x1 -= parseInt(document.getElementById("lay1").style.left);
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
214 y1 -= parseInt(document.getElementById("lay1").style.top);
20
d407cb901df4 Initial revision
robcast
parents:
diff changeset
215
34
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
216 x2 = event.pageX-parseInt(document.getElementById("lay1").style.left);
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
217 y2 = event.pageY-parseInt(document.getElementById("lay1").style.top);
20
d407cb901df4 Initial revision
robcast
parents:
diff changeset
218
34
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
219 document.getElementById("lay1").removeEventListener("mousedown", click, true);
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
220 document.getElementById("eck4").removeEventListener("mousedown", click, true);
20
d407cb901df4 Initial revision
robcast
parents:
diff changeset
221
34
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
222 document.getElementById("lay1").removeEventListener("mousemove", move, true);
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
223 document.getElementById("eck4").removeEventListener("mousemove", move, true);
20
d407cb901df4 Initial revision
robcast
parents:
diff changeset
224
34
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
225 document.getElementById("eck1").style.visibility="hidden";
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
226 document.getElementById("eck2").style.visibility="hidden";
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
227 document.getElementById("eck3").style.visibility="hidden";
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
228 document.getElementById("eck4").style.visibility="hidden";
20
d407cb901df4 Initial revision
robcast
parents:
diff changeset
229
34
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
230 att[5] = cropFloat(att[5]+att[7]*((x1 < x2) ? x1 : x2)/document.pic.offsetWidth);
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
231 att[6] = cropFloat(att[6]+att[8]*((y1 < y2) ? y1 : y2)/document.pic.offsetHeight);
20
d407cb901df4 Initial revision
robcast
parents:
diff changeset
232
34
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
233 att[7] = cropFloat(att[7]*Math.abs(x1-x2)/document.pic.offsetWidth);
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
234 att[8] = cropFloat(att[8]*Math.abs(y1-y2)/document.pic.offsetHeight);
20
d407cb901df4 Initial revision
robcast
parents:
diff changeset
235
d407cb901df4 Initial revision
robcast
parents:
diff changeset
236 if (att[7] != 0 && att[8] != 0) {
d407cb901df4 Initial revision
robcast
parents:
diff changeset
237 loadPicture(2);
d407cb901df4 Initial revision
robcast
parents:
diff changeset
238 }
d407cb901df4 Initial revision
robcast
parents:
diff changeset
239 }
d407cb901df4 Initial revision
robcast
parents:
diff changeset
240 }
d407cb901df4 Initial revision
robcast
parents:
diff changeset
241
34
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
242 function move(event) {
20
d407cb901df4 Initial revision
robcast
parents:
diff changeset
243
d407cb901df4 Initial revision
robcast
parents:
diff changeset
244 x2 = event.pageX;
d407cb901df4 Initial revision
robcast
parents:
diff changeset
245 y2 = event.pageY;
d407cb901df4 Initial revision
robcast
parents:
diff changeset
246
34
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
247 document.getElementById("eck1").style.left = ((x1 < x2) ? x1 : x2);
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
248 document.getElementById("eck1").style.top = ((y1 < y2) ? y1 : y2);
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
249 document.getElementById("eck2").style.left = ((x1 < x2) ? x2 : x1)-12;
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
250 document.getElementById("eck2").style.top = ((y1 < y2) ? y1 : y2);
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
251 document.getElementById("eck3").style.left = ((x1 < x2) ? x1 : x2);
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
252 document.getElementById("eck3").style.top = ((y1 < y2) ? y2 : y1)-12;
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
253 document.getElementById("eck4").style.left = ((x1 < x2) ? x2 : x1)-12;
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
254 document.getElementById("eck4").style.top = ((y1 < y2) ? y2 : y1)-12;
20
d407cb901df4 Initial revision
robcast
parents:
diff changeset
255 }
d407cb901df4 Initial revision
robcast
parents:
diff changeset
256
34
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
257 document.getElementById("lay1").addEventListener("mousedown", click, true);
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
258 document.getElementById("eck4").addEventListener("mousedown", click, true);
20
d407cb901df4 Initial revision
robcast
parents:
diff changeset
259 }
d407cb901df4 Initial revision
robcast
parents:
diff changeset
260
d407cb901df4 Initial revision
robcast
parents:
diff changeset
261
34
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
262 function zoomPoint() {
20
d407cb901df4 Initial revision
robcast
parents:
diff changeset
263
34
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
264 function zoomPointEvent(event) {
20
d407cb901df4 Initial revision
robcast
parents:
diff changeset
265
34
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
266 att[5] = cropFloat(att[5]+att[7]*(event.pageX-parseInt(document.getElementById("lay1").style.left))/document.pic.offsetWidth-0.5*att[7]*0.7);
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
267 att[6] = cropFloat(att[6]+att[8]*(event.pageY-parseInt(document.getElementById("lay1").style.top))/document.pic.offsetHeight-0.5*att[8]*0.7);
20
d407cb901df4 Initial revision
robcast
parents:
diff changeset
268
d407cb901df4 Initial revision
robcast
parents:
diff changeset
269 att[7] = cropFloat(att[7]*0.7);
d407cb901df4 Initial revision
robcast
parents:
diff changeset
270 att[8] = cropFloat(att[8]*0.7);
d407cb901df4 Initial revision
robcast
parents:
diff changeset
271
d407cb901df4 Initial revision
robcast
parents:
diff changeset
272 if (att[5] < 0) {
d407cb901df4 Initial revision
robcast
parents:
diff changeset
273 att[5] = 0;
d407cb901df4 Initial revision
robcast
parents:
diff changeset
274 }
d407cb901df4 Initial revision
robcast
parents:
diff changeset
275 if (att[6] < 0) {
d407cb901df4 Initial revision
robcast
parents:
diff changeset
276 att[6] = 0;
d407cb901df4 Initial revision
robcast
parents:
diff changeset
277 }
d407cb901df4 Initial revision
robcast
parents:
diff changeset
278 if (att[5]+att[7] > 1) {
d407cb901df4 Initial revision
robcast
parents:
diff changeset
279 att[5] = 1-att[7];
d407cb901df4 Initial revision
robcast
parents:
diff changeset
280 }
d407cb901df4 Initial revision
robcast
parents:
diff changeset
281 if (att[6]+att[8] > 1) {
d407cb901df4 Initial revision
robcast
parents:
diff changeset
282 att[6] = 1-att[8];
d407cb901df4 Initial revision
robcast
parents:
diff changeset
283 }
d407cb901df4 Initial revision
robcast
parents:
diff changeset
284
34
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
285 document.getElementById("lay1").removeEventListener("mousedown", zoomPointEvent, true);
20
d407cb901df4 Initial revision
robcast
parents:
diff changeset
286
d407cb901df4 Initial revision
robcast
parents:
diff changeset
287 loadPicture(2);
d407cb901df4 Initial revision
robcast
parents:
diff changeset
288 }
d407cb901df4 Initial revision
robcast
parents:
diff changeset
289
34
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
290 document.getElementById("lay1").addEventListener("mousedown", zoomPointEvent, true);
20
d407cb901df4 Initial revision
robcast
parents:
diff changeset
291 }
d407cb901df4 Initial revision
robcast
parents:
diff changeset
292
d407cb901df4 Initial revision
robcast
parents:
diff changeset
293
34
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
294 function zoomOut() {
20
d407cb901df4 Initial revision
robcast
parents:
diff changeset
295
d407cb901df4 Initial revision
robcast
parents:
diff changeset
296 loadPicture(1);
d407cb901df4 Initial revision
robcast
parents:
diff changeset
297 }
d407cb901df4 Initial revision
robcast
parents:
diff changeset
298
d407cb901df4 Initial revision
robcast
parents:
diff changeset
299
34
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
300 function moveTo() {
20
d407cb901df4 Initial revision
robcast
parents:
diff changeset
301
34
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
302 function moveToEvent(event) {
20
d407cb901df4 Initial revision
robcast
parents:
diff changeset
303
34
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
304 att[5] = cropFloat(att[5]+att[7]*(event.pageX-parseInt(document.getElementById("lay1").style.left))/document.pic.offsetWidth-0.5*att[7]);
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
305 att[6] = cropFloat(att[6]+att[8]*(event.pageY-parseInt(document.getElementById("lay1").style.top))/document.pic.offsetHeight-0.5*att[8]);
20
d407cb901df4 Initial revision
robcast
parents:
diff changeset
306
d407cb901df4 Initial revision
robcast
parents:
diff changeset
307 if (att[5] < 0) {
d407cb901df4 Initial revision
robcast
parents:
diff changeset
308 att[5] = 0;
d407cb901df4 Initial revision
robcast
parents:
diff changeset
309 }
d407cb901df4 Initial revision
robcast
parents:
diff changeset
310 if (att[6] < 0) {
d407cb901df4 Initial revision
robcast
parents:
diff changeset
311 att[6] = 0;
d407cb901df4 Initial revision
robcast
parents:
diff changeset
312 }
d407cb901df4 Initial revision
robcast
parents:
diff changeset
313 if (att[5]+att[7] > 1) {
d407cb901df4 Initial revision
robcast
parents:
diff changeset
314 att[5] = 1-att[7];
d407cb901df4 Initial revision
robcast
parents:
diff changeset
315 }
d407cb901df4 Initial revision
robcast
parents:
diff changeset
316 if (att[6]+att[8] > 1) {
d407cb901df4 Initial revision
robcast
parents:
diff changeset
317 att[6] = 1-att[8];
d407cb901df4 Initial revision
robcast
parents:
diff changeset
318 }
d407cb901df4 Initial revision
robcast
parents:
diff changeset
319
34
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
320 document.getElementById("lay1").removeEventListener("mousedown", moveToEvent, true);
20
d407cb901df4 Initial revision
robcast
parents:
diff changeset
321
d407cb901df4 Initial revision
robcast
parents:
diff changeset
322 loadPicture(2);
d407cb901df4 Initial revision
robcast
parents:
diff changeset
323 }
d407cb901df4 Initial revision
robcast
parents:
diff changeset
324
34
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
325 document.getElementById("lay1").addEventListener("mousedown", moveToEvent, true);
20
d407cb901df4 Initial revision
robcast
parents:
diff changeset
326 }
d407cb901df4 Initial revision
robcast
parents:
diff changeset
327
d407cb901df4 Initial revision
robcast
parents:
diff changeset
328
34
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
329 function scale(scaledef) {
20
d407cb901df4 Initial revision
robcast
parents:
diff changeset
330
d407cb901df4 Initial revision
robcast
parents:
diff changeset
331 att[2] = scaledef;
d407cb901df4 Initial revision
robcast
parents:
diff changeset
332 loadPicture(2);
d407cb901df4 Initial revision
robcast
parents:
diff changeset
333 }
d407cb901df4 Initial revision
robcast
parents:
diff changeset
334
d407cb901df4 Initial revision
robcast
parents:
diff changeset
335
34
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
336 function setMarks() {
20
d407cb901df4 Initial revision
robcast
parents:
diff changeset
337
d407cb901df4 Initial revision
robcast
parents:
diff changeset
338 if (att[4] != "" && att[4] != "0/0") {
d407cb901df4 Initial revision
robcast
parents:
diff changeset
339 var mark = att[4].split(";");
d407cb901df4 Initial revision
robcast
parents:
diff changeset
340
d407cb901df4 Initial revision
robcast
parents:
diff changeset
341 var countMarks = mark.length;
d407cb901df4 Initial revision
robcast
parents:
diff changeset
342
d407cb901df4 Initial revision
robcast
parents:
diff changeset
343 // maximum of marks is 8
d407cb901df4 Initial revision
robcast
parents:
diff changeset
344 // we do not report this error because this is already done in func. "Mark"
d407cb901df4 Initial revision
robcast
parents:
diff changeset
345 if (countMarks > 8) countMarks = 8;
d407cb901df4 Initial revision
robcast
parents:
diff changeset
346
34
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
347 var picWidth = document.pic.offsetWidth;
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
348 var picHeight = document.pic.offsetHeight;
20
d407cb901df4 Initial revision
robcast
parents:
diff changeset
349
d407cb901df4 Initial revision
robcast
parents:
diff changeset
350 // catch the cases where the picture had not been loaded already and
d407cb901df4 Initial revision
robcast
parents:
diff changeset
351 // make a timeout so that the coordinates are calculated with the real dimensions
34
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
352 if (document.pic.complete) {
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
353 var xoffset = parseInt(document.getElementById("lay1").style.left);
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
354 var yoffset = parseInt(document.getElementById("lay1").style.top);
20
d407cb901df4 Initial revision
robcast
parents:
diff changeset
355
d407cb901df4 Initial revision
robcast
parents:
diff changeset
356 for (var i = 0; i < countMarks; i++) {
d407cb901df4 Initial revision
robcast
parents:
diff changeset
357 mark[i] = mark[i].split("/");
d407cb901df4 Initial revision
robcast
parents:
diff changeset
358
d407cb901df4 Initial revision
robcast
parents:
diff changeset
359 if ((mark[i][0] > att[5]) && (mark[i][1] > att[6]) && (mark[i][0] < (att[5]+att[7])) && (mark[i][1] < (att[6]+att[8]))) {
d407cb901df4 Initial revision
robcast
parents:
diff changeset
360
d407cb901df4 Initial revision
robcast
parents:
diff changeset
361 mark[i][0] = parseInt(xoffset+picWidth*(mark[i][0]-att[5])/att[7]);
d407cb901df4 Initial revision
robcast
parents:
diff changeset
362 mark[i][1] = parseInt(yoffset+picHeight*(mark[i][1]-att[6])/att[8]);
d407cb901df4 Initial revision
robcast
parents:
diff changeset
363
d407cb901df4 Initial revision
robcast
parents:
diff changeset
364
34
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
365 document.getElementById("dot" + i).style.left = mark[i][0]-5;
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
366 document.getElementById("dot" + i).style.top = mark[i][1]-5;
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
367 document.getElementById("dot" + i).style.visibility = "visible";
20
d407cb901df4 Initial revision
robcast
parents:
diff changeset
368 }
d407cb901df4 Initial revision
robcast
parents:
diff changeset
369 }
d407cb901df4 Initial revision
robcast
parents:
diff changeset
370 } else {
34
84a481a388bb first update of new client-version
luginbue
parents: 20
diff changeset
371 setTimeout("setMarks()", 100);
20
d407cb901df4 Initial revision
robcast
parents:
diff changeset
372 }
d407cb901df4 Initial revision
robcast
parents:
diff changeset
373 }
d407cb901df4 Initial revision
robcast
parents:
diff changeset
374 }
d407cb901df4 Initial revision
robcast
parents:
diff changeset
375
d407cb901df4 Initial revision
robcast
parents:
diff changeset
376 // capturing keypresses for next and previous page
d407cb901df4 Initial revision
robcast
parents:
diff changeset
377 // ascii-values of n = 110, b = 98
d407cb901df4 Initial revision
robcast
parents:
diff changeset
378 function parseKeypress (event) {
d407cb901df4 Initial revision
robcast
parents:
diff changeset
379 if (event.charCode == 110) {
d407cb901df4 Initial revision
robcast
parents:
diff changeset
380 Nextpage();
d407cb901df4 Initial revision
robcast
parents:
diff changeset
381 }
d407cb901df4 Initial revision
robcast
parents:
diff changeset
382 if (event.charCode == 98) {
d407cb901df4 Initial revision
robcast
parents:
diff changeset
383 Backpage();
d407cb901df4 Initial revision
robcast
parents:
diff changeset
384 }
d407cb901df4 Initial revision
robcast
parents:
diff changeset
385 }
d407cb901df4 Initial revision
robcast
parents:
diff changeset
386
d407cb901df4 Initial revision
robcast
parents:
diff changeset
387
d407cb901df4 Initial revision
robcast
parents:
diff changeset
388 // auxiliary function to crop senseless precicsion
d407cb901df4 Initial revision
robcast
parents:
diff changeset
389 function cropFloat(tmp) {
d407cb901df4 Initial revision
robcast
parents:
diff changeset
390 return parseInt(10000*tmp)/10000;
d407cb901df4 Initial revision
robcast
parents:
diff changeset
391 }