Opencv实现图片的边界填充和阈值处理

Opencv实现图片的边界填充和阈值处理

目录

图片的边界填充


指定颜色填充

BORDER_CONSTANT

  • 格式:cv2.copyMakeBorder(a,t,b,l,r,borderType=BORDER_CONSTANT,value=(b,g,r))
    • a:为图片变量
    • t,b,l,r :为边界长度 ,顺序是上下左右
    • borderType :可以设置边界类型 ,这里为BORDER_CONSTANT,指定颜色填充
    • value设置边界填充的颜色,色块顺序是BGR,为0-255的整数

代码展示:

python 复制代码
a = cv2.imread('at1.png')
t,b,l,r = 40,40,40,40
a_cnostant = cv2.copyMakeBorder(a,t,b,l,r,borderType=cv2.BORDER_CONSTANT,value=(255,255,255))
cv2.imshow('a',a)
cv2.waitKey(0)
cv2.imshow('a_cnostant',a_cnostant)
cv2.waitKey(0)

运行结果:

镜面反射填充

  • 格式:cv2.copyMakeBorder(a,t,b,l,r,borderType=BORDER_REFLECT)
    borderType:
    • BORDER_REFLECT,镜面反射填充,交接处不删除
    • BORDER_REFLECT101,镜面反射填充,交接处删除

代码展示:

python 复制代码
a = cv2.imread('at1.png')
t,b,l,r = 70,70,70,70
a_reflect = cv2.copyMakeBorder(a,t,b,l,r,borderType=cv2.BORDER_REFLECT)
a_reflect101 = cv2.copyMakeBorder(a,t,b,l,r,borderType=cv2.BORDER_REFLECT101)
cv2.imshow('a_reflect',a_reflect)
cv2.waitKey(0)
cv2.imshow('a_reflect101',a_reflect101)
cv2.waitKey(0)

运行结果:

边界像素值替换

  • 格式:cv2.copyMakeBorder(a,t,b,l,r,borderType=BORDER_REPLICATE)
    borderType:
    • BORDER_REPLICATE,边界像素值替换,如aaaa,bbbbb类似,||||类似
    • BORDER_WRAP,上下左右相互替换为边界

代码展示:

python 复制代码
a = cv2.imread('at1.png')
t,b,l,r = 40,40,40,40
a_replicate = cv2.copyMakeBorder(a,t,b,l,r,borderType=cv2.BORDER_REPLICATE)
cv2.copyMakeBorder(a,t,b,l,r,borderType=cv2.BORDER_WRAP)
cv2.imshow('a_replicate',a_replicate)
cv2.waitKey(0)
cv2.imshow('a_wrap',a_wrap)
cv2.waitKey(0)

运行结果:

图片的阈值处理


基本格式

图片要进行阈值处理必须先转为灰度图,否则不能处理

基本格式:cv2.threshold(a,t,m,cv2.THRESH_XXXX)
a:图像变量
t:thresh数值,在0-255间,与像素值像比较
m:maxval数值,设置像素最大值,一般为255
cv2.THRESH_XXXX:XXXX决定处理类型

返回值:有两个,第一个是t(thresh数值),第二个是图像

基本类型

  • BINARY
    a的像素值> t(即图像的像素值 、thresh数值)时,取值为maxval,否则为0
  • BINARY_INV
    a的像素值> t 时,取值为maxval,否则为0
  • TRUNC
    a的像素值> t 时,取值为t(thresh值),否则为a原图像像素值
  • TOZERO
    a的像素值> t 时,a原图像像素值,否则为0
  • TOZERO_INV
    a的像素值> t 时,为0,否则为a原图像像素值

代码展示:

t 也可以自己调整修改 ,BINARY和BINARY_INV类型更突出

python 复制代码
a = cv2.imread('at1.png',0)
r1,a_binary = cv2.threshold(a,150,255,cv2.THRESH_BINARY)
r2,a_binary_inv = cv2.threshold(a,150,255,cv2.THRESH_BINARY_INV)
r3,a_trunc = cv2.threshold(a,150,255,cv2.THRESH_TRUNC)
r4,a_tozero = cv2.threshold(a,150,255,cv2.THRESH_TOZERO)
r5,a_tozero_inv = cv2.threshold(a,150,255,cv2.THRESH_TOZERO_INV)
cv2.imshow('a',a)
cv2.waitKey(0)
cv2.imshow('a_binary',a_binary)
cv2.waitKey(0)
cv2.imshow('a_binary_inv',a_binary_inv)
cv2.waitKey(0)
cv2.imshow('a_trunc',a_trunc)
cv2.waitKey(0)
cv2.imshow('a_tozero',a_tozero)
cv2.waitKey(0)
cv2.imshow('a_tozero_inv',a_tozero_inv)
cv2.waitKey(0)
print(r1,r2,r3,r4,r5)
cv2.destroyAllWindows()

运行结果:

相关推荐
AI前沿技术追踪几秒前
OpenAI 12天发布会:AI革命的里程碑@附35页PDF文件下载
人工智能
jndingxin5 分钟前
OpenCV相机标定与3D重建(26)计算两个二维点集之间的部分仿射变换矩阵(2x3)函数 estimateAffinePartial2D()的使用
opencv·3d
余~~185381628007 分钟前
稳定的碰一碰发视频、碰一碰矩阵源码技术开发,支持OEM
开发语言·人工智能·python·音视频
0zxm17 分钟前
06 - Django 视图view
网络·后端·python·django
galileo201638 分钟前
LLM与金融
人工智能
DREAM依旧1 小时前
隐马尔科夫模型|前向算法|Viterbi 算法
人工智能
ROBOT玲玉1 小时前
Milvus 中,FieldSchema 的 dim 参数和索引参数中的 “nlist“ 的区别
python·机器学习·numpy
GocNeverGiveUp1 小时前
机器学习2-NumPy
人工智能·机器学习·numpy
Kai HVZ2 小时前
python爬虫----爬取视频实战
爬虫·python·音视频
古希腊掌管学习的神2 小时前
[LeetCode-Python版]相向双指针——611. 有效三角形的个数
开发语言·python·leetcode