Vue Js Extract Text from Image: Extracting text from an image using Vue.js involves using a third-party library or API that can perform Optical Character Recognition (OCR) on the image. The process typically involves sending the image to the OCR service, which then uses machine learning algorithms to recognize the characters in the image and convert them into machine-readable text.
Vue.js can be used to build the frontend of a web application that integrates with an OCR API, allowing users to upload images and receive the extracted text. This can be useful for tasks such as digitizing documents, extracting text from images for translation or analysis, and more.
What is the process for extracting text from an image using Vue.js ?
- The data object is defined with three properties: “image”, “extractedText”, and “loading”.
- The “loadImage” method is defined to load the selected image file and set it as the “image” property using the FileReader API.
- The “extractText” method is defined to extract text from the loaded image using the Tesseract.js OCR library. The “loading” property is set to true during the text extraction process.
- The “extractedText” property is set with the extracted text and the “loading” property is set to false after the text extraction process is complete.
- The HTML markup is defined with a button to upload an image, an image tag to display the selected image, a button to extract text from the image, and a div to display the extracted text.
- The “v-if” directive is used to conditionally render elements based on whether the image is loaded, the text extraction process is in progress, or the extracted text is available.
- The Tesseract.js OCR library is used to extract text from the loaded image by passing the loaded image, language to be used for OCR, and an optional logger object.
- The extracted text is displayed within the “pre” tag using the “extractedText” property.
Vue Js Extract Text from Image Example
<div id="app">
<div class="upload-btn-wrapper">
<button class="btn">Upload Image</button>
<input type="file" @change="loadImage" accept="image/*">
</div>
<div v-if="image">
<img :src="image">
<button class="btn" @click="extractText">Extract Text</button>
</div>
<div v-if="loading">
<h2>Loading...<span class="loader"></span></h2>
</div>
<div v-if="extractedText">
<h2>Extracted Text</h2>
<pre>{{ extractedText }}</pre>
</div>
</div>
<script>
new Vue({
el: '#app',
data() {
return {
image: null,
extractedText: null,
loading: false,
};
},
methods: {
loadImage(event) {
const file = event.target.files[0];
const reader = new FileReader();
reader.readAsDataURL(file);
reader.onload = () => {
this.image = reader.result;
};
},
extractText() {
this.loading = true;
Tesseract.recognize(
this.image,
'eng+hin',
{ logger: m => console.log(m) }
).then(({ data: { text } }) => {
this.extractedText = text;
}).finally(() => {
this.loading = false;
});
},
},
});
</script>