《OpenCV计算机视觉》--介绍及基础操作

文章目录

《OpenCV计算机视觉》--介绍及基础操作

一.OpenCV介绍

OpenCV(open source computer vision library)是一个基于BSD许可(开源)发行的跨平台计算机视觉库,可以运行在Linux、Windows、Android和Mac OS操作系统上。

它轻量级而且高效------由一系列 C 函数和少量 C++ 类构成,同时提供了Python、Ruby、MATLAB等语言的接口,实现了图像处理和计算机视觉方面的很多通用算法。

OpenCV用C++语言编写,它的主要接口也是C++语言,但是依然保留了大量的C语言接口。

在计算机视觉项目的开发中,OpenCV作为较大众的开源库,拥有了丰富的常用图像处理函数库,采用C/C++语言编写,可以运行在Linux/Windows/Mac等操作系统上,能够快速的实现一些图像处理和识别的任务。

二.下载OpenCV

  • pip install opencv-python

注意:下载虽然使用opencv-python,但是在python中调用使用import cv2。

三.基础操作

1.调用OpenCV

python 复制代码
import cv2

2.读取图片信息

python 复制代码
a = cv2.imread('demo1.png') #读取图片
print(a)
cv2.imshow('tu',a) # 展示图片
b = cv2.waitKey(10000) # 展示时间,当为0时为一直保留
print(b)
cv2.destroyAllWindows() #关闭所有窗口,并释放内存
print("图片形状(shape):",a.shape)
print("图片数据类型(dtype)",a.dtype)
print("图片大小(size):",a.size)

3.读取图片的灰度图

python 复制代码
b = cv2.imread('demo1.png',cv2.IMREAD_GRAYSCALE) # 使用opencv的IMREAD_GRAYSCALE方法,使彩色图片转换成灰度图
cv2.imshow('xx',b)
cv2.waitKey(0)
print(b.shape)
print(b.dtype)
print(b.size)
cv2.imwrite('demo1_GRAY.png',b) # 将图片保存到根目录
cv2.destroyAllWindows()

4.视频文件读取

python 复制代码
video_capture = cv2.VideoCapture(xxxx.mp4) # 当cv2.VideoCapture()中是0时调用摄像头
# 检查视频是否成功打开
if not video_capture.isOpened():
    print('无法打开视频文件')
    exit()
# 循环读取视频帧
while True:
    ret, frame = video_capture.read()
    if not ret:
        break
     # 将图片从一种颜色转换成另一种颜色空间
    frame = cv2.cvtColor(frame,cv2.COLOR_BGR2GRAY)
    # 显示当前帧
    cv2.imshow('Video',frame)
    # 检查用户是否按下'esc'键,如果是则退出循环
    if cv2.waitKey(1) == 27:
        break
# 释放资源
video_capture.release()
cv2.destroyAllWindows()

5.对图片进行切片

python 复制代码
a = cv2.imread(r'./demo1.png')
b = a[100:300,100:300] # 进行切片
cv2.imshow('yuantu',a)
cv2.imshow('qiepian',b)
cv2.waitKey(0)
cv2.destroyAllWindows()

6.提取RGB颜色通道

python 复制代码
import cv2
a = cv2.imread(r'./demo1.png')
# 提取颜色通道
a1=a[:,:,0] # B
a2=a[:,:,1] # G
a3=a[:,:,2] # R

# 或者使用cv2.split()来分离颜色通道
b , g, r = cv2.split(a)

cv2.imshow('result',a2)

cv2.waitKey(0)
cv2.destroyAllWindows()

图片提取出来可以看到图片无论是a1,a2,a3都是灰色图片,因为提取后的图片都是一维的都是灰度图。

故此可以使用一下方法提取颜色:

python 复制代码
a = cv2.imread(r'./demo1.png')

a_new = a.copy()
a_new[:,:,0]=0
a_new[:,:,1]=0

cv2.imshow('result',a_new)
cv2.waitKey(0)
cv2.destroyAllWindows()

7.合并颜色通道

