Spaces:
Running
Running
File size: 3,474 Bytes
6084325 5d52af1 9f0ef40 6084325 784d954 6084325 784d954 550ae51 6084325 784d954 550ae51 24c48fb 550ae51 24c48fb 784d954 550ae51 24c48fb 8102829 550ae51 8102829 6084325 550ae51 784d954 550ae51 44c3663 550ae51 9e1cd24 784d954 6084325 784d954 6084325 784d954 550ae51 784d954 6084325 784d954 550ae51 6084325 550ae51 9f6b576 550ae51 9f6b576 6084325 550ae51 056d44f 08657ec 784d954 550ae51 0125c43 |
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 |
import qrcode
from PIL import Image
import gradio as gr
import tempfile
import numpy as np
# Function to generate a QR code
def generate_qr(data):
qr = qrcode.QRCode(
version=1,
error_correction=qrcode.constants.ERROR_CORRECT_L,
box_size=10,
border=4,
)
qr.add_data(data)
qr.make(fit=True)
img = qr.make_image(fill="black", back_color="white")
# Save to a temporary file
temp_file = tempfile.NamedTemporaryFile(delete=False, suffix=".png")
img.save(temp_file.name, format="PNG")
temp_file.close() # Ensure file is written to disk
return temp_file.name # Return the file path only, Gradio will handle displaying the image
# Function to read a QR code
def read_qr(image_file):
# Convert PIL image to a NumPy array
img = Image.open(image_file.name)
img_np = np.array(img)
# Convert RGB to BGR as OpenCV expects
if img_np.ndim == 3:
img_np = cv2.cvtColor(img_np, cv2.COLOR_RGB2BGR)
# Initialize OpenCV QR code detector
detector = cv2.QRCodeDetector()
data, _, _ = detector.detectAndDecode(img_np)
return data if data else "No QR code found."
# Function to copy text to clipboard (this requires platform-specific implementations)
def copy_to_clipboard(text):
import pyperclip
pyperclip.copy(text)
return "Copied to Clipboard!"
# Gradio Interface
def create_gradio_interface():
# QR Code Generator with Display and Downloadable Link
def generate_qr_interface(data):
qr_file = generate_qr(data) # This will now return the file path directly
qr_image = Image.open(qr_file)
return [qr_image, qr_file] # Return both image and file for Gradio to display/download
# QR Code Reader with Copy-to-Clipboard Button
def read_qr_interface(image_file):
decoded_data = read_qr(image_file)
return decoded_data # Return decoded text
# QR Code Generator Tab
generate_interface = gr.Interface(
fn=generate_qr_interface,
inputs=gr.Textbox(placeholder="Enter text or URL here...", label="Data to Encode"),
outputs=[
gr.Image(label="Generated QR Code"), # Display the QR code image
gr.File(label="Download QR Code"), # Downloadable link for the QR code file
],
title="Generate QR Code",
description="Quickly create a QR code from any text or URL.",
)
# QR Code Reader Tab
read_interface = gr.Interface(
fn=read_qr_interface,
inputs=gr.File(type="file", label="Upload QR Code Image"),
outputs=gr.Textbox(label="Decoded Data"),
title="Read QR Code",
description="Upload an image with a QR code to decode the embedded data.",
)
# Clipboard Functionality for "Read QR Code" Tab
with gr.Blocks() as demo:
gr.Markdown("## QR Code Tool: Generate and Decode with Ease")
with gr.Tab("Generate QR Code"):
generate_interface.render()
with gr.Tab("Read QR Code"):
qr_text = gr.Textbox(label="Decoded Data") # Single box for decoded data
copy_button = gr.Button("Copy to Clipboard")
read_interface.render()
# Connect button click to copy function
copy_button.click(
fn=copy_to_clipboard,
inputs=qr_text,
outputs=qr_text,
)
demo.launch(share=True)
# Run the Gradio interface
create_gradio_interface()
|