@mapcatch/util 1.0.9 → 1.0.10-a

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (70) hide show
  1. package/CHANGELOG.md +8 -1
  2. package/dist/catchUtil.min.esm.js +9906 -10852
  3. package/dist/catchUtil.min.js +25 -27
  4. package/package.json +1 -2
  5. package/src/constants/bmap_types.js +2 -2
  6. package/src/constants/crs_types.js +22 -0
  7. package/src/constants/default_layers.js +9 -9
  8. package/src/constants/index.js +3 -2
  9. package/src/constants/layer_folders.js +4 -4
  10. package/src/constants/measurement_fields.js +198 -0
  11. package/src/gl-operations/shaders/fragment/convertDem.js +2 -2
  12. package/src/gl-operations/shaders/fragment/convolutionSmooth.js +2 -2
  13. package/src/gl-operations/shaders/fragment/diffCalc.js +2 -2
  14. package/src/gl-operations/shaders/fragment/drawResult.js +2 -2
  15. package/src/gl-operations/shaders/fragment/hillshading/hsAdvAmbientShadows.js +2 -2
  16. package/src/gl-operations/shaders/fragment/hillshading/hsAdvFinalBaselayer.js +2 -2
  17. package/src/gl-operations/shaders/fragment/hillshading/hsAdvNormals.js +2 -2
  18. package/src/gl-operations/shaders/fragment/hillshading/hsAdvSoftShadows.js +2 -2
  19. package/src/gl-operations/shaders/fragment/interpolateColor.js +2 -2
  20. package/src/gl-operations/shaders/fragment/interpolateColorOnly.js +2 -2
  21. package/src/gl-operations/shaders/fragment/interpolateValue.js +2 -2
  22. package/src/gl-operations/shaders/fragment/multiAnalyze1Calc.js +2 -2
  23. package/src/gl-operations/shaders/fragment/multiAnalyze2Calc.js +2 -2
  24. package/src/gl-operations/shaders/fragment/multiAnalyze3Calc.js +2 -2
  25. package/src/gl-operations/shaders/fragment/multiAnalyze4Calc.js +2 -2
  26. package/src/gl-operations/shaders/fragment/multiAnalyze5Calc.js +2 -2
  27. package/src/gl-operations/shaders/fragment/multiAnalyze6Calc.js +2 -2
  28. package/src/gl-operations/shaders/vertex/double.js +2 -2
  29. package/src/gl-operations/shaders/vertex/multi3.js +2 -2
  30. package/src/gl-operations/shaders/vertex/multi4.js +2 -2
  31. package/src/gl-operations/shaders/vertex/multi5.js +2 -2
  32. package/src/gl-operations/shaders/vertex/multi6.js +2 -2
  33. package/src/gl-operations/shaders/vertex/singleNotTransformed.js +2 -2
  34. package/src/index.js +0 -2
  35. package/src/util.js +31 -51
  36. package/src/constants/map_view_mode.js +0 -10
  37. package/src/exif/exif.js +0 -37
  38. package/src/exif/gps_tags.js +0 -33
  39. package/src/exif/ifd1_tags.js +0 -22
  40. package/src/exif/index.js +0 -33
  41. package/src/exif/iptc_field_map.js +0 -12
  42. package/src/exif/parse_image.js +0 -445
  43. package/src/exif/string_values.js +0 -137
  44. package/src/exif/tags.js +0 -75
  45. package/src/exif/tiff_tags.js +0 -35
  46. package/src/exif/util.js +0 -108
  47. package/src/image-size/detector.js +0 -24
  48. package/src/image-size/fromFile.js +0 -55
  49. package/src/image-size/index.js +0 -2
  50. package/src/image-size/lookup.js +0 -37
  51. package/src/image-size/types/bmp.js +0 -10
  52. package/src/image-size/types/cur.js +0 -16
  53. package/src/image-size/types/dds.js +0 -10
  54. package/src/image-size/types/gif.js +0 -11
  55. package/src/image-size/types/heif.js +0 -35
  56. package/src/image-size/types/icns.js +0 -112
  57. package/src/image-size/types/ico.js +0 -74
  58. package/src/image-size/types/index.js +0 -43
  59. package/src/image-size/types/j2c.js +0 -11
  60. package/src/image-size/types/jp2.js +0 -22
  61. package/src/image-size/types/jpg.js +0 -157
  62. package/src/image-size/types/ktx.js +0 -18
  63. package/src/image-size/types/png.js +0 -36
  64. package/src/image-size/types/pnm.js +0 -74
  65. package/src/image-size/types/psd.js +0 -10
  66. package/src/image-size/types/svg.js +0 -100
  67. package/src/image-size/types/tga.js +0 -14
  68. package/src/image-size/types/tiff.js +0 -92
  69. package/src/image-size/types/utils.js +0 -83
  70. package/src/image-size/types/webp.js +0 -67
