python3+Opencv 搭建环境和基本操作

一、必备前提:

Python3.5及以上版本、pip、windows环境

二、搭建opencv

该部分可以创建隔绝的Python环境来引入,参照virtualenv的使用

 在目标的cmd窗口,依次输入以下命令:

pip install --upgrade setuptools
pip install numpy Matplotlib
pip install opencv-python

如果下载中间出现error或wrong,重新输入命令即可。

如果多次下载失败,可以从http://www.lfd.uci.edu/~gohlke/pythonlibs/直接下载whl包安装,安装whl包依然使用pip

pip install 包的位置(如:C:\download\xxx.whl)

三、示例代码

读入图片:

cv.imread(filepath,flags)

filepath:要读入图片的完整路径
flags:读入图片的标志 
cv2.IMREAD_COLOR:默认参数,读入一副彩色图片,忽略alpha通道(1)
cv2.IMREAD_GRAYSCALE:读入灰度图片(0)
cv2.IMREAD_UNCHANGED:顾名思义,读入完整图片,包括alpha通道(-1)

支持 bmp、jpg、png、tiff 等常用格式,详情可以查看imread()方法的文档注释


显示图片:

cv.imshow('image',img)
cv.waitKey(0)
cv.destroyAllWindows()#cv.destroyWindow(wname)

cv2.imshow(wname,img)显示图像,第一个参数是显示图像的窗口的名字,第二个参数是要显示的图像(imread读入的图像),窗口大小自动调整为图片大小

cv2.waitKey顾名思义等待键盘输入,单位为毫秒,即等待指定的毫秒数看是否有键盘输入,若在等待时间内按下任意键则返回按键的ASCII码,程序继续运行。若没有按下任何键,超时后返回-1。参数为0表示无限等待。不调用waitKey的话,窗口会一闪而逝,看不到显示的图片。

cv2.destroyAllWindow()销毁所有窗口
cv2.destroyWindow(wname)销毁指定窗口

保存图片:

cv2.imwrite(file,img,num)

第一个参数是要保存的文件名,保存支持格式同读取,按需保存
第二个参数是要保存的图像。
可选的第三个参数,它针对特定的格式:对于JPEG,其表示的是图像的质量,用0 - 100的整数表示,默认95;对于png ,第三个参数表示的是压缩级别。默认为3.

cv2.IMWRITE_JPEG_QUALITY类型为 long ,必须转换成 int 
cv2.IMWRITE_PNG_COMPRESSION, 从0到9 压缩级别越高图像越小。

cv2.imwrite('1.jpeg',img, [int( cv2.IMWRITE_JPEG_QUALITY), 95])
cv2.imwrite('1.png',img, [int(cv2.IMWRITE_PNG_COMPRESSION), 9])

此处需注意,按照默认质量保存图片为JPEG files(\*.jpeg, \*.jpe, \*.jpg)时,由于jpeg压缩版本在压缩过程中导致了部分像素丢失,会导致保存后的像素点值与写入前有差别。

保存图片为png格式,即可以解决此问题

 

示例代码:读入一副图像,按’s’键保存后退出,其它任意键则直接退出不保存

import cv2 as cv
img = cv.imread('D:\python\test.jpg',cv2.IMREAD_UNCHANGED)
cv.imshow('image',img)
k = cv.waitKey(0)
if k == ord('s'): 
    # wait for 's' key to save and exit   
    cv.imwrite('1.png',img)    
    cv.destroyAllWindows()
else:     
    cv.destroyAllWindows()

 

四、图像的基本操作

创建图片

1.创建三通道

import numpy as np
import cv2 as cv

# 三通道
creat_img3 = np.zeros([400, 400, 3], np.uint8)  # 高400*宽400*通道3 单通道8位
creat_img3[:, :, 0] = np.ones([400, 400]) * 255  # 0(Blue)通道全部赋值255
creat_img3[:, :, 2] = np.ones([400, 400]) * 255  # 2(Red)通道全部赋值255
cv.imshow("create image3", creat_img3)

