当前位置: 首页 > news >正文

open cv学习 (五) 图像的阈值处理

图像的阈值处理

demo1
# 二值化处理黑白渐变图
import cv2
img = cv2.imread("./img.png", 0)
# 二值化处理
t1, dst = cv2.threshold(img, 127, 255, cv2.THRESH_BINARY)
cv2.imshow("img", img)
cv2.imshow("dst", dst)
cv2.waitKey()
cv2.destroyAllWindows()
demo2
# 二值化处理黑白渐变图
import cv2
img = cv2.imread("./img.png", 0)
# 二值化处理
t1, dst1 = cv2.threshold(img, 127, 255, cv2.THRESH_BINARY)
t2, dst2 = cv2.threshold(img, 210, 255, cv2.THRESH_BINARY)
cv2.imshow("img", img)
cv2.imshow("dst1", dst1)
cv2.imshow("dst2", dst2)
cv2.waitKey()
cv2.destroyAllWindows()
demo3
# 二值化处理黑白渐变图
import cv2
img = cv2.imread("./img.png", 0)
# 二值化处理
t1, dst1 = cv2.threshold(img, 127, 255, cv2.THRESH_BINARY)
t2, dst2 = cv2.threshold(img, 210,150, cv2.THRESH_BINARY)
cv2.imshow("img", img)
cv2.imshow("dst1", dst1)
cv2.imshow("dst2", dst2)
cv2.waitKey()
cv2.destroyAllWindows()
demo4
# 反二值化处理
import cv2
img = cv2.imread("./img.png", 0)
# 二值化处理
t1, dst1 = cv2.threshold(img, 127, 255, cv2.THRESH_BINARY)
t2, dst2 = cv2.threshold(img, 127, 255, cv2.THRESH_BINARY_INV)
cv2.imshow("img", img)
cv2.imshow("dst1", dst1)
cv2.imshow("dst2", dst2)
cv2.waitKey()
cv2.destroyAllWindows()
demo5
# 零处理---低于阈值0处理
import cv2
img = cv2.imread("./img.png", 1)
# 二值化处理
t1, dst1 = cv2.threshold(img, 127, 255, cv2.THRESH_TOZERO)
cv2.imshow("img", img)
cv2.imshow("dst1", dst1)
cv2.imwrite("./myimg.jpg", dst1)
cv2.waitKey()
cv2.destroyAllWindows()
demo6
# 零处理---高于阈值0处理
import cv2
img = cv2.imread("./img.png", 0)
# 二值化处理
t1, dst1 = cv2.threshold(img, 127, 255, cv2.THRESH_TOZERO_INV)
cv2.imshow("img", img)
cv2.imshow("dst1", dst1)
cv2.imwrite("./myimg.jpg", dst1)
cv2.waitKey()
cv2.destroyAllWindows()
demo7
# 截断处理---大于阈值阈值处理
import cv2
img = cv2.imread("./img.png")
img_gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
athdMEAM = cv2.adaptiveThreshold(img_gray, 255, cv2.ADAPTIVE_THRESH_MEAN_C, cv2.THRESH_BINARY, 5, 3)
athdGAUS = cv2.adaptiveThreshold(img_gray, 255, cv2.ADAPTIVE_THRESH_GAUSSIAN_C, cv2.THRESH_BINARY, 5, 3)
cv2.imshow("athdMEAM", athdMEAM)
cv2.imshow("athdGAUS", athdGAUS)
# cv2.imwrite("./myimg.jpg", dst1)
cv2.waitKey()
cv2.destroyAllWindows()
demo8
# OTsu方法
import cv2
img = cv2.imread("./img.png", 1)
img_gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)t1, dst1 = cv2.threshold(img_gray, 0, 255, cv2.THRESH_BINARY + cv2.THRESH_OTSU)
cv2.putText(dst1, "best threshold" + str(t1), (0, 30), cv2.FONT_HERSHEY_SIMPLEX, 1, (0, 0, 0), 2)cv2.imshow("dst1", dst1)
cv2.waitKey()
cv2.destroyAllWindows()
http://www.lryc.cn/news/129503.html

相关文章:

  • NVIDIA vGPU License许可服务器高可用全套部署秘籍
  • 基于CNN卷积神经网络的口罩检测识别系统matlab仿真
  • 《HeadFirst设计模式(第二版)》第九章代码——迭代器模式
  • Electron入门,项目启动。
  • 深入理解索引B+树的基本原理
  • vue3 简易用对话框实现点击头像放大查看
  • opencv 矩阵运算
  • 第四章 字符串part01
  • Python3内置函数大全
  • 什么是“新型基础设施”?建设重点是什么?
  • 混杂接口模式---vlan
  • Greenplum多级分区表添加分区报错ERROR: no partitions specified at depth 2
  • EV PV AC SPI CPI TCPI
  • 【电商领域】Axure在线购物商城小程序原型图,品牌自营垂直电商APP原型
  • Cpp基础Ⅰ之编译、链接
  • 用户新增预测(Datawhale机器学习AI夏令营第三期)
  • RGOS日常管理操作
  • 阿里云使用WordPress搭建个人博客
  • 供应链安全和第三方风险管理:讨论如何应对供应链中的安全风险,以及评估和管理第三方合作伙伴可能带来的威胁
  • 《Java极简设计模式》第04章:建造者模式(Builder)
  • Go download
  • 2023年Java核心技术面试第四篇(篇篇万字精讲)
  • 数字化时代,数据仓库和商业智能BI系统演进的五个阶段
  • 【【Verilog典型电路设计之FIFO设计】】
  • JAVA设计模式总结之23种设计模式
  • Flutter 测试小结
  • docker build -t 和 docker build -f 区别
  • Java 项目日志实例基础:Log4j
  • K8S应用笔记 —— 签发自签名证书用于Ingress的https配置
  • webpack 和 ts 简单配置及使用