|
1 | 1 | <template> |
2 | | - <div class="scanner-container"> |
3 | | - <div v-show="!isLoading"> |
4 | | - <video poster="data:image/gif,AAAA" ref="scanner"></video> |
5 | | - <div class="overlay-element"></div> |
6 | | - <div class="laser"></div> |
7 | | - </div> |
| 2 | + <div class="scanner-container"> |
| 3 | + <div v-show="!isLoading"> |
| 4 | + <video poster="data:image/gif,AAAA" ref="scanner"></video> |
| 5 | + <div class="overlay-element"></div> |
| 6 | + <div class="laser"></div> |
8 | 7 | </div> |
| 8 | + </div> |
9 | 9 | </template> |
10 | 10 |
|
11 | 11 | <script> |
12 | 12 | import { BrowserMultiFormatReader, Exception } from "@zxing/library"; |
13 | 13 |
|
14 | 14 | export default { |
15 | | - name: "stream-barcode-reader", |
| 15 | + name: "stream-barcode-reader", |
16 | 16 |
|
17 | | - data() { |
18 | | - return { |
19 | | - isLoading: true, |
20 | | - codeReader: new BrowserMultiFormatReader(), |
21 | | - isMediaStreamAPISupported: |
22 | | - navigator && |
23 | | - navigator.mediaDevices && |
24 | | - "enumerateDevices" in navigator.mediaDevices |
25 | | - }; |
26 | | - }, |
| 17 | + data() { |
| 18 | + return { |
| 19 | + isLoading: true, |
| 20 | + codeReader: new BrowserMultiFormatReader(), |
| 21 | + isMediaStreamAPISupported: navigator && navigator.mediaDevices && "enumerateDevices" in navigator.mediaDevices, |
| 22 | + }; |
| 23 | + }, |
27 | 24 |
|
28 | | - mounted() { |
29 | | - if (!this.isMediaStreamAPISupported) { |
30 | | - throw new Exception("Media Stream API is not supported"); |
31 | | - return; |
32 | | - } |
| 25 | + mounted() { |
| 26 | + if (!this.isMediaStreamAPISupported) { |
| 27 | + throw new Exception("Media Stream API is not supported"); |
| 28 | + return; |
| 29 | + } |
33 | 30 |
|
34 | | - this.start(); |
35 | | - this.$refs.scanner.oncanplay = event => { |
36 | | - this.isLoading = false; |
37 | | - this.$emit("loaded"); |
38 | | - }; |
39 | | - }, |
| 31 | + this.start(); |
| 32 | + this.$refs.scanner.oncanplay = (event) => { |
| 33 | + this.isLoading = false; |
| 34 | + this.$emit("loaded"); |
| 35 | + }; |
| 36 | + }, |
40 | 37 |
|
41 | | - beforeUnmount() { |
42 | | - this.codeReader.reset(); |
43 | | - }, |
| 38 | + beforeUnmount() { |
| 39 | + this.codeReader.reset(); |
| 40 | + }, |
44 | 41 |
|
45 | | - methods: { |
46 | | - start() { |
47 | | - this.codeReader.decodeFromVideoDevice( |
48 | | - undefined, |
49 | | - this.$refs.scanner, |
50 | | - (result, err) => { |
51 | | - if (result) { |
52 | | - this.$emit("decode", result.text); |
53 | | - } |
54 | | - } |
55 | | - ); |
| 42 | + methods: { |
| 43 | + start() { |
| 44 | + this.codeReader.decodeFromVideoDevice(undefined, this.$refs.scanner, (result, err) => { |
| 45 | + if (result) { |
| 46 | + this.$emit("decode", result.text); |
| 47 | + this.$emit("result", result); |
56 | 48 | } |
57 | | - } |
| 49 | + }); |
| 50 | + }, |
| 51 | + }, |
58 | 52 | }; |
59 | 53 | </script> |
60 | 54 |
|
61 | 55 | <style scoped> |
62 | 56 | video { |
63 | | - max-width: 100%; |
64 | | - max-height: 100%; |
| 57 | + max-width: 100%; |
| 58 | + max-height: 100%; |
65 | 59 | } |
66 | 60 | .scanner-container { |
67 | | - position: relative; |
| 61 | + position: relative; |
68 | 62 | } |
69 | 63 |
|
70 | 64 | .overlay-element { |
71 | | - position: absolute; |
72 | | - top: 0; |
73 | | - width: 100%; |
74 | | - height: 99%; |
75 | | - background: rgba(30, 30, 30, 0.5); |
| 65 | + position: absolute; |
| 66 | + top: 0; |
| 67 | + width: 100%; |
| 68 | + height: 99%; |
| 69 | + background: rgba(30, 30, 30, 0.5); |
76 | 70 |
|
77 | | - -webkit-clip-path: polygon( |
78 | | - 0% 0%, |
79 | | - 0% 100%, |
80 | | - 20% 100%, |
81 | | - 20% 20%, |
82 | | - 80% 20%, |
83 | | - 80% 80%, |
84 | | - 20% 80%, |
85 | | - 20% 100%, |
86 | | - 100% 100%, |
87 | | - 100% 0% |
88 | | - ); |
89 | | - clip-path: polygon( |
90 | | - 0% 0%, |
91 | | - 0% 100%, |
92 | | - 20% 100%, |
93 | | - 20% 20%, |
94 | | - 80% 20%, |
95 | | - 80% 80%, |
96 | | - 20% 80%, |
97 | | - 20% 100%, |
98 | | - 100% 100%, |
99 | | - 100% 0% |
100 | | - ); |
| 71 | + -webkit-clip-path: polygon(0% 0%, 0% 100%, 20% 100%, 20% 20%, 80% 20%, 80% 80%, 20% 80%, 20% 100%, 100% 100%, 100% 0%); |
| 72 | + clip-path: polygon(0% 0%, 0% 100%, 20% 100%, 20% 20%, 80% 20%, 80% 80%, 20% 80%, 20% 100%, 100% 100%, 100% 0%); |
101 | 73 | } |
102 | 74 |
|
103 | 75 | .laser { |
104 | | - width: 60%; |
105 | | - margin-left: 20%; |
106 | | - background-color: tomato; |
107 | | - height: 1px; |
108 | | - position: absolute; |
109 | | - top: 40%; |
110 | | - z-index: 2; |
111 | | - box-shadow: 0 0 4px red; |
112 | | - -webkit-animation: scanning 2s infinite; |
113 | | - animation: scanning 2s infinite; |
| 76 | + width: 60%; |
| 77 | + margin-left: 20%; |
| 78 | + background-color: tomato; |
| 79 | + height: 1px; |
| 80 | + position: absolute; |
| 81 | + top: 40%; |
| 82 | + z-index: 2; |
| 83 | + box-shadow: 0 0 4px red; |
| 84 | + -webkit-animation: scanning 2s infinite; |
| 85 | + animation: scanning 2s infinite; |
114 | 86 | } |
115 | 87 | @-webkit-keyframes scanning { |
116 | | - 50% { |
117 | | - -webkit-transform: translateY(75px); |
118 | | - transform: translateY(75px); |
119 | | - } |
| 88 | + 50% { |
| 89 | + -webkit-transform: translateY(75px); |
| 90 | + transform: translateY(75px); |
| 91 | + } |
120 | 92 | } |
121 | 93 | @keyframes scanning { |
122 | | - 50% { |
123 | | - -webkit-transform: translateY(75px); |
124 | | - transform: translateY(75px); |
125 | | - } |
| 94 | + 50% { |
| 95 | + -webkit-transform: translateY(75px); |
| 96 | + transform: translateY(75px); |
| 97 | + } |
126 | 98 | } |
127 | 99 | </style> |
0 commit comments