@mapcatch/util 1.0.8 → 1.0.9-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.
- package/CHANGELOG.md +5 -1
- package/dist/catchUtil.min.esm.js +1179 -1160
- package/dist/catchUtil.min.js +13 -13
- package/package.json +1 -1
- package/src/exif/index.js +49 -9
- package/src/exif/parse_image.js +1 -11
- package/src/util.js +3 -7
package/package.json
CHANGED
package/src/exif/index.js
CHANGED
|
@@ -1,16 +1,56 @@
|
|
|
1
1
|
import {getData} from './parse_image'
|
|
2
2
|
import {getAllTags} from './exif'
|
|
3
|
+
import {imageSize} from '../image-size'
|
|
3
4
|
|
|
4
5
|
export const getPhotoTags = (file) => {
|
|
5
6
|
return new Promise((resolve, reject) => {
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
7
|
+
if (file.type === 'image/jpeg') {
|
|
8
|
+
let sliceFile = file.slice(0, 131072)
|
|
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
|
+
if (!exif.PixelXDimension || !exif.PixelYDimension || exif.PixelXDimension == 65535 || exif.PixelYDimension == 65535) {
|
|
18
|
+
getImageSize(file).then((size) => {
|
|
19
|
+
Object.assign(exif, size)
|
|
20
|
+
resolve(exif)
|
|
21
|
+
})
|
|
22
|
+
} else {
|
|
23
|
+
resolve(exif)
|
|
24
|
+
}
|
|
25
|
+
})
|
|
26
|
+
} else {
|
|
27
|
+
var fileReader = new FileReader();
|
|
28
|
+
fileReader.onload = function (e) {
|
|
29
|
+
let u8array = new Uint8Array(e.target.result)
|
|
30
|
+
let size = imageSize(u8array)
|
|
31
|
+
resolve({
|
|
32
|
+
PixelXDimension: size.width,
|
|
33
|
+
PixelYDimension: size.height
|
|
34
|
+
})
|
|
35
|
+
};
|
|
36
|
+
|
|
37
|
+
fileReader.readAsArrayBuffer(file);
|
|
38
|
+
}
|
|
39
|
+
})
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
function getImageSize(file) {
|
|
43
|
+
return new Promise((resolve, reject) => {
|
|
44
|
+
var fileReader = new FileReader();
|
|
45
|
+
fileReader.onload = function (e) {
|
|
46
|
+
let u8array = new Uint8Array(e.target.result)
|
|
47
|
+
let size = imageSize(u8array)
|
|
48
|
+
resolve({
|
|
49
|
+
PixelXDimension: size.width,
|
|
50
|
+
PixelYDimension: size.height
|
|
51
|
+
})
|
|
52
|
+
};
|
|
53
|
+
|
|
54
|
+
fileReader.readAsArrayBuffer(file);
|
|
15
55
|
})
|
|
16
56
|
}
|
package/src/exif/parse_image.js
CHANGED
|
@@ -4,7 +4,6 @@ import ExifTags from './tags'
|
|
|
4
4
|
import StringValues from './string_values'
|
|
5
5
|
import GPSTags from './gps_tags'
|
|
6
6
|
import IptcFieldMap from './iptc_field_map'
|
|
7
|
-
import {imageSize} from '../image-size'
|
|
8
7
|
|
|
9
8
|
var isXmpEnabled = false
|
|
10
9
|
|
|
@@ -87,10 +86,6 @@ function findEXIFinJPEG(file) {
|
|
|
87
86
|
var dataView = new DataView(file);
|
|
88
87
|
let exif = {}
|
|
89
88
|
|
|
90
|
-
if ((dataView.getUint8(0) != 0xFF) || (dataView.getUint8(1) != 0xD8)) {
|
|
91
|
-
return false; // not a valid jpeg
|
|
92
|
-
}
|
|
93
|
-
|
|
94
89
|
var offset = 2,
|
|
95
90
|
length = file.byteLength,
|
|
96
91
|
marker;
|
|
@@ -107,12 +102,7 @@ function findEXIFinJPEG(file) {
|
|
|
107
102
|
|
|
108
103
|
if (marker == 225) {
|
|
109
104
|
exif = readEXIFData(dataView, offset + 4, dataView.getUint16(offset + 2) - 2)
|
|
110
|
-
|
|
111
|
-
Object.assign(exif, {
|
|
112
|
-
PixelXDimension: size.width,
|
|
113
|
-
PixelYDimension: size.height
|
|
114
|
-
})
|
|
115
|
-
return exif
|
|
105
|
+
break
|
|
116
106
|
}
|
|
117
107
|
offset += 2 + dataView.getUint16(offset + 2);
|
|
118
108
|
}
|
package/src/util.js
CHANGED
|
@@ -32,9 +32,7 @@ export function formatFileSize (value) { // 文件大小格式化,自动换算
|
|
|
32
32
|
}
|
|
33
33
|
}
|
|
34
34
|
export async function getPhotoInfo(file) { // 获取照片的经纬度
|
|
35
|
-
let
|
|
36
|
-
sliceFile.name = file.name
|
|
37
|
-
let exif = await getPhotoTags(sliceFile)
|
|
35
|
+
let exif = await getPhotoTags(file)
|
|
38
36
|
let {GPSAltitude, GPSLatitude, GPSLatitudeRef, GPSLongitude, GPSLongitudeRef, DateTimeOriginal, Model, PixelXDimension, PixelYDimension} = exif
|
|
39
37
|
let position = null
|
|
40
38
|
if (GPSLongitude && GPSLatitude) {
|
|
@@ -56,15 +54,13 @@ export async function getPhotoInfo(file) { // 获取照片的经纬度
|
|
|
56
54
|
export function getPhotoMeta(file) { // 获取照片的元数据,包括exif和md5,为了提高计算效率,只取前64k进行计算
|
|
57
55
|
return new Promise((resolve, reject) => {
|
|
58
56
|
let md5, exif
|
|
59
|
-
|
|
60
|
-
sliceFile.name = file.name
|
|
61
|
-
getPhotoTags(sliceFile).then(data => {
|
|
57
|
+
getPhotoTags(file).then(data => {
|
|
62
58
|
exif = data
|
|
63
59
|
done()
|
|
64
60
|
})
|
|
65
61
|
let fileReader = new FileReader()
|
|
66
62
|
let spark = new SparkMD5.ArrayBuffer()
|
|
67
|
-
fileReader.readAsArrayBuffer(
|
|
63
|
+
fileReader.readAsArrayBuffer(file)
|
|
68
64
|
fileReader.onload = e => {
|
|
69
65
|
spark.append(e.target.result)
|
|
70
66
|
md5 = spark.end()
|