gpt4 book ai didi

javascript - 如何使用 Flask 将 Canvas url 转换为图像 numpy 数组?

转载 作者:行者123 更新时间:2023-11-28 00:39:41 25 4
gpt4 key购买 nike

我正在将 Canvas 转换为 url 并使用 Flask 通过 ajax POST 请求将其发送到 python。我得到的网址没问题,甚至打印出来,两者都是一样的。但我不知道如何找回图像。我在互联网上搜索,大多数答案都说使用解码方法,但我收到解码无法在“str”对象上工作的错误。我还尝试将 StringIO 与 Image.open 一起使用,这也会出错。那么,任何人都可以告诉我该怎么做吗?我的 JS:

$SCRIPT_ROOT = {
{
request.script_root | tojson | safe
}
};
$(function() {
$("#pic").bind('click', function() {
ctx.drawImage(video, 0, 0, canvas.width, canvas.height);
var imgURL = canvas.toDataURL();

$.ajax({
type: "POST",
url: $SCRIPT_ROOT + '/send_pic',
data: {
imageBase64: imgURL
}
}).done(function() {
console.log("sent");
});
});

我的 python 代码:

@app.route('/send_pic',methods=['GET','POST'])
def button_pressed():
print("Image recieved")
data_url = request.values['imageBase64']
img = Image.open(StringIO(data_url))
img = np.array(img)
cv2.imshow(img)
cv2.waitKeys(0)
cv2.destroyAllWindows()

return ""

data_url 的值为:



谢谢!!!

最佳答案

从您的代码中我了解到,在您的端点中您需要 base64 数据。如果是这样,你可以尝试这样的事情:

import base64
from io import BytesIO

@app.route('/send_pic',methods=['GET','POST'])
def button_pressed():
print("Image recieved")
data_url = request.values['imageBase64']
# Decoding base64 string to bytes object
img_bytes = base64.b64decode(data_url)
img = Image.open(BytesIO(img_bytes))
img = np.array(img)
cv2.imshow(img)
cv2.waitKeys(0)
cv2.destroyAllWindows()
return ""

编辑:如果您发送的数据不是 base64,那么您可以尝试像这样使用 numpy 对其进行转换:

from flask import request
...
img_data = np.fromstring(request.data, np.uint8)
# Do what you want with it
cv2.imshow(img)

编辑 2:根据您提供的值,您必须从请求中拆分值以获取 base64 图像数据:

@app.route('/send_pic',methods=['GET','POST'])
def button_pressed():
print("Image recieved")
data_url = request.values['imageBase64']
# Decoding base64 string to bytes object
offset = data_url.index(',')+1
img_bytes = base64.b64decode(data_url[offset:])
img = Image.open(BytesIO(img_bytes))
img = np.array(img)
cv2.imshow(img)
cv2.waitKeys(0)
cv2.destroyAllWindows()
return ""

关于javascript - 如何使用 Flask 将 Canvas url 转换为图像 numpy 数组?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54198488/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com