2.创建单通道

# 单通道
creat_img1 = np.zeros([400, 400, 1], np.uint8)
creat_img1[:, :, 0] = np.ones([400, 400]) * 127  # 单通道灰度图像
cv.imshow("create image1", creat_img1)

3.创建小尺寸

# 生成小尺寸图片
mini_img = np.ones([3, 3], np.float)
mini_img.fill(127.1)  # .fill方法填充数据
mini_img2 = mini_img.reshape([1, 9])  # reshape只改变形状,不改变数据
print(mini_img, mini_img2)

以上内容摘自:https://blog.csdn.net/l0ve777/article/details/88715704

读取图片并编辑

import cv2 as cv

img = cv.imread("D://test.jpeg")
#对 BGR 图像而言,返回值为 B, G, R 的值,对灰度图像而言,会返回他的灰度值。即彩图返回三通道三维数组,灰度图返回单通道三维数组,小图返回二维数组
print(img[100,100])      #[ 42  57 130]
print(img.item(100,100,2))   #130
img.itemset((100,100,2),25)  #img[100,100,2]=25
print(img.item(100,100,2))   #25

获取图像属性

import cv2 as cv

img = cv.imread("D://test.jpeg")
# img.shape 可以获取图像的形状。他的返回值是一个包含行数,列数,通道数的元组。行数对应坐标轴上的y轴,即高度;而列数对应x轴,即宽度。返回值可以理解为高度,宽度,通道数。
print(img.shape)     #(512, 512, 3)
# img.size 可以返回图像的像素数目。
print(img.size)    #786432
#img.dtype 返回的是图像的数据类型。
print(img.dtype)   #uint8

 设置ROI

ROI(Region of Interest)是指图像中的一个矩形区域,如果后续需要单独处理某一个小区域,可以设置ROI

import cv2 as cv

ballImg = img[380:512,230:350]   #利用numpy中的数组切片设置ROI区域
img[0:132,0:120] = ballImg       #将设置的ROI区域添加到原图像的左上方

cv.namedWindow("Image")
cv.imshow("Image", img)
cv.waitKey(0)

 

拆分及合并图像通道

要对单个通道进行操作的时候,需要拆分出单个通道,有2种方法

1)用opencv自带的split函数

 

保存图片

需注意按照需要,保存不同格式

 1 mini_img = np.ones([3, 3], np.uint8)
 2 mini_img.fill(127)  # .fill方法填充数据
 3 #mini_img2 = mini_img.reshape([1, 9])  # reshape只改变形状,不改变数据
 4 #print(mini_img, mini_img2)
 5 print(mini_img)
 6 cv.imshow("mini_img", mini_img)
 7 cv.waitKey(0) #毫秒级,0为无限等待
 8 cv.imwrite('mini.jpg', mini_img)
 9 
10 image = cv.imread('mini.jpg',0) #0表示灰度图
11 print(image)
12 
13 image[0][0] = 100 #image.itemset(0,100)
14 image[1][0] = 40  #image.itemset((1,0),40)
15 cv.imshow("mini_img", image)
16 cv.waitKey(0)
17 cv.imwrite('mini2.jpg', image)
18 
19 image = cv.imread('mini2.jpg',0)
20 print(image)

以上三处打印分别为:

[[127 127 127]
 [127 127 127]
 [127 127 127]]

[[127 127 127]
 [127 127 127]
 [127 127 127]]

[[100 126 125]
 [ 39 131 127]
 [128 127 124]]

发现,为灰度图(即像素数相同,为127)时,读图数据与写入一致,但是当改变了其中某些像素值后,读图数据发生了变化,

是由于jpeg压缩版本在压缩过程中导致了部分像素丢失,保存图片为tif格式或者png格式,即可以解决此问题

cv.imwrite('mini2.png', image)

image = cv.imread('mini2.png',0)

 

posted @ 2019-07-16 15:50  sen_c7  阅读(10365)  评论(0编辑  收藏  举报