Mercurial > hg > orthanc-wsi
annotate ViewerPlugin/viewer.js @ 334:f011fc199b6a default tip
back to mainline
author | Sebastien Jodogne <s.jodogne@gmail.com> |
---|---|
date | Fri, 18 Oct 2024 15:44:18 +0200 |
parents | c42083d50ddf |
children |
rev | line source |
---|---|
0 | 1 /** |
2 * Orthanc - A Lightweight, RESTful DICOM Store | |
3 * Copyright (C) 2012-2016 Sebastien Jodogne, Medical Physics | |
4 * Department, University Hospital of Liege, Belgium | |
312
0683312e21ba
updated copyright, as Orthanc Team now replaces Osimis
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
309
diff
changeset
|
5 * Copyright (C) 2017-2023 Osimis S.A., Belgium |
0683312e21ba
updated copyright, as Orthanc Team now replaces Osimis
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
309
diff
changeset
|
6 * Copyright (C) 2024-2024 Orthanc Team SRL, Belgium |
309
7020852a8fa9
updated year to 2024
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
254
diff
changeset
|
7 * Copyright (C) 2021-2024 Sebastien Jodogne, ICTEAM UCLouvain, Belgium |
0 | 8 * |
9 * This program is free software: you can redistribute it and/or | |
10 * modify it under the terms of the GNU Affero General Public License | |
11 * as published by the Free Software Foundation, either version 3 of | |
12 * the License, or (at your option) any later version. | |
13 * | |
14 * This program is distributed in the hope that it will be useful, but | |
15 * WITHOUT ANY WARRANTY; without even the implied warranty of | |
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | |
17 * Affero General Public License for more details. | |
18 * | |
19 * You should have received a copy of the GNU Affero General Public License | |
20 * along with this program. If not, see <http://www.gnu.org/licenses/>. | |
21 **/ | |
22 | |
23 | |
24 // For IE compatibility | |
25 if (!window.console) window.console = {}; | |
26 if (!window.console.log) window.console.log = function () { }; | |
27 | |
28 | |
29 // http://stackoverflow.com/a/21903119/881731 | |
30 function GetUrlParameter(sParam) | |
31 { | |
32 var sPageURL = decodeURIComponent(window.location.search.substring(1)); | |
33 var sURLVariables = sPageURL.split('&'); | |
34 var sParameterName; | |
35 var i; | |
36 | |
37 for (i = 0; i < sURLVariables.length; i++) | |
38 { | |
39 sParameterName = sURLVariables[i].split('='); | |
40 | |
41 if (sParameterName[0] === sParam) | |
42 { | |
43 return sParameterName[1] === undefined ? '' : sParameterName[1]; | |
44 } | |
45 } | |
46 | |
47 return ''; | |
48 }; | |
49 | |
50 | |
51 | |
52 $(document).ready(function() { | |
53 var seriesId = GetUrlParameter('series'); | |
54 if (seriesId.length == 0) | |
55 { | |
56 alert('Error - No series ID specified!'); | |
57 } | |
58 else | |
59 { | |
60 $.ajax({ | |
61 url : '../pyramids/' + seriesId, | |
62 error: function() { | |
63 alert('Error - Cannot get the pyramid structure of series: ' + seriesId); | |
64 }, | |
65 success : function(series) { | |
330
c42083d50ddf
Added support for DICOM tag "Recommended Absent Pixel CIELab" (0048,0015)
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
312
diff
changeset
|
66 $('#map').css('background', series['BackgroundColor']); // New in WSI 2.1 |
c42083d50ddf
Added support for DICOM tag "Recommended Absent Pixel CIELab" (0048,0015)
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
312
diff
changeset
|
67 |
0 | 68 var width = series['TotalWidth']; |
69 var height = series['TotalHeight']; | |
70 var countLevels = series['Resolutions'].length; | |
71 | |
72 // Maps always need a projection, but Zoomify layers are not geo-referenced, and | |
73 // are only measured in pixels. So, we create a fake projection that the map | |
74 // can use to properly display the layer. | |
75 var proj = new ol.proj.Projection({ | |
76 code: 'pixel', | |
77 units: 'pixels', | |
78 extent: [0, 0, width, height] | |
79 }); | |
80 | |
81 var extent = [0, -height, width, 0]; | |
82 | |
83 // Disable the rotation of the map, and inertia while panning | |
84 // http://stackoverflow.com/a/25682186 | |
85 var interactions = ol.interaction.defaults({ | |
86 altShiftDragRotate : false, | |
87 pinchRotate : false, | |
88 dragPan: false | |
89 }).extend([ | |
90 new ol.interaction.DragPan({kinetic: false}) | |
91 ]); | |
92 | |
93 var layer = new ol.layer.Tile({ | |
94 extent: extent, | |
95 source: new ol.source.TileImage({ | |
96 projection: proj, | |
97 tileUrlFunction: function(tileCoord, pixelRatio, projection) { | |
98 return ('../tiles/' + seriesId + '/' + | |
99 (countLevels - 1 - tileCoord[0]) + '/' + tileCoord[1] + '/' + (-tileCoord[2] - 1)); | |
100 }, | |
101 tileGrid: new ol.tilegrid.TileGrid({ | |
102 extent: extent, | |
103 resolutions: series['Resolutions'].reverse(), | |
217
20bc074ec19a
Viewer can display DICOM pyramids whose tile sizes vary across levels
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
214
diff
changeset
|
104 tileSizes: series['TilesSizes'].reverse() |
0 | 105 }) |
106 }), | |
107 wrapX: false, | |
108 projection: proj | |
109 }); | |
110 | |
111 | |
112 var map = new ol.Map({ | |
113 target: 'map', | |
114 layers: [ layer ], | |
115 view: new ol.View({ | |
116 projection: proj, | |
117 center: [width / 2, -height / 2], | |
118 zoom: 0, | |
119 minResolution: 1 // Do not interpelate over pixels | |
120 }), | |
121 interactions: interactions | |
122 }); | |
123 | |
124 map.getView().fit(extent, map.getSize()); | |
125 } | |
126 }); | |
127 } | |
128 }); |