mirror of
https://github.com/HumanAIGC-Engineering/gradio-webrtc.git
synced 2026-02-05 18:09:23 +08:00
fix bugs + release version 0.0.4
This commit is contained in:
@@ -369,6 +369,10 @@ class WebRTC(Component):
|
|||||||
):
|
):
|
||||||
from gradio.blocks import Block
|
from gradio.blocks import Block
|
||||||
|
|
||||||
|
if inputs is None:
|
||||||
|
inputs = []
|
||||||
|
if outputs is None:
|
||||||
|
outputs = []
|
||||||
if isinstance(inputs, Block):
|
if isinstance(inputs, Block):
|
||||||
inputs = [inputs]
|
inputs = [inputs]
|
||||||
if isinstance(outputs, Block):
|
if isinstance(outputs, Block):
|
||||||
@@ -404,7 +408,7 @@ class WebRTC(Component):
|
|||||||
js=js,
|
js=js,
|
||||||
)
|
)
|
||||||
elif self.mode == "receive":
|
elif self.mode == "receive":
|
||||||
if self in cast(list[Block], inputs):
|
if isinstance(inputs, list) and self in cast(list[Block], inputs):
|
||||||
raise ValueError(
|
raise ValueError(
|
||||||
"In the receive mode stream event, the WebRTC component cannot be an input."
|
"In the receive mode stream event, the WebRTC component cannot be an input."
|
||||||
)
|
)
|
||||||
|
|||||||
72
demo/app_orig.py
Normal file
72
demo/app_orig.py
Normal file
@@ -0,0 +1,72 @@
|
|||||||
|
import gradio as gr
|
||||||
|
import cv2
|
||||||
|
from huggingface_hub import hf_hub_download
|
||||||
|
from gradio_webrtc import WebRTC
|
||||||
|
from twilio.rest import Client
|
||||||
|
import os
|
||||||
|
from inference import YOLOv10
|
||||||
|
|
||||||
|
model_file = hf_hub_download(
|
||||||
|
repo_id="onnx-community/yolov10n", filename="onnx/model.onnx"
|
||||||
|
)
|
||||||
|
|
||||||
|
model = YOLOv10(model_file)
|
||||||
|
|
||||||
|
account_sid = os.environ.get("TWILIO_ACCOUNT_SID")
|
||||||
|
auth_token = os.environ.get("TWILIO_AUTH_TOKEN")
|
||||||
|
|
||||||
|
if account_sid and auth_token:
|
||||||
|
client = Client(account_sid, auth_token)
|
||||||
|
|
||||||
|
token = client.tokens.create()
|
||||||
|
|
||||||
|
rtc_configuration = {
|
||||||
|
"iceServers": token.ice_servers,
|
||||||
|
"iceTransportPolicy": "relay",
|
||||||
|
}
|
||||||
|
else:
|
||||||
|
rtc_configuration = None
|
||||||
|
|
||||||
|
|
||||||
|
def detection(image, conf_threshold=0.3):
|
||||||
|
image = cv2.resize(image, (model.input_width, model.input_height))
|
||||||
|
new_image = model.detect_objects(image, conf_threshold)
|
||||||
|
return cv2.resize(new_image, (500, 500))
|
||||||
|
|
||||||
|
|
||||||
|
css = """.my-group {max-width: 600px !important; max-height: 600 !important;}
|
||||||
|
.my-column {display: flex !important; justify-content: center !important; align-items: center !important};"""
|
||||||
|
|
||||||
|
|
||||||
|
with gr.Blocks(css=css) as demo:
|
||||||
|
gr.HTML(
|
||||||
|
"""
|
||||||
|
<h1 style='text-align: center'>
|
||||||
|
YOLOv10 Webcam Stream (Powered by WebRTC ⚡️)
|
||||||
|
</h1>
|
||||||
|
"""
|
||||||
|
)
|
||||||
|
gr.HTML(
|
||||||
|
"""
|
||||||
|
<h3 style='text-align: center'>
|
||||||
|
<a href='https://arxiv.org/abs/2405.14458' target='_blank'>arXiv</a> | <a href='https://github.com/THU-MIG/yolov10' target='_blank'>github</a>
|
||||||
|
</h3>
|
||||||
|
"""
|
||||||
|
)
|
||||||
|
with gr.Column(elem_classes=["my-column"]):
|
||||||
|
with gr.Group(elem_classes=["my-group"]):
|
||||||
|
image = WebRTC(label="Stream", rtc_configuration=rtc_configuration)
|
||||||
|
conf_threshold = gr.Slider(
|
||||||
|
label="Confidence Threshold",
|
||||||
|
minimum=0.0,
|
||||||
|
maximum=1.0,
|
||||||
|
step=0.05,
|
||||||
|
value=0.30,
|
||||||
|
)
|
||||||
|
|
||||||
|
image.stream(
|
||||||
|
fn=detection, inputs=[image, conf_threshold], outputs=[image], time_limit=10
|
||||||
|
)
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
demo.launch()
|
||||||
57
demo/audio_out_2.py
Normal file
57
demo/audio_out_2.py
Normal file
@@ -0,0 +1,57 @@
|
|||||||
|
import gradio as gr
|
||||||
|
import numpy as np
|
||||||
|
from gradio_webrtc import WebRTC
|
||||||
|
from twilio.rest import Client
|
||||||
|
import os
|
||||||
|
from pydub import AudioSegment
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
account_sid = os.environ.get("TWILIO_ACCOUNT_SID")
|
||||||
|
auth_token = os.environ.get("TWILIO_AUTH_TOKEN")
|
||||||
|
|
||||||
|
if account_sid and auth_token:
|
||||||
|
client = Client(account_sid, auth_token)
|
||||||
|
|
||||||
|
token = client.tokens.create()
|
||||||
|
|
||||||
|
rtc_configuration = {
|
||||||
|
"iceServers": token.ice_servers,
|
||||||
|
"iceTransportPolicy": "relay",
|
||||||
|
}
|
||||||
|
else:
|
||||||
|
rtc_configuration = None
|
||||||
|
|
||||||
|
import time
|
||||||
|
|
||||||
|
def generation(num_steps):
|
||||||
|
for _ in range(num_steps):
|
||||||
|
segment = AudioSegment.from_file("/Users/freddy/sources/gradio/demo/audio_debugger/cantina.wav")
|
||||||
|
yield (segment.frame_rate, np.array(segment.get_array_of_samples()).reshape(1, -1))
|
||||||
|
time.sleep(3.5)
|
||||||
|
|
||||||
|
|
||||||
|
css = """.my-group {max-width: 600px !important; max-height: 600 !important;}
|
||||||
|
.my-column {display: flex !important; justify-content: center !important; align-items: center !important};"""
|
||||||
|
|
||||||
|
|
||||||
|
with gr.Blocks() as demo:
|
||||||
|
gr.HTML(
|
||||||
|
"""
|
||||||
|
<h1 style='text-align: center'>
|
||||||
|
Audio Streaming (Powered by WebRaTC ⚡️)
|
||||||
|
</h1>
|
||||||
|
"""
|
||||||
|
)
|
||||||
|
with gr.Row():
|
||||||
|
with gr.Column():
|
||||||
|
gr.Slider()
|
||||||
|
with gr.Column():
|
||||||
|
# audio = gr.Audio(interactive=False)
|
||||||
|
audio = WebRTC(label="Stream", rtc_configuration=rtc_configuration,
|
||||||
|
mode="receive", modality="audio")
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
demo.launch()
|
||||||
@@ -69,7 +69,6 @@ else:
|
|||||||
|
|
||||||
|
|
||||||
def detection(image, conf_threshold=0.3):
|
def detection(image, conf_threshold=0.3):
|
||||||
print("running detection")
|
|
||||||
image = cv2.resize(image, (model.input_width, model.input_height))
|
image = cv2.resize(image, (model.input_width, model.input_height))
|
||||||
new_image = model.detect_objects(image, conf_threshold)
|
new_image = model.detect_objects(image, conf_threshold)
|
||||||
return cv2.resize(new_image, (500, 500))
|
return cv2.resize(new_image, (500, 500))
|
||||||
|
|||||||
52
demo/video_out_stream.py
Normal file
52
demo/video_out_stream.py
Normal file
@@ -0,0 +1,52 @@
|
|||||||
|
import gradio as gr
|
||||||
|
from gradio_webrtc import WebRTC
|
||||||
|
from twilio.rest import Client
|
||||||
|
import os
|
||||||
|
import cv2
|
||||||
|
|
||||||
|
|
||||||
|
account_sid = os.environ.get("TWILIO_ACCOUNT_SID")
|
||||||
|
auth_token = os.environ.get("TWILIO_AUTH_TOKEN")
|
||||||
|
|
||||||
|
if account_sid and auth_token:
|
||||||
|
client = Client(account_sid, auth_token)
|
||||||
|
|
||||||
|
token = client.tokens.create()
|
||||||
|
|
||||||
|
rtc_configuration = {
|
||||||
|
"iceServers": token.ice_servers,
|
||||||
|
"iceTransportPolicy": "relay",
|
||||||
|
}
|
||||||
|
else:
|
||||||
|
rtc_configuration = None
|
||||||
|
|
||||||
|
|
||||||
|
def generation():
|
||||||
|
url = "https://download.tsi.telecom-paristech.fr/gpac/dataset/dash/uhd/mux_sources/hevcds_720p30_2M.mp4"
|
||||||
|
cap = cv2.VideoCapture(url)
|
||||||
|
iterating = True
|
||||||
|
while iterating:
|
||||||
|
iterating, frame = cap.read()
|
||||||
|
yield frame
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
with gr.Blocks() as demo:
|
||||||
|
gr.HTML(
|
||||||
|
"""
|
||||||
|
<h1 style='text-align: center'>
|
||||||
|
Video Streaming (Powered by WebRTC ⚡️)
|
||||||
|
</h1>
|
||||||
|
"""
|
||||||
|
)
|
||||||
|
output_video = WebRTC(label="Video Stream", rtc_configuration=rtc_configuration,
|
||||||
|
mode="receive", modality="video")
|
||||||
|
button = gr.Button("Start", variant="primary")
|
||||||
|
output_video.stream(
|
||||||
|
fn=generation, inputs=None, outputs=[output_video],
|
||||||
|
trigger=button.click
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
demo.launch()
|
||||||
@@ -148,6 +148,7 @@
|
|||||||
} else {
|
} else {
|
||||||
stop(pc);
|
stop(pc);
|
||||||
stream_state = "closed";
|
stream_state = "closed";
|
||||||
|
_time_limit = null;
|
||||||
await access_webcam();
|
await access_webcam();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ build-backend = "hatchling.build"
|
|||||||
|
|
||||||
[project]
|
[project]
|
||||||
name = "gradio_webrtc"
|
name = "gradio_webrtc"
|
||||||
version = "0.0.2"
|
version = "0.0.4"
|
||||||
description = "Stream images in realtime with webrtc"
|
description = "Stream images in realtime with webrtc"
|
||||||
readme = "README.md"
|
readme = "README.md"
|
||||||
license = "apache-2.0"
|
license = "apache-2.0"
|
||||||
|
|||||||
Reference in New Issue
Block a user