Django中上传的图片经过OpenCV处理后在前端显示

本文介绍如何将OpenCV处理后的图片转换为Base64格式,以便在前端HTML页面中显示。通过JavaScript和Django的配合,实现图片的处理与传输。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  OpenCV打开的图片都是以Mat(矩阵)的形式打开,直接传到前端就是一堆矩阵数字,不能正常显示。众所周知,在HTML上显示图片,用到的img标签都是以src的形式写的,base64格式可以代替src中需要填写的地址。因此,可以将OpenCV处理之后的图片转为base64再传输
  JavaScript的写法如下:dataType是从后端传回到前端的数据格式,必须以text的形式,这样传递的数据就能够直接在dom渲染的地方使用。$(’#newpic’)处表示的就是对dom进行新的渲染。

 $.ajax({
            url: "/getimg", //请求路径
            type: 'POST', // 请求类型
            data: formData, // 请求数据
            //dataType: "JSON", // JSON格式不对
            dataType: "text", // 返回数据格式
            contentType: false, //表示不处理数据
            processData: false,
            cache: false,
            success: function (data) {
                console.log("上传成功打印:"+data);
                if (data != null){
                    console.log("返回的数据:"+data)
                    $('#newpic').append("<img src="+'"data:image/jpg;base64,'+data+'">')
                }
                if (data == null){
                    console.log("返回数据为空")
                }
            },
            error: function (data) {
                console.log("数据返回失败")
                console.log(data);
            }
        });

  Django的后端代码如下,注释已经很清楚了。

def getimg(request):
    print("in")
    try:
        # 当不使用JS时
        # image = request.FILES.get('images')
        # 当使用ajax时
        # 得到img文件
        image = request.FILES['img']
  		# path需要修改
  		# path表示的是图片从前端上传之后,在服务器某处存储(这里写的比较简单,可换用数据库等等)
        path = default_storage.save('static/' + image.name, ContentFile(image.read()))
        print(path.__str__())
        # 保存图像
        os.path.join(settings.MEDIA_ROOT, path)
        # 调用opencv库
        # face_xml_location = os.path.join('.','haarcascade_frontalface_default.xml')
        # 声明cascadeclassifie对象face_cascade,用于检测人脸
        face_cascade = cv2.CascadeClassifier('DjangoBlog/haarcascade_frontalface_default.xml')
        img = cv2.imread('static/'+image.name)
        # openCV识别灰度图片,也就是黑白图片,所以要进行转换
        gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
        faces = face_cascade.detectMultiScale(gray, 1.3, 5)
        # 在人脸周围绘制矩形
        for (x, y, w, h) in faces:
            #得到的是矩阵形式的图片
            img = cv2.rectangle(img, (x, y), (x + w, y + h), (255, 0, 0), 0)
        # 此处是核心部分:OPENCV转BASE64
        img1 = cv2.imencode('.jpg',img)[1]
        back_2 = base64.b64encode(img1)
        print(back_2)
        
        return HttpResponse(back_2)
    except:
        return HttpResponse("<p>图片上传不成功</p>")

  话外:在新插入一个dom的时候,需要实现写好这个dom的CSS样式,或者用于渲染的代码上需要写上该dom的css样式。

  关于dom的base64渲染

$('#newpic').append("<img src="+'"data:image/jpg;base64,'+data+'">')

data:,文本数据
data:text/plain,文本数据
data:text/html,HTML代码
data:text/html;base64,base64编码的HTML代码
data:text/css,CSS代码
data:text/css;base64,base64编码的CSS代码
data:text/javascript,Javascript代码
data:text/javascript;base64,base64编码的Javascript代码
编码的gif图片数据
编码的png图片数据
编码的jpeg图片数据
编码的icon图片数据
但是这种方法不兼容IE6/7,使用时要注意!



在项目之外,记载PIL/OpenCV/base64相互转换(非原创),转自:https://blog.youkuaiyun.com/haveanybody/article/details/86494063

##PIL读取、保存图片方法
from PIL import Image
img = Image.open(img_path)
img.save(img_path2)
 
 
##cv2读取、保存图片方法
import cv2
img = cv2.imread(img_path)
cv2.imwrite(img_path2, img)
 
 
##图片文件打开为base64
import base64
 
def img_base64(img_path):
    with open(img_path,"rb") as f:
        base64_str = base64.b64encode(f.read())
    return base64_str 

1、PIL和cv2转换

##PIL转cv2
import cv2
from PIL import Image
import numpy as np
 
def pil_cv2(img_path):
    image = Image.open(img_path)
    img = cv2.cvtColor(np.asarray(image),cv2.COLOR_RGB2BGR)
    return img
 
 
##cv2转PIL
import cv2
from PIL import Image
 
def cv2_pil(img_path):
    image = cv2.imread(img_path)
    image = Image.fromarray(cv2.cvtColor(image,cv2.COLOR_BGR2RGB))
    return image

2、PIL和base64转换

##PIL转base64
import base64
from io import BytesIO
 
def pil_base64(image):
    img_buffer = BytesIO()
    image.save(img_buffer, format='JPEG')
    byte_data = img_buffer.getvalue()
    base64_str = base64.b64encode(byte_data)
    return base64_str
 
 
##base64转PIL
import base64
from io import BytesIO
from PIL import Image
 
def base64_pil(base64_str):
    image = base64.b64decode(base64_str)
    image = BytesIO(image)
    image = Image.open(image)
    return image

3、cv2和base64转换

##cv2转base64
import cv2
 
def cv2_base64(image):
    base64_str = cv2.imencode('.jpg',image)[1].tostring()
    base64_str = base64.b64encode(base64_str)
    return base64_str 
 
 
##base64转cv2
import base64
import numpy as np
import cv2
 
def base64_cv2(base64_str):
    imgString = base64.b64decode(base64_str)
    nparr = np.fromstring(imgString,np.uint8)  
    image = cv2.imdecode(nparr,cv2.IMREAD_COLOR)
    return image

其他有价值的参考:
图像前后端的数据交互及图像格式的转换(python、opencv)
https://blog.youkuaiyun.com/zsycode/article/details/91320053
通过template渲染的形式从后端写入图片
https://blog.youkuaiyun.com/liuweiyuxiang/article/details/71152956
使用Django StreamingHttpResponse实现opencv处理图片后进行web视频流播放
http://javabin.cn/2018/django_steam.html
python cv2展示网络图片、图片编解码、及与base64转换
https://www.cnblogs.com/gmhappy/p/11863946.html

OpenCV(Open Source Computer Vision Library)是一款开源的计算机视觉库,专门为图像和视频处理任务设计,广泛应用于学术研究、工业应用以及个人项目中。以下是关于OpenCV的详细介绍: 历史与发展 起源:OpenCV于1999年由英特尔公司发起,旨在促进计算机视觉技术的普及和商业化应用。该项目旨在创建一个易于使用、高效且跨平台的库,为开发者提供实现计算机视觉算法所需的基础工具。 社区与支持:随着时间的推移,OpenCV吸引了全球众多开发者和研究人员的参与,形成了活跃的社区。目前,OpenCV由非盈利组织OpenCV.org维护,并得到了全球开发者、研究机构以及企业的持续贡献和支持。 主要特点 跨平台:OpenCV支持多种操作系统,包括但不限于Windows、Linux、macOS、Android和iOS,确保代码能够在不同平台上无缝运行。 丰富的功能:库中包含了数千个优化过的函数,涵盖了计算机视觉领域的诸多方面,如图像处理(滤波、形态学操作、色彩空间转换等)、特征检测与描述(如SIFT、SURF、ORB等)、物体识别与检测(如Haar级联分类器、HOG、DNN等)、视频分析、相机校正、立体视觉、机器学习(SVM、KNN、决策树等)、深度学习(基于TensorFlow、PyTorch后端的模型加载与部署)等。 高效性能:OpenCV代码经过高度优化,能够利用多核CPU、GPU以及特定硬件加速(如Intel IPP、OpenCL等),实现高速图像处理和实时计算机视觉应用。 多语言支持:尽管OpenCV主要使用C++编写,但它提供了丰富的API绑定,支持包括C、Python、Java、MATLAB、JavaScript等多种编程语言,方便不同领域的开发者使用。 开源与免费:OpenCV遵循BSD开源许可证发布,用户可以免费下载、使用、修改和分发库及其源代码,无需担心版权问题。 架构与核心模块 OpenCV的架构围绕核心模块构建,这些模块提供了不同层次的功能: Core:包含基本的数据结构(如cv::Mat用于图像存储和操作)、基本的图像和矩阵操作、数学函数、文件I/O等底层功能。 ImgProc:提供图像预处理、滤波、几何变换、形态学操作、直方图计算、轮廓发现与分析等图像处理功能。 HighGui:提供图形用户界面(GUI)支持,如图像和视频的显示、用户交互(如鼠标事件处理)以及简单的窗口管理。 VideoIO:负责视频的读写操作,支持多种视频格式和捕获设备。 Objdetect:包含预训练的对象检测模型(如Haar级联分类器用于人脸检测)。 Features2D:提供特征点检测(如SIFT、ORB)与描述符计算、特征匹配与对应关系估计等功能。 Calib3d:用于相机标定、立体视觉、多视图几何等问题。 ML:包含统机器学习算法,如支持向量机(SVM)、K近邻(KNN)、决策树等。 DNN:深度神经网络模块,支持导入和运行预训练的深度学习模型,如卷积神经网络(CNN)。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值