@mapcatch/util 1.0.5 → 1.0.7
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 +10 -1
- package/dist/catchUtil.min.esm.js +2503 -2494
- package/dist/catchUtil.min.js +17 -17
- package/package.json +2 -2
- package/src/exif/parse_image.js +15 -8
- package/src/util.js +14 -11
package/package.json
CHANGED
package/src/exif/parse_image.js
CHANGED
|
@@ -84,6 +84,7 @@ function getImageData(img, callback) {
|
|
|
84
84
|
|
|
85
85
|
function findEXIFinJPEG(file) {
|
|
86
86
|
var dataView = new DataView(file);
|
|
87
|
+
let exif = {}
|
|
87
88
|
|
|
88
89
|
if ((dataView.getUint8(0) != 0xFF) || (dataView.getUint8(1) != 0xD8)) {
|
|
89
90
|
return false; // not a valid jpeg
|
|
@@ -95,7 +96,7 @@ function findEXIFinJPEG(file) {
|
|
|
95
96
|
|
|
96
97
|
while (offset < length) {
|
|
97
98
|
if (dataView.getUint8(offset) != 0xFF) {
|
|
98
|
-
|
|
99
|
+
break
|
|
99
100
|
}
|
|
100
101
|
|
|
101
102
|
marker = dataView.getUint8(offset + 1);
|
|
@@ -104,16 +105,22 @@ function findEXIFinJPEG(file) {
|
|
|
104
105
|
// but we're only looking for 0xFFE1 for EXIF data
|
|
105
106
|
|
|
106
107
|
if (marker == 225) {
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
108
|
+
Object.assign(exif, readEXIFData(dataView, offset + 4, dataView.getUint16(offset + 2) - 2))
|
|
109
|
+
} else if (marker === 192) {
|
|
110
|
+
let width = dataView.getUint16(offset + 7)
|
|
111
|
+
let height = dataView.getUint16(offset + 5)
|
|
112
|
+
if (width && height) {
|
|
113
|
+
Object.assign(exif, {
|
|
114
|
+
PixelXDimension: width,
|
|
115
|
+
PixelYDimension: height
|
|
116
|
+
})
|
|
117
|
+
}
|
|
118
|
+
return exif
|
|
114
119
|
}
|
|
120
|
+
offset += 2 + dataView.getUint16(offset + 2);
|
|
115
121
|
|
|
116
122
|
}
|
|
123
|
+
return exif
|
|
117
124
|
|
|
118
125
|
}
|
|
119
126
|
|
package/src/util.js
CHANGED
|
@@ -32,28 +32,31 @@ export function formatFileSize (value) { // 文件大小格式化,自动换算
|
|
|
32
32
|
}
|
|
33
33
|
}
|
|
34
34
|
export async function getPhotoInfo(file) { // 获取照片的经纬度
|
|
35
|
-
let sliceFile = file.slice(0,
|
|
35
|
+
let sliceFile = file.slice(0, 131072)
|
|
36
36
|
sliceFile.name = file.name
|
|
37
37
|
let exif = await getPhotoTags(sliceFile)
|
|
38
|
-
let {GPSAltitude, GPSLatitude, GPSLatitudeRef, GPSLongitude, GPSLongitudeRef, DateTimeOriginal, Model} = exif
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
let date = DateTimeOriginal.split(' ')[0].replaceAll(':', '-')
|
|
43
|
-
return {
|
|
44
|
-
date,
|
|
45
|
-
Model,
|
|
46
|
-
position: {
|
|
38
|
+
let {GPSAltitude, GPSLatitude, GPSLatitudeRef, GPSLongitude, GPSLongitudeRef, DateTimeOriginal, Model, PixelXDimension, PixelYDimension} = exif
|
|
39
|
+
let position = null
|
|
40
|
+
if (GPSLongitude && GPSLatitude) {
|
|
41
|
+
position = {
|
|
47
42
|
lng: getGeoCoordOperator(GPSLongitudeRef) * toRadian(GPSLongitude),
|
|
48
43
|
lat: getGeoCoordOperator(GPSLatitudeRef) * toRadian(GPSLatitude),
|
|
49
44
|
alt: +GPSAltitude
|
|
50
45
|
}
|
|
51
46
|
}
|
|
47
|
+
let date = DateTimeOriginal && DateTimeOriginal.split(' ')[0].replaceAll(':', '-')
|
|
48
|
+
return {
|
|
49
|
+
date,
|
|
50
|
+
Model,
|
|
51
|
+
width: PixelXDimension,
|
|
52
|
+
height: PixelYDimension,
|
|
53
|
+
position
|
|
54
|
+
}
|
|
52
55
|
}
|
|
53
56
|
export function getPhotoMeta(file) { // 获取照片的元数据,包括exif和md5,为了提高计算效率,只取前64k进行计算
|
|
54
57
|
return new Promise((resolve, reject) => {
|
|
55
58
|
let md5, exif
|
|
56
|
-
let sliceFile = file.slice(0,
|
|
59
|
+
let sliceFile = file.slice(0, 131072)
|
|
57
60
|
sliceFile.name = file.name
|
|
58
61
|
getPhotoTags(sliceFile).then(data => {
|
|
59
62
|
exif = data
|