forked from exif-js/exif-js
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.html
112 lines (103 loc) · 19.5 KB
/
index.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
</head>
<body>
Upload a local file to read Exif data.
<br/>
<input id="file-input" type="file" />
<br/><br/>
Click the images to read Exif data. The first image tests reading single tags, while the other two simply show all available data. Check this <a href="example">example</a> if you prefer not to click but see EXIF info immediately.
<br/><br/>
Note: these examples will not work if running from a local file:// URL.
<br/><br/>
<img src="example/DSCN0614_small.jpg" id="img1" />
<br/>
<img src="example/Bush-dog.jpg" id="img2" />
<br/>
<img src="example/dsc_09827.jpg" id="img3" /><br/>
<br/>
<button id="objecturltest">Object URL Test</button><br/>
<br/>
<button id="blobtest">Blob Test</button><br/>
<br/>
<button id="base64test">Base64 Test</button><br/>
<script type="text/javascript" src="exif.js"></script>
<script>
document.getElementById("img1").onclick = function() {
EXIF.getData(this, function() {
var make = EXIF.getTag(this, "Make"),
model = EXIF.getTag(this, "Model");
alert("I was taken by a " + make + " " + model);
});
}
document.getElementById("img2").onclick = function() {
EXIF.getData(this, function() {
alert(EXIF.pretty(this));
});
}
document.getElementById("img3").onclick = function() {
EXIF.getData(this, function() {
alert(EXIF.pretty(this));
});
}
document.getElementById("file-input").onchange = function(e) {
var file = e.target.files[0]
if (file && file.name) {
EXIF.getData(file, function() {
var exifData = EXIF.pretty(this);
if (exifData) {
alert(exifData);
} else {
alert("No EXIF data found in image '" + file.name + "'.");
}
});
}
}
document.getElementById("base64test").onclick = function() {
var image = new Image();
image.onload = function() {
EXIF.getData(image, function() {
alert(EXIF.pretty(this));
});
};
image.src = ""
}
var testFilePath = "example/DSCN0614_small.jpg";
document.getElementById("objecturltest").onclick = function() {
var http = new XMLHttpRequest();
http.open("GET", testFilePath, true);
http.responseType = "blob";
http.onload = function(e) {
if (this.status === 200) {
var image = new Image();
image.onload = function() {
EXIF.getData(image, function() {
alert(EXIF.pretty(this));
});
};
image.src = URL.createObjectURL(http.response);
}
};
http.send();
}
document.getElementById("blobtest").onclick = function() {
var http = new XMLHttpRequest();
http.open("GET", testFilePath, true);
http.responseType = "blob";
http.onload = function(e) {
if (this.status === 200) {
EXIF.getData(http.response, function() {
alert(EXIF.pretty(this));
});
}
};
http.send();
}
</script>
</body>
</html>