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

标签 javascript python html flask html5-canvas

我正在将 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/

相关文章:

javascript - chart.js-datalabels-plugins 不起作用

javascript - 我想从 javascript 随机改变渐变 Angular

python - 双 for 循环列表理解

python - 仅将 Python 中字符串的首字母大写

javascript - 索引键上的 cursor.skip() 总是更快吗?

javascript - redux Actions 必须是普通对象,但我定义了普通对象

没有方法的Python模块包

html - 下拉菜单不显示

jquery - jQuery removeClass 有问题

javascript - 如何为一个 div 设置动画以显示并移动到另一个 div 上方