package/src/exif/exif.js DELETED
@@ -1,37 +0,0 @@
1
- import util from './util'
2
-
3
- export const getTag = function (img, tag) {
4
- if (!util.imageHasData(img)) return;
5
- return img.exifdata[tag];
6
- }
7
-
8
- export const getIptcTag = function (img, tag) {
9
- if (!util.imageHasData(img)) return;
10
- return img.iptcdata[tag];
11
- }
12
-
13
- export const getAllTags = function (img) {
14
- if (!util.imageHasData(img)) return {};
15
- var a,
16
- data = img.exifdata,
17
- tags = {};
18
- for (a in data) {
19
- if (data.hasOwnProperty(a)) {
20
- tags[a] = data[a];
21
- }
22
- }
23
- return tags;
24
- }
25
-
26
- export const getAllIptcTags = function (img) {
27
- if (!imageHasData(img)) return {};
28
- var a,
29
- data = img.iptcdata,
30
- tags = {};
31
- for (a in data) {
32
- if (data.hasOwnProperty(a)) {
33
- tags[a] = data[a];
34
- }
35
- }
36
- return tags;
37
- }
@@ -1,33 +0,0 @@
1
- export default {
2
- 0x0000: "GPSVersionID",
3
- 0x0001: "GPSLatitudeRef",
4
- 0x0002: "GPSLatitude",
5
- 0x0003: "GPSLongitudeRef",
6
- 0x0004: "GPSLongitude",
7
- 0x0005: "GPSAltitudeRef",
8
- 0x0006: "GPSAltitude",
9
- 0x0007: "GPSTimeStamp",
10
- 0x0008: "GPSSatellites",
11
- 0x0009: "GPSStatus",
12
- 0x000A: "GPSMeasureMode",
13
- 0x000B: "GPSDOP",
14
- 0x000C: "GPSSpeedRef",
15
- 0x000D: "GPSSpeed",
16
- 0x000E: "GPSTrackRef",
17
- 0x000F: "GPSTrack",
18
- 0x0010: "GPSImgDirectionRef",
19
- 0x0011: "GPSImgDirection",
20
- 0x0012: "GPSMapDatum",
21
- 0x0013: "GPSDestLatitudeRef",
22
- 0x0014: "GPSDestLatitude",
23
- 0x0015: "GPSDestLongitudeRef",
24
- 0x0016: "GPSDestLongitude",
25
- 0x0017: "GPSDestBearingRef",
26
- 0x0018: "GPSDestBearing",
27
- 0x0019: "GPSDestDistanceRef",
28
- 0x001A: "GPSDestDistance",
29
- 0x001B: "GPSProcessingMethod",
30
- 0x001C: "GPSAreaInformation",
31
- 0x001D: "GPSDateStamp",
32
- 0x001E: "GPSDifferential"
33
- };
@@ -1,22 +0,0 @@
1
- export default {
2
- 0x0100: "ImageWidth",
3
- 0x0101: "ImageHeight",
4
- 0x0102: "BitsPerSample",
5
- 0x0103: "Compression",
6
- 0x0106: "PhotometricInterpretation",
7
- 0x0111: "StripOffsets",
8
- 0x0112: "Orientation",
9
- 0x0115: "SamplesPerPixel",
10
- 0x0116: "RowsPerStrip",
11
- 0x0117: "StripByteCounts",
12
- 0x011A: "XResolution",
13
- 0x011B: "YResolution",
14
- 0x011C: "PlanarConfiguration",
15
- 0x0128: "ResolutionUnit",
16
- 0x0201: "JpegIFOffset", // When image format is JPEG, this value show offset to JPEG data stored.(aka "ThumbnailOffset" or "JPEGInterchangeFormat")
17
- 0x0202: "JpegIFByteCount", // When image format is JPEG, this value shows data size of JPEG image (aka "ThumbnailLength" or "JPEGInterchangeFormatLength")
18
- 0x0211: "YCbCrCoefficients",
19
- 0x0212: "YCbCrSubSampling",
20
- 0x0213: "YCbCrPositioning",
21
- 0x0214: "ReferenceBlackWhite"
22
- };
package/src/exif/index.js DELETED
@@ -1,33 +0,0 @@
1
- import {getData} from './parse_image'
2
- import {getAllTags} from './exif'
3
- import {imageSize} from '../image-size'
4
-
5
- export const getPhotoTags = (file) => {
6
- return new Promise((resolve, reject) => {
7
- if (file.type === 'image/jpeg') {
8
- let sliceFile = file.slice(0, 524288)
9
- sliceFile.name = file.name
10
- getData(sliceFile, function (img, err) {
11
- if (err) {
12
- reject(err)
13
- return
14
- }
15
- let info = getAllTags(img)
16
- let exif = JSON.parse(JSON.stringify(info).replaceAll('\\u0000', '')) || {}
17
- resolve(exif)
18
- })
19
- } else {
20
- var fileReader = new FileReader();
21
- fileReader.onload = function (e) {
22
- let u8array = new Uint8Array(e.target.result)
23
- let size = imageSize(u8array)
24
- resolve({
25
- PixelXDimension: size.width,
26
- PixelYDimension: size.height
27
- })
28
- };
29
-
30
- fileReader.readAsArrayBuffer(file);
31
- }
32
- })
33
- }
@@ -1,12 +0,0 @@
1
- export default {
2
- 0x78: 'caption',
3
- 0x6E: 'credit',
4
- 0x19: 'keywords',
5
- 0x37: 'dateCreated',
6
- 0x50: 'byline',
7
- 0x55: 'bylineTitle',
8
- 0x7A: 'captionWriter',
9
- 0x69: 'headline',
10
- 0x74: 'copyright',
11
- 0x0F: 'category'
12
- };
@@ -1,445 +0,0 @@
1
- import util from './util'
2
- import TiffTags from './tiff_tags'
3
- import ExifTags from './tags'
4
- import StringValues from './string_values'
5
- import GPSTags from './gps_tags'
6
- import IptcFieldMap from './iptc_field_map'
7
- import {imageSize} from '../image-size'
8
-
9
- var isXmpEnabled = false
10
-
11
- export const getData = function (img, callback) {
12
- if (((self.Image && img instanceof self.Image)
13
- || (self.HTMLImageElement && img instanceof self.HTMLImageElement))
14
- && !img.complete) {
15
- callback(null, new Error('不支持的格式'))
16
- return false;
17
- }
18
-
19
-
20
- if (!util.imageHasData(img)) {
21
- getImageData(img, callback);
22
- } else {
23
- if (callback) {
24
- callback(img);
25
- }
26
- }
27
- return true;
28
- }
29
-
30
- function getImageData(img, callback) {
31
- function handleBinaryFile(binFile) {
32
- try {
33
- var data = findEXIFinJPEG(binFile);
34
- img.exifdata = data || {};
35
- // var iptcdata = findIPTCinJPEG(binFile);
36
- // img.iptcdata = iptcdata || {};
37
- if (isXmpEnabled) {
38
- var xmpdata = findXMPinJPEG(binFile);
39
- img.xmpdata = xmpdata || {};
40
- }
41
- if (callback) {
42
- callback(img);
43
- }
44
- } catch (err) {
45
- callback(null, err)
46
- }
47
- }
48
-
49
- if (img.src) {
50
- if (/^data\:/i.test(img.src)) { // Data URI
51
- var arrayBuffer = util.base64ToArrayBuffer(img.src);
52
- handleBinaryFile(arrayBuffer);
53
-
54
- } else if (/^blob\:/i.test(img.src)) { // Object URL
55
- var fileReader = new FileReader();
56
- fileReader.onload = function (e) {
57
- handleBinaryFile(e.target.result);
58
- };
59
- util.objectURLToBlob(img.src, function (blob) {
60
- fileReader.readAsArrayBuffer(blob);
61
- });
62
- } else {
63
- var http = new XMLHttpRequest();
64
- http.onload = function () {
65
- if (this.status == 200 || this.status === 0) {
66
- handleBinaryFile(http.response);
67
- } else {
68
- throw "Could not load image";
69
- }
70
- http = null;
71
- };
72
- http.open("GET", img.src, true);
73
- http.responseType = "arraybuffer";
74
- http.send(null);
75
- }
76
- } else if (self.FileReader && (img instanceof self.Blob || img instanceof self.File)) {
77
- var fileReader = new FileReader();
78
- fileReader.onload = function (e) {
79
- handleBinaryFile(e.target.result);
80
- };
81
-
82
- fileReader.readAsArrayBuffer(img);
83
- }
84
- }
85
-
86
- function findEXIFinJPEG(file) {
87
- var dataView = new DataView(file);
88
- let exif = {}
89
-
90
- var offset = 2,
91
- length = file.byteLength,
92
- marker;
93
-
94
- while (offset < length) {
95
- if (dataView.getUint8(offset) != 0xFF) {
96
- break
97
- }
98
-
99
- marker = dataView.getUint8(offset + 1);
100
-
101
- // we could implement handling for other markers here,
102
- // but we're only looking for 0xFFE1 for EXIF data
103
-
104
- if (marker == 225) {
105
- exif = readEXIFData(dataView, offset + 4, dataView.getUint16(offset + 2) - 2)
106
- break
107
- }
108
- offset += 2 + dataView.getUint16(offset + 2);
109
- }
110
- let size = imageSize(new Uint8Array(file))
111
- Object.assign(exif, {
112
- PixelXDimension: size.width,
113
- PixelYDimension: size.height
114
- })
115
- return exif
116
-
117
- }
118
-
119
- function findIPTCinJPEG(file) {
120
- var dataView = new DataView(file);
121
-
122
- if ((dataView.getUint8(0) != 0xFF) || (dataView.getUint8(1) != 0xD8)) {
123
- return false; // not a valid jpeg
124
- }
125
-
126
- var offset = 2,
127
- length = file.byteLength;
128
-
129
-
130
- var isFieldSegmentStart = function (dataView, offset) {
131
- return (
132
- dataView.getUint8(offset) === 0x38 &&
133
- dataView.getUint8(offset + 1) === 0x42 &&
134
- dataView.getUint8(offset + 2) === 0x49 &&
135
- dataView.getUint8(offset + 3) === 0x4D &&
136
- dataView.getUint8(offset + 4) === 0x04 &&
137
- dataView.getUint8(offset + 5) === 0x04
138
- );
139
- };
140
-
141
- while (offset < length) {
142
-
143
- if (isFieldSegmentStart(dataView, offset)) {
144
-
145
- // Get the length of the name header (which is padded to an even number of bytes)
146
- var nameHeaderLength = dataView.getUint8(offset + 7);
147
- if (nameHeaderLength % 2 !== 0) nameHeaderLength += 1;
148
- // Check for pre photoshop 6 format
149
- if (nameHeaderLength === 0) {
150
- // Always 4
151
- nameHeaderLength = 4;
152
- }
153
-
154
- var startOffset = offset + 8 + nameHeaderLength;
155
- var sectionLength = dataView.getUint16(offset + 6 + nameHeaderLength);
156
-
157
- return readIPTCData(file, startOffset, sectionLength);
158
-
159
- }
160
- // Not the marker, continue searching
161
- offset++;
162
-
163
- }
164
- }
165
-
166
- function findXMPinJPEG(file) {
167
-
168
- if (!('DOMParser' in self)) {
169
- // console.warn('XML parsing not supported without DOMParser');
170
- return;
171
- }
172
- var dataView = new DataView(file);
173
-
174
- if ((dataView.getUint8(0) != 0xFF) || (dataView.getUint8(1) != 0xD8)) {
175
- return false; // not a valid jpeg
176
- }
177
-
178
- var offset = 2,
179
- length = file.byteLength,
180
- dom = new DOMParser();
181
-
182
- while (offset < (length - 4)) {
183
- if (util.getStringFromDB(dataView, offset, 4) == "http") {
184
- var startOffset = offset - 1;
185
- var sectionLength = dataView.getUint16(offset - 2) - 1;
186
- var xmpString = util.getStringFromDB(dataView, startOffset, sectionLength)
187
- var xmpEndIndex = xmpString.indexOf('xmpmeta>') + 8;
188
- xmpString = xmpString.substring(xmpString.indexOf('<x:xmpmeta'), xmpEndIndex);
189
-
190
- var indexOfXmp = xmpString.indexOf('x:xmpmeta') + 10
191
- //Many custom written programs embed xmp/xml without any namespace. Following are some of them.
192
- //Without these namespaces, XML is thought to be invalid by parsers
193
- xmpString = xmpString.slice(0, indexOfXmp)
194
- + 'xmlns:Iptc4xmpCore="http://iptc.org/std/Iptc4xmpCore/1.0/xmlns/" '
195
- + 'xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" '
196
- + 'xmlns:tiff="http://ns.adobe.com/tiff/1.0/" '
197
- + 'xmlns:plus="http://schemas.android.com/apk/lib/com.google.android.gms.plus" '
198
- + 'xmlns:ext="http://www.gettyimages.com/xsltExtension/1.0" '
199
- + 'xmlns:exif="http://ns.adobe.com/exif/1.0/" '
200
- + 'xmlns:stEvt="http://ns.adobe.com/xap/1.0/sType/ResourceEvent#" '
201
- + 'xmlns:stRef="http://ns.adobe.com/xap/1.0/sType/ResourceRef#" '
202
- + 'xmlns:crs="http://ns.adobe.com/camera-raw-settings/1.0/" '
203
- + 'xmlns:xapGImg="http://ns.adobe.com/xap/1.0/g/img/" '
204
- + 'xmlns:Iptc4xmpExt="http://iptc.org/std/Iptc4xmpExt/2008-02-29/" '
205
- + xmpString.slice(indexOfXmp)
206
-
207
- var domDocument = dom.parseFromString(xmpString, 'text/xml');
208
- return util.xml2Object(domDocument);
209
- } else {
210
- offset++;
211
- }
212
- }
213
- }
214
-
215
- function readEXIFData(file, start) {
216
- if (util.getStringFromDB(file, start, 4) != "Exif") {
217
- return false;
218
- }
219
-
220
- var bigEnd,
221
- tags, tag,
222
- exifData, gpsData,
223
- tiffOffset = start + 6;
224
-
225
- // test for TIFF validity and endianness
226
- if (file.getUint16(tiffOffset) == 0x4949) {
227
- bigEnd = false;
228
- } else if (file.getUint16(tiffOffset) == 0x4D4D) {
229
- bigEnd = true;
230
- } else {
231
- return false;
232
- }
233
-
234
- if (file.getUint16(tiffOffset + 2, !bigEnd) != 0x002A) {
235
- return false;
236
- }
237
-
238
- var firstIFDOffset = file.getUint32(tiffOffset + 4, !bigEnd);
239
-
240
- if (firstIFDOffset < 0x00000008) {
241
- return false;
242
- }
243
-
244
- tags = readTags(file, tiffOffset, tiffOffset + firstIFDOffset, TiffTags, bigEnd);
245
-
246
- if (tags.ExifIFDPointer) {
247
- exifData = readTags(file, tiffOffset, tiffOffset + tags.ExifIFDPointer, ExifTags, bigEnd);
248
- for (tag in exifData) {
249
- switch (tag) {
250
- case "LightSource":
251
- case "Flash":
252
- case "MeteringMode":
253
- case "ExposureProgram":
254
- case "SensingMethod":
255
- case "SceneCaptureType":
256
- case "SceneType":
257
- case "CustomRendered":
258
- case "WhiteBalance":
259
- case "GainControl":
260
- case "Contrast":
261
- case "Saturation":
262
- case "Sharpness":
263
- case "SubjectDistanceRange":
264
- case "FileSource":
265
- exifData[tag] = StringValues[tag][exifData[tag]];
266
- break;
267
-
268
- case "ExifVersion":
269
- case "FlashpixVersion":
270
- exifData[tag] = String.fromCharCode(exifData[tag][0], exifData[tag][1], exifData[tag][2], exifData[tag][3]);
271
- break;
272
-
273
- case "ComponentsConfiguration":
274
- exifData[tag] =
275
- StringValues.Components[exifData[tag][0]] +
276
- StringValues.Components[exifData[tag][1]] +
277
- StringValues.Components[exifData[tag][2]] +
278
- StringValues.Components[exifData[tag][3]];
279
- break;
280
- }
281
- tags[tag] = exifData[tag];
282
- }
283
- }
284
-
285
- if (tags.GPSInfoIFDPointer) {
286
- gpsData = readTags(file, tiffOffset, tiffOffset + tags.GPSInfoIFDPointer, GPSTags, bigEnd);
287
- for (tag in gpsData) {
288
- switch (tag) {
289
- case "GPSVersionID":
290
- gpsData[tag] = gpsData[tag][0] +
291
- "." + gpsData[tag][1] +
292
- "." + gpsData[tag][2] +
293
- "." + gpsData[tag][3];
294
- break;
295
- }
296
- tags[tag] = gpsData[tag];
297
- }
298
- }
299
-
300
- // extract thumbnail
301
- //tags['thumbnail'] = readThumbnailImage(file, tiffOffset, firstIFDOffset, bigEnd);
302
-
303
- return tags;
304
- }
305
-
306
- function readTags(file, tiffStart, dirStart, strings, bigEnd) {
307
- var entries = file.getUint16(dirStart, !bigEnd),
308
- tags = {},
309
- entryOffset, tag,
310
- i;
311
-
312
- for (i = 0; i < entries; i++) {
313
- entryOffset = dirStart + i * 12 + 2;
314
- tag = strings[file.getUint16(entryOffset, !bigEnd)];
315
- tags[tag] = readTagValue(file, entryOffset, tiffStart, dirStart, bigEnd);
316
- }
317
- return tags;
318
- }
319
-
320
- function readTagValue(file, entryOffset, tiffStart, dirStart, bigEnd) {
321
- var type = file.getUint16(entryOffset + 2, !bigEnd),
322
- numValues = file.getUint32(entryOffset + 4, !bigEnd),
323
- valueOffset = file.getUint32(entryOffset + 8, !bigEnd) + tiffStart,
324
- offset,
325
- vals, val, n,
326
- numerator, denominator;
327
-
328
- switch (type) {
329
- case 1: // byte, 8-bit unsigned int
330
- case 7: // undefined, 8-bit byte, value depending on field
331
- if (numValues == 1) {
332
- return file.getUint8(entryOffset + 8, !bigEnd);
333
- } else {
334
- offset = numValues > 4 ? valueOffset : (entryOffset + 8);
335
- vals = [];
336
- for (n = 0; n < numValues; n++) {
337
- vals[n] = file.getUint8(offset + n);
338
- }
339
- return vals;
340
- }
341
-
342
- case 2: // ascii, 8-bit byte
343
- offset = numValues > 4 ? valueOffset : (entryOffset + 8);
344
- return util.getStringFromDB(file, offset, numValues - 1);
345
-
346
- case 3: // short, 16 bit int
347
- if (numValues == 1) {
348
- return file.getUint16(entryOffset + 8, !bigEnd);
349
- } else {
350
- offset = numValues > 2 ? valueOffset : (entryOffset + 8);
351
- vals = [];
352
- for (n = 0; n < numValues; n++) {
353
- vals[n] = file.getUint16(offset + 2 * n, !bigEnd);
354
- }
355
- return vals;
356
- }
357
-
358
- case 4: // long, 32 bit int
359
- if (numValues == 1) {
360
- return file.getUint32(entryOffset + 8, !bigEnd);
361
- } else {
362
- vals = [];
363
- for (n = 0; n < numValues; n++) {
364
- vals[n] = file.getUint32(valueOffset + 4 * n, !bigEnd);
365
- }
366
- return vals;
367
- }
368
-
369
- case 5: // rational = two long values, first is numerator, second is denominator
370
- if (numValues == 1) {
371
- numerator = file.getUint32(valueOffset, !bigEnd);
372
- denominator = file.getUint32(valueOffset + 4, !bigEnd);
373
- val = new Number(numerator / denominator);
374
- val.numerator = numerator;
375
- val.denominator = denominator;
376
- return val;
377
- } else {
378
- vals = [];
379
- for (n = 0; n < numValues; n++) {
380
- numerator = file.getUint32(valueOffset + 8 * n, !bigEnd);
381
- denominator = file.getUint32(valueOffset + 4 + 8 * n, !bigEnd);
382
- vals[n] = new Number(numerator / denominator);
383
- vals[n].numerator = numerator;
384
- vals[n].denominator = denominator;
385
- }
386
- return vals;
387
- }
388
-
389
- case 9: // slong, 32 bit signed int
390
- if (numValues == 1) {
391
- return file.getInt32(entryOffset + 8, !bigEnd);
392
- } else {
393
- vals = [];
394
- for (n = 0; n < numValues; n++) {
395
- vals[n] = file.getInt32(valueOffset + 4 * n, !bigEnd);
396
- }
397
- return vals;
398
- }
399
-
400
- case 10: // signed rational, two slongs, first is numerator, second is denominator
401
- if (numValues == 1) {
402
- return file.getInt32(valueOffset, !bigEnd) / file.getInt32(valueOffset + 4, !bigEnd);
403
- } else {
404
- vals = [];
405
- for (n = 0; n < numValues; n++) {
406
- vals[n] = file.getInt32(valueOffset + 8 * n, !bigEnd) / file.getInt32(valueOffset + 4 + 8 * n, !bigEnd);
407
- }
408
- return vals;
409
- }
410
- }
411
- }
412
-
413
- function readIPTCData(file, startOffset, sectionLength) {
414
- var dataView = new DataView(file);
415
- var data = {};
416
- var fieldValue, fieldName, dataSize, segmentType, segmentSize;
417
- var segmentStartPos = startOffset;
418
- while (segmentStartPos < startOffset + sectionLength) {
419
- if (dataView.getUint8(segmentStartPos) === 0x1C && dataView.getUint8(segmentStartPos + 1) === 0x02) {
420
- segmentType = dataView.getUint8(segmentStartPos + 2);
421
- if (segmentType in IptcFieldMap) {
422
- dataSize = dataView.getInt16(segmentStartPos + 3);
423
- segmentSize = dataSize + 5;
424
- fieldName = IptcFieldMap[segmentType];
425
- fieldValue = util.getStringFromDB(dataView, segmentStartPos + 5, dataSize);
426
- // Check if we already stored a value with this name
427
- if (data.hasOwnProperty(fieldName)) {
428
- // Value already stored with this name, create multivalue field
429
- if (data[fieldName] instanceof Array) {
430
- data[fieldName].push(fieldValue);
431
- }
432
- else {
433
- data[fieldName] = [data[fieldName], fieldValue];
434
- }
435
- }
436
- else {
437
- data[fieldName] = fieldValue;
438
- }
439
- }
440
-
441
- }
442
- segmentStartPos++;
443
- }
444
- return data;
445
- }