import gradio as gr import cv2 import easyocr from PIL import Image # Functions for OCR steps def get_grayscale(image): return cv2.cvtColor(image, cv2.COLOR_BGR2GRAY) def thresholding(src): return cv2.threshold(src,127,255, cv2.THRESH_TOZERO)[1] def ocr_with_easy(img): gray_scale_image = get_grayscale(img) thresholded_image = thresholding(gray_scale_image) cv2.imwrite('image.png', thresholded_image) reader = easyocr.Reader(['en']) bounds = reader.readtext('image.png', paragraph="False", detail=0) bounds = ''.join(bounds) return bounds def generate_ocr(img): text_output = '' if (img).any(): if img is not None: text_output = ocr_with_easy(img) else: raise gr.Error("Please upload an image!!!!") return text_output # Interactive questions questions = [ { "question": "What is the first step in OCR?", "options": ["Binarization", "Grayscale conversion", "Edge detection"], "answer": "Grayscale conversion" }, { "question": "What is the purpose of thresholding in OCR?", "options": ["To detect edges", "To convert image to grayscale", "To binarize the image"], "answer": "To binarize the image" }, { "question": "Which library is used for OCR in this app?", "options": ["Tesseract", "EasyOCR", "OpenCV"], "answer": "EasyOCR" }, { "question": "What format is the image saved in after preprocessing?", "options": ["JPG", "PNG", "TIFF"], "answer": "PNG" }, { "question": "What does OCR stand for?", "options": ["Optical Character Recognition", "Optical Character Reading", "Optical Code Recognition"], "answer": "Optical Character Recognition" } ] def quiz_interface(): def check_answer(question_idx, selected): if questions[question_idx]["answer"] == selected: return "Correct!" else: return "Incorrect. The correct answer is: " + questions[question_idx]["answer"] interfaces = [] for idx, question in enumerate(questions): radio = gr.Radio(choices=question["options"], label=question["question"]) button = gr.Button("Submit") output = gr.Textbox(label="Result") def create_submit_fn(idx): def submit(selected): return check_answer(idx, selected) return submit interfaces.append(gr.Interface( create_submit_fn(idx), radio, output, live=True )) return interfaces # Explanation text explanation_text = """ **Welcome to the OCR Tutorial!** Optical Character Recognition (OCR) is a technology used to convert different types of documents, such as scanned paper documents, PDF files, or images captured by a digital camera, into editable and searchable data. **Steps in the OCR Process:** 1. **Grayscale Conversion:** The first step in OCR is converting the image to grayscale. This simplifies the image and reduces the amount of data the OCR algorithm needs to process. 2. **Thresholding:** This step converts the grayscale image into a binary image, where the text is in black, and the background is in white. This makes it easier for the OCR algorithm to distinguish text from the background. 3. **OCR using EasyOCR:** We use the EasyOCR library to recognize and extract text from the preprocessed image. Now that you understand the basics, you can try the OCR tool below and then proceed to answer the questions in the other tabs. """ image = gr.Image() output = gr.Textbox(label="Output") explanation = gr.Markdown(explanation_text) ocr_app = gr.Interface( fn=generate_ocr, inputs=image, outputs=output, title="Optical Character Recognition", description=explanation_text, css=".gradio-container {background-color: lightgray} #radio_div {background-color: #FFD8B4; font-size: 40px;}" ) quiz_app = gr.TabbedInterface( [ocr_app] + quiz_interface(), ["OCR Tool"] + [f"Question {i+1}" for i in range(len(questions))], title="OCR Tutorial and Quiz" ) quiz_app.launch()