python 复制代码
# 读取图像
a = cv2.imread(r'./demo1.png')
# 提取颜色通道
a1 = a[:, :, 0]
a2 = a[:, :, 1]
a3 = a[:, :, 2]
# 或使用cv2.split()来分离颜色通道
b, g, r = cv2.split(a)
# 使用cv2.merge()函数将三个通道合并成一个图像
img = cv2.merge((b, g, r))
# img = cv2.merge((a1,a2,a3))或使用这串代码
cv2.imshow('result', img)
cv2.waitKey(0)
cv2.destroyAllWindows()

8.图片修改

图片打码
python 复制代码
import numpy as np
a = cv2.imread(r'demo1.png')
a[100:200,200:300]= np.random.randint(0,256,(100,100,3)) # 将a中的宽100到200和高200到300变成马赛克,注意后面的(100,100,3)要和前面所截取的大小相同。
cv2.imshow('masaike',a)
cv2.waitKey(0)
cv2.destroyAllWindows()
图片组合
python 复制代码
a= cv2.imread('demo1.png')
b = cv2.imread('demo2.png')
b[200:500,100:400]= a[200:500,200:500]
cv2.imshow('b',b)
cv2.imshow('a',a)
cv2.waitKey(0)
cv2.destroyAllWindows()

9.cv2.resize

cv2.resize()方法是用来改变图片的大小的

python 复制代码
a = cv2.imread('demo1.png')
# a_new = cv2.resize(a,(300,500)) # 宽、高 或者下面这种方法
a_new = cv2.resize(a,dsize=None,fx=0.5,fy=0.5)
cv2.imshow('a',a)
cv2.imshow('a_new',a_new)
cv2.waitKey(0)
cv2.destroyAllWindows()

10.图形运算

图像加法运算
python 复制代码
a = cv2.imread('demo1.png')
b = cv2.imread('demo2.png')
c = a+10
cv2.imshow('yuan',a)
cv2.imshow('a+10',c)
cv2.waitKey(10000)

c=a[100:300,50:250]+b[100:300,50:250]
cv2.imshow('a+b',c)
cv2.waitKey(10000)
cv2.add()运算

cv2.add()是 OpenCV 库中的一个函数,用于对两个数组(通常是图像或矩阵)进行加法操作。

python 复制代码
a = cv2.imread('demo1.png')
b = cv2.imread('demo2.png')
b = cv2.resize(b,(400,400))
a = cv2.resize(a,(400,400))
c = cv2.add(a,b)
cv2.imshow('a add b',c)
cv2.waitKey(10000)
图像加权运算
python 复制代码
a = cv2.imread('demo1.png')
b = cv2.imread('demo2.png')
b = cv2.resize(b, (400,400))
a = cv2.resize(a, (400,400))
c = cv2.addWeighted(a, 0.5,b, 0.3,0) # 分别将图片的权值占比改变
cv2.imshow('addWeighted',c)
cv2.waitKey(10000)
cv2.destroyAllWindows()
相关推荐
Elastic 中国社区官方博客26 分钟前
使用 Elasticsearch 导航检索增强生成图表
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·全文检索
云天徽上1 小时前
【数据可视化】全国星巴克门店可视化
人工智能·机器学习·信息可视化·数据挖掘·数据分析
大嘴吧Lucy1 小时前
大模型 | AI驱动的数据分析:利用自然语言实现数据查询到可视化呈现
人工智能·信息可视化·数据分析
AI技术控1 小时前
计算机视觉算法实战——无人机检测
算法·计算机视觉·无人机
艾思科蓝 AiScholar1 小时前
【连续多届EI稳定收录&出版级别高&高录用快检索】第五届机械设计与仿真国际学术会议(MDS 2025)
人工智能·数学建模·自然语言处理·系统架构·机器人·软件工程·拓扑学
watersink2 小时前
面试题库笔记
大数据·人工智能·机器学习
Yuleave2 小时前
PaSa:基于大语言模型的综合学术论文搜索智能体
人工智能·语言模型·自然语言处理
数字化综合解决方案提供商2 小时前
【Rate Limiting Advanced插件】赋能AI资源高效分配
大数据·人工智能
一只码代码的章鱼2 小时前
机器学习2 (笔记)(朴素贝叶斯,集成学习,KNN和matlab运用)
人工智能·机器学习
周杰伦_Jay3 小时前
简洁明了:介绍大模型的基本概念(大模型和小模型、模型分类、发展历程、泛化和微调)
人工智能·算法·机器学习·生成对抗网络·分类·数据挖掘·transformer