OpenCV---计算机图像基本 *** 作

OpenCV---计算机图像基本 *** 作,第1张

OpenCV---计算机图像基本 *** 作

【OpenCV+TensorFlow】清华博士带你做项目!计算机视觉实战+深度学习,项目可写进简历!(附源码资料)-人工智能/深度学习框架/RNN/池化层/感受_哔哩哔哩_bilibili

pip install opencv-python

ctrl+L快速清屏

 计算机中rgb范围0-255

矩阵形状 [500,500,3]

import cv2  # 读取的格式是BGR
import matplotlib.pyplot as plt
import numpy as np


# img = cv2.imread('rabbit.jpg')  # 读取路径不能包含中文,否则会为none
# print(img)
# cv2.imshow('image', img)  # 第一个为窗口名字
# cv2.waitKey(0)  # 等待时间,毫秒级,0表示任意键终止
# cv2.destroyAllWindows()

def cv_show(name, img):
    cv2.imshow('image', img)  # 第一个为窗口名字
    cv2.waitKey(0)  # 等待时间,毫秒级,0表示任意键终止
    cv2.destroyAllWindows()


# img.shape()


# img = cv2.imread('flower.jpg', cv2.IMREAD_GRAYSCALE)  # cv2.IMREAD.COLOR 彩色图像;cv2.IMREAD_GRAYSCALE灰度图像
# print(img.shape)
# cv2.imshow('image', img)  # 图像的显示,也可以创建多个窗口
# cv2.waitKey(10000)
# cv2.destroyAllWindows()
# cv2.imwrite('mygreyflower.png', img)  # 保存
# type(img)
# print(img.size)
# print(img.dtype)


# # 视频读取
# girl = cv2.VideoCapture("美女.mp4")
# # 检查是否打开
# if girl.isOpened():
#     open, frame = girl.read()  # open为bool值,如果第一帧可以读入,为true,frame接收每一帧图像信息
# else:
#     open = False
#
# while open:
#     ret, frame = girl.read()
#     if frame is None:  # 视频为空停止执行
#         break
#     if ret == True:
#         gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)  # 转成黑白图像
#         cv2.imshow('result', gray)
#         print(frame)
#         if cv2.waitKey(100) & 0xFF == 27:  # 27为退出键 
#             break
# girl.release()
# cv2.destroyAllWindows()


# 截取部分图像数据
# img = cv2.imread('flower.jpg')
# flower = img[0:200, 0:200]
# cv_show('flower', flower)

# # 颜色通道提取
# b, g, r = cv2.split(img)  # 分别提出3个通道
# print(b)
# print(b.shape)
# print(g.shape)
#
# img = cv2.merge((b, g, r))  # 合并3个通道
# print(img.shape)


# # 只保留R
# img = cv2.imread('flower.jpg')
# cur_img = img.copy()
# cur_img[:, :, 0] = 0
# cur_img[:, :, 1] = 0
# cv_show('R', cur_img)


# # 边界填充
# img = cv2.imread('flower.jpg')
# top_size, bottom_size, left_size, right_size = (50, 50, 50, 50)
# replicate = cv2.copyMakeBorder(img, top_size, bottom_size, left_size, right_size,
#                                borderType=cv2.BORDER_REPLICATE)  # 复制最边缘像素
# reflect = cv2.copyMakeBorder(img, top_size, bottom_size, left_size, right_size,
#                              cv2.BORDER_REFLECT)  # 反射法,fedcba|abcdefgh|hgfedcb
# reflect101 = cv2.copyMakeBorder(img, top_size, bottom_size, left_size, right_size,
#                                 cv2.BORDER_REFLECT_101)  # gfedcb|abcdefgh|gfedcba
# wrap = cv2.copyMakeBorder(img, top_size, bottom_size, left_size, right_size, cv2.BORDER_WRAP)  # cdefgh|abcdefgh|abcdefg
# constant = cv2.copyMakeBorder(img, top_size, bottom_size, left_size, right_size, cv2.BORDER_CONSTANT, value=0)  # 常数值填充
#
# plt.subplot(231), plt.imshow(img, 'gray'), plt.title("ORIGINAL")
# plt.subplot(232), plt.imshow(replicate, 'gray'), plt.title("REPLICATE")
# plt.subplot(233), plt.imshow(reflect, 'gray'), plt.title("REFLECT")
# plt.subplot(234), plt.imshow(reflect101, 'gray'), plt.title("REFLECT_101")
# plt.subplot(235), plt.imshow(wrap, 'gray'), plt.title("WRAP")
# plt.subplot(236), plt.imshow(constant, 'gray'), plt.title("CONSTANT")
# plt.show()

# # 图片加法
# img = cv2.imread('flower.jpg')
# img_flower2 = img + 10
# print(img_flower2[:5, :, 0])
# print((img_flower2 + img)[:5, :, 0])  # 越界取余
# print(cv2.add(img_flower2, img)[:5, :, 0])  # 越界取255


# # 图片融合
# img_flower = cv2.imread('flower.jpg')
# img_rabbit = cv2.imread('rabbit.jpg')
# print(img_flower.shape)
# print(img_rabbit.shape)
# img_rabbit = cv2.resize(img_rabbit, (319, 300))
# print(img_rabbit.shape)
# res = cv2.addWeighted(img_rabbit, 0.4, img_flower, 0.6, 0)
# plt.imshow(res)
# plt.show()


# img_flower = cv2.imread('flower.jpg')
# res = cv2.resize(img_flower, (0, 0), fx=3, fy=1)  # 倍数关系,变形
# plt.imshow(res)
# plt.show()


import cv2
import matplotlib.pyplot as plt
import numpy as np
img=cv2.imread(r"C:UsersRSBDesktopflower.jpg")
print(img)
cv2.imshow('image', img)  # 第一个为窗口名字
cv2.waitKey(0)  # 等待时间,毫秒级,0表示任意键终止
cv2.destroyAllWindows()

cv2.waitKey()   等待时间   cv2.waitKey(1000) 1000比100慢10倍

# b, g, r = cv2.split(img) # 分别提出3个通道

 

两种加法的区别

 

 

 

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5658444.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-16
下一篇 2022-12-16

发表评论

登录后才能评论

评论列表(0条)

保存