Zhu-FaceOnLive's picture
Update demo.py
db78260
raw
history blame
7.86 kB
import gradio as gr
import requests
import json
from PIL import Image
def idcard_recognition(frame1, frame2):
url = "http://127.0.0.1:8000/ocr/idcard"
files = None
if frame1 is not None and frame2 is not None:
files = {'image1': open(frame1, 'rb'), 'image2': open(frame2, 'rb')}
elif frame1 is not None and frame2 is None:
files = {'image1': open(frame1, 'rb')}
elif frame1 is None and frame2 is not None:
files = {'image1': open(frame2, 'rb')}
else:
return ['', None]
print(frame1, files)
r = requests.post(url=url, files=files)
images = None
resultValues = {}
table_value = ""
for key, value in r.json().items():
if key == 'data':
if 'image' in value:
del value['image']
resultValues[key] = value
else:
resultValues[key] = value
if 'data' in r.json():
for key, value in r.json()['data'].items():
if key == 'image':
for image_key, image_value in value.items():
row_value = ("<tr>"
"<td>{key}</td>"
"<td><img src=""data:image/png;base64,{base64_image} width = '200' height= '100' /></td>"
"</tr>".format(key=image_key, base64_image=image_value))
table_value = table_value + row_value
images = ("<table>"
"<tr>"
"<th>Field</th>"
"<th>Image</th>"
"</tr>"
"{table_value}"
"</table>".format(table_value=table_value))
json_result = json.dumps(resultValues, indent=4)
return [json_result, images]
def barcode_recognition(frame):
url = "http://127.0.0.1:8000/ocr/barcode"
files = None
if frame is None:
return ['', None]
files = {'image': open(frame, 'rb')}
r = requests.post(url=url, files=files)
images = None
resultValues = {}
table_value = ""
for key, value in r.json().items():
if key == 'data':
if 'image' in value:
del value['image']
resultValues[key] = value
else:
resultValues[key] = value
if 'data' in r.json():
for key, value in r.json()['data'].items():
if key == 'image':
for image_key, image_value in value.items():
row_value = ("<tr>"
"<td>{key}</td>"
"<td><img src=""data:image/png;base64,{base64_image} width = '200' height= '100' /></td>"
"</tr>".format(key=image_key, base64_image=image_value))
table_value = table_value + row_value
images = ("<table>"
"<tr>"
"<th>Field</th>"
"<th>Image</th>"
"</tr>"
"{table_value}"
"</table>".format(table_value=table_value))
json_result = json.dumps(resultValues, indent=4)
return [json_result, images]
def credit_recognition(frame):
url = "http://127.0.0.1:8000/ocr/credit"
files = None
if frame is None:
return ['', None]
files = {'image': open(frame, 'rb')}
r = requests.post(url=url, files=files)
images = None
resultValues = {}
table_value = ""
for key, value in r.json().items():
if key == 'data':
if 'image' in value:
del value['image']
resultValues[key] = value
else:
resultValues[key] = value
if 'data' in r.json():
for key, value in r.json()['data'].items():
if key == 'image':
for image_key, image_value in value.items():
row_value = ("<tr>"
"<td>{key}</td>"
"<td><img src=""data:image/png;base64,{base64_image} width = '200' height= '100' /></td>"
"</tr>".format(key=image_key, base64_image=image_value))
table_value = table_value + row_value
images = ("<table>"
"<tr>"
"<th>Field</th>"
"<th>Image</th>"
"</tr>"
"{table_value}"
"</table>".format(table_value=table_value))
json_result = json.dumps(resultValues, indent=4)
return [json_result, images]
with gr.Blocks() as demo:
gr.Markdown(
"""
# ID Document Recognition
Get your own ID Document Recognition Server by duplicating this space.<br/>
Or run on your own machine using docker.<br/>
```docker run -it -p 7860:7860 --platform=linux/amd64 \
-e LICENSE_KEY="YOUR_VALUE_HERE" \
registry.hf.space/faceonlive-id-document-recognition-sdk:latest```<br/><br/>
Contact us at https://faceonlive.com for issues and support.<br/><br/>
** For security and privacy, kindly refrain from uploading real ID card or credit card information on this platform.
"""
)
with gr.TabItem("ID Card Recognition"):
with gr.Row():
with gr.Column(scale=3):
id_image_input1 = gr.Image(type='filepath', label='Front')
id_image_input2 = gr.Image(type='filepath', label='Back')
id_recognition_button = gr.Button("ID Card Recognition")
id_examples = gr.Examples(
examples=[['samples/11.jpg', 'samples/12.jpg'], ['samples/21.jpg', 'samples/22.jpg'], ['samples/3.jpg', None] ['samples/4.jpg', None]],
inputs=[id_image_input1, id_image_input2],
outputs=None,
fn=idcard_recognition
)
with gr.Column(scale=5):
id_result_output = gr.JSON()
with gr.Column(scale=2):
image_result_output = gr.HTML()
id_examples.outputs = [id_result_output, image_result_output]
id_recognition_button.click(idcard_recognition, inputs=[id_image_input1, id_image_input2], outputs=[id_result_output, image_result_output])
with gr.TabItem("Barcode Recognition"):
with gr.Row():
with gr.Column(scale=3):
barcode_image_input = gr.Image(type='filepath')
barcode_recognition_button = gr.Button("Barcode Recognition")
with gr.Column(scale=5):
barcode_result_output = gr.JSON()
with gr.Column(scale=2):
image_result_output = gr.HTML()
barcode_recognition_button.click(barcode_recognition, inputs=barcode_image_input, outputs=[barcode_result_output, image_result_output])
with gr.TabItem("Credit Card Recognition"):
with gr.Row():
with gr.Column(scale=3):
credit_image_input = gr.Image(type='filepath')
credit_recognition_button = gr.Button("Credit Card Recognition")
credit_examples = gr.Examples(
examples=['samples/c1.jpg', 'samples/c2.jpg', 'samples/c3.jpg'],
inputs=credit_image_input,
outputs=None,
fn=credit_recognition
)
with gr.Column(scale=5):
credit_result_output = gr.JSON()
with gr.Column(scale=2):
image_result_output = gr.HTML()
credit_examples.outputs = [credit_result_output, image_result_output]
credit_recognition_button.click(credit_recognition, inputs=credit_image_input, outputs=[credit_result_output, image_result_output])
demo.launch(server_name="0.0.0.0", server_port=7860)