
本文介绍了如何在 Gradio 应用中使用自定义 JavaScript 事件处理程序与 Python 代码进行交互。通过在 Gradio 应用中嵌入 JavaScript 代码,监听特定事件,并将事件数据传递回 Python 函数,实现更灵活的前后端交互。本文提供了一个具体示例,展示了如何监听图像点击事件,并将点击坐标传递给 Python 函数进行处理。
在 Gradio 应用中,有时我们需要利用 JavaScript 监听特定事件,并将事件数据传递回 Python 代码进行处理。虽然 Gradio 提供了自定义 JavaScript 的功能,但直接将 JavaScript 事件数据传递到 Python 函数并非易事。本文将介绍一种利用隐藏的文本框作为桥梁,实现 JavaScript 和 Python 之间数据传递的方法。
该方案的核心思想是:
以下代码演示了如何监听图像点击事件,并将点击坐标传递给 Python 函数。
立即学习“Java免费学习笔记(深入)”;
import gradio as gr
script = """
function setupClick() {
console.log("BEFORE");
const video = document.getElementById("video_feed");
const textbox = document.getElementById("output_box");
if (!video) {
console.log("Required elements not found.");
return;
}
const boundingBox = video.getBoundingClientRect();
const outputBox = document.querySelector("#real_box textarea")
video.addEventListener("click", function handleClick(event) {
console.log("Got click: ", event);
const relativeX = event.clientX - boundingBox.left;
const relativeY = event.clientY - boundingBox.top;
const message = `Clicked at X: ${Math.round(relativeX)} Y: ${Math.round(relativeY)}`;
console.log(message);
outputBox.value = message;
let event2 = new Event("input")
outputBox.dispatchEvent(event2);
}, false);
console.log("AFTER");
return 'Animation created';
}
"""
def handle_click(x=0, y=0):
return f"Received from JS: X={x}, Y={y}"
def handle_textbox_change(text):
return "Received from JS: " + text
with gr.Blocks(js=script) as demo:
gr.Markdown("Click on the image to trigger a Python function")
output = gr.Textbox(label="Response from Python", elem_id="real_box")
textbox = gr.Textbox(elem_id="output_box")
textbox.change(fn=handle_textbox_change, inputs=textbox, outputs=output)
# Add a visible image to click on
img = gr.Image(value="test_images/frog.jpg", elem_id="video_feed")
demo.launch()代码解释:
本文介绍了一种利用隐藏文本框和 Gradio change 事件,实现 JavaScript 和 Python 之间数据传递的方法。虽然这种方法有一些限制,但它可以快速解决一些简单的前后端交互问题。在实际应用中,应根据具体需求选择合适的解决方案。
以上就是使用 Gradio 中的自定义 JavaScript 事件处理程序的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号