opencv-python小课堂-day-02

# opencv的色彩空间

# 最常见的色彩空间就是RGB, 人眼也是基于RGB的色彩空间去分辨颜色
# opencv默认使用的是BGR,BGR和RGB色彩空间的区别在于图片在色彩通道上的排列顺序不同。

# OpenCV用的最多的色彩空间是HSV
# - Hue: 色相, 即色彩, 如红色, 蓝色. 用角度度量,取值范围为0°~360°,
# 从红色开始按逆时针方向计算,红色为0°,绿色为120°,蓝色为240°
# - Saturation: 饱和度, 表示颜色接近光谱色的程度。
# 一种颜色,可以看成是某种光谱色与白色混合的结果。
# 其中光谱色所占的比例愈大,颜色接近光谱色的程度就愈高,颜色的饱和度也就愈高。
# 饱和度高,颜色则深而艳。光谱色的白光成分为0,饱和度达到最高。
# 通常取值范围为0%~100%,值越大,颜色越饱和。
# - Value: 明度. 明度表示颜色明亮的程度,对于光源色,
# 明度值与发光体的光亮度有关;对于物体色,此值和物体的透射比或反射比有关。
# 通常取值范围为0%(黑)到100%(白)。


import cv2 as cv
def callback(value):
    pass
cv.namedWindow("color",cv.WINDOW_NORMAL)
cv.resizeWindow("color",(600,600))

img = cv.imread("./cat.jpeg")

# 常见色彩空间转换
colorspaces = [cv.COLOR_BGR2RGBA,cv.COLOR_BGR2BGRA,
              cv.COLOR_BGR2GRAY,cv.COLOR_BGR2HSV,
              cv.COLOR_BGR2YUV]

cv.createTrackbar("curcolor","color",0,4,callback)

while True:
    index = cv.getTrackbarPos("curcolor",'color')
    
#    颜色空间转换API
    cvt_img= cv.cvtColor(img,colorspaces[index])
    
    cv.imshow('color',cvt_img)
    
    key = cv.waitKey(10)
    if key == ord("q"):
        break
        
cv.destroyAllWindows()
# Mat介绍
# 在python中Mat数据对应numpy的ndarray, 使用numpy提供的深浅拷贝方法即可实现Mat的拷贝

import cv2 as cv
import numpy as np

img = cv.imread("./cat.jpeg")

# 浅拷贝
img2 = img.view()

# 深拷贝
img3 = img.copy()
img[10:100,10:100]=[0,0,255]

cv.imshow("img",img)
cv.imshow('img2', img2)
cv.imshow('img3', img3)

cv.waitKey(0)
cv.destroyAllWindows()
import cv2 as cv
import numpy as np

img = cv.imread("./cat.jpeg")

# shape属性中包括的了三个信息
# 高度、长度、通道数
print(img.shape)


# 图像占用多大空间
# 高度*长度*通道数
print(img.size)

# 图像中每个元素的位深
print(img.dtype)
# 绘制图形

# 画直线
# line(img,pt1,pt2,color,thickness,linetype,shift)
import cv2
import numpy as np

img = np.zeros((600,600,3),np.uint8)

# 画直线
cv.line(img,(10,20),(300,400),(0,0,255),2)

# 画矩形
cv.rectangle(img,(10,10),(50,50),(0,255,0),2)

# 画圆
cv.circle(img,(100,100),100,(255,0,0),2)

# 画椭圆
cv.ellipse(img,(320,240),(100,20),15,0,360,(255,255,0),2)

# 画多边形
pts = np.array([(300,10),(150,100),(450,100)],np.int32)
cv.polylines(img,[pts],True,(0,255,255))

# 填充多边形-fillPoly
pts1 = np.array([(200,30),(250,50),(350,150)],np.int32)
cv.fillPoly(img,[pts1],(0,255,255))

# 写字
cv.putText(img,"hello world",(400,400),)
cv.imshow("img",img)

cv2.waitKey(0)
cv2.destroyAllWindows()
# 绘制中文 opencv本身不支持, 因为没有中文字体.我们可以借助pillow来实现绘制中文
# 写字--中文

import cv2 as cv
import numpy as np
from PIL import ImageFont,ImageDraw, Image

img = np.full((500,500,3),fill_value = 0,dtype = np.uint8)

# 导入字体文件
font_path = "./STXINGKA.TTF"
font = ImageFont.truetype(font_path,15)
img_pil = Image.fromarray(img)

draw = ImageDraw.Draw(img_pil)
draw.text((10,120),'绘制中文',font = font,finll = (0,255,0,0))

img = np.array(img_pil)

cv.imshow("img",img)

cv2.waitKey(0)
cv2.destroyAllWindows()

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值