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

opencv-常用代码

以下是一些OpenCV中常用的代码片段,涵盖了一些基本的图像处理和计算机视觉任务。

  1. 加载和显示图像:

    import cv2# 读取图像
    img = cv2.imread('image.jpg')# 显示图像
    cv2.imshow('Image', img)
    cv2.waitKey(0)
    cv2.destroyAllWindows()
    
  2. 调整图像大小:

    resized_img = cv2.resize(img, (width, height))
    
  3. 灰度转换:

    gray_img = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
    
  4. 图像平滑:

    smoothed_img = cv2.GaussianBlur(img, (kernel_size, kernel_size), 0)
    
  5. 边缘检测:

    edges = cv2.Canny(gray_img, threshold1, threshold2)
    
  6. 图像阈值处理:

    ret, binary_img = cv2.threshold(gray_img, threshold_value, max_value, cv2.THRESH_BINARY)
    
  7. 图像轮廓检测:

    contours, hierarchy = cv2.findContours(edges, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)
    
  8. 绘制轮廓:

    cv2.drawContours(img, contours, -1, (0, 255, 0), 2)
    
  9. 人脸检测:

    face_cascade = cv2.CascadeClassifier('haarcascade_frontalface_default.xml')
    faces = face_cascade.detectMultiScale(gray_img, scaleFactor=1.3, minNeighbors=5)
    
  10. 图像旋转:

    rows, cols = img.shape[:2]
    M = cv2.getRotationMatrix2D((cols / 2, rows / 2), angle, scale)
    rotated_img = cv2.warpAffine(img, M, (cols, rows))
    
  11. 图像腐蚀与膨胀:

    kernel = np.ones((kernel_size, kernel_size), np.uint8)
    eroded_img = cv2.erode(img, kernel, iterations=1)
    dilated_img = cv2.dilate(img, kernel, iterations=1)
    
  12. 图像直方图均衡化:

    equ_img = cv2.equalizeHist(gray_img)
    
  13. 图像混合:

    blended_img = cv2.addWeighted(img1, alpha, img2, beta, gamma)
    
  14. 图像拼接:

    stitched_img = cv2.hconcat([img1, img2])
    
  15. 图像截取:

    roi = img[y:y+h, x:x+w]
    
  16. 图像相加:

    added_img = cv2.add(img1, img2)
    
  17. 图像减法:

    subtracted_img = cv2.subtract(img1, img2)
    
  18. 图像位运算:

    bitwise_and = cv2.bitwise_and(img1, img2)
    bitwise_or = cv2.bitwise_or(img1, img2)
    bitwise_xor = cv2.bitwise_xor(img1, img2)
    bitwise_not = cv2.bitwise_not(img)
    
  19. 图像平均模糊:

    averaged_img = cv2.blur(img, (kernel_size, kernel_size))
    
  20. 中值滤波:

    median_blurred_img = cv2.medianBlur(img, ksize)
    
  21. 自适应阈值:

    adaptive_thresh = cv2.adaptiveThreshold(gray_img, 255, cv2.ADAPTIVE_THRESH_GAUSSIAN_C, cv2.THRESH_BINARY, 11, 2)
    
  22. 图像旋转缩放:

    M = cv2.getRotationMatrix2D((cols / 2, rows / 2), angle, scale)
    rotated_resized_img = cv2.warpAffine(img, M, (new_cols, new_rows))
    
  23. SIFT 特征提取和匹配:

    sift = cv2.SIFT_create()
    keypoints1, descriptors1 = sift.detectAndCompute(img1, None)
    keypoints2, descriptors2 = sift.detectAndCompute(img2, None)
    
  24. SURF 特征提取和匹配:

    surf = cv2.SURF_create()
    keypoints1, descriptors1 = surf.detectAndCompute(img1, None)
    keypoints2, descriptors2 = surf.detectAndCompute(img2, None)
    
  25. ORB 特征提取和匹配:

    orb = cv2.ORB_create()
    keypoints1, descriptors1 = orb.detectAndCompute(img1, None)
    keypoints2, descriptors2 = orb.detectAndCompute(img2, None)
    
  26. 使用 FLANN 匹配器进行特征匹配:

    FLANN_INDEX_KDTREE = 1
    index_params = dict(algorithm=FLANN_INDEX_KDTREE, trees=5)
    search_params = dict(checks=50)
    flann = cv2.FlannBasedMatcher(index_params, search_params)
    matches = flann.knnMatch(descriptors1, descriptors2, k=2)
    
  27. 简单图像深度学习任务:

    net = cv2.dnn.readNet('model.weights', 'model.cfg')
    blob = cv2.dnn.blobFromImage(img, scalefactor=1.0, size=(300, 300), mean=(104.0, 177.0, 123.0))
    net.setInput(blob)
    detections = net.forward()
    
  28. HOG 特征提取与行人检测:

    hog = cv2.HOGDescriptor()
    hog.setSVMDetector(cv2.HOGDescriptor_getDefaultPeopleDetector())
    boxes, weights = hog.detectMultiScale(img, winStride=(8, 8), padding=(0, 0), scale=1.05)
    

这些是一些基本的OpenCV代码示例,覆盖了图像处理和计算机视觉中的常见任务。在实际应用中,可能需要根据具体场景和需求进一步调整参数和算法。

相关文章:

  • ELK企业级日志分析平台
  • Springboot3+vue3从0到1开发实战项目(一)
  • 指针笔试题分享
  • 机器篇——决策树(六) 细说 评估指标的交叉验证
  • 阿里云服务器(vgn7i-vws) anaconda(py39)+pytorch1.12.0(cu113)
  • YOLOv3老矣尚能战否?基于YOLOv3开发构建建钢铁产业产品智能自动化检测识别系统,我们来与YOLOv5进行全方位对比评测
  • SpringCloud Alibaba集成 Gateway(自定义负载均衡器)、Nacos(配置中心、注册中心)、loadbalancer
  • 鸿鹄工程项目管理系统 Spring Cloud+Spring Boot+Mybatis+Vue+ElementUI+前后端分离构建工程项目管理系统项目背景
  • MobaXterm连接节点一段时间后超时Session stopped
  • Towhee介绍
  • 【转载】如何在Macbook上把Ubuntu安装到移动硬盘里
  • CSM32RV003:国产高精度16位ADC低功耗RISC-V内核MCU
  • 配电室智慧运维监控系统
  • 数据治理技术之数据清洗
  • ElementUI table+dialog实现一个简单的可编辑的表格
  • (三)从jvm层面了解线程的启动和停止
  • [译]Python中的类属性与实例属性的区别
  • 【108天】Java——《Head First Java》笔记(第1-4章)
  • 【跃迁之路】【519天】程序员高效学习方法论探索系列(实验阶段276-2018.07.09)...
  • AzureCon上微软宣布了哪些容器相关的重磅消息
  • canvas实际项目操作,包含:线条,圆形,扇形,图片绘制,图片圆角遮罩,矩形,弧形文字...
  • IOS评论框不贴底(ios12新bug)
  • JS创建对象模式及其对象原型链探究(一):Object模式
  • Mithril.js 入门介绍
  • Vue 动态创建 component
  • 检测对象或数组
  • 开发基于以太坊智能合约的DApp
  • 让你的分享飞起来——极光推出社会化分享组件
  • 如何解决微信端直接跳WAP端
  • 用Canvas画一棵二叉树
  • 栈实现走出迷宫(C++)
  • 字符串匹配基础上
  • 自定义函数
  • 白色的风信子
  • #我与Java虚拟机的故事#连载05:Java虚拟机的修炼之道
  • (1)Android开发优化---------UI优化
  • (ibm)Java 语言的 XPath API
  • (ZT)一个美国文科博士的YardLife
  • (初研) Sentence-embedding fine-tune notebook
  • (翻译)Entity Framework技巧系列之七 - Tip 26 – 28
  • (分类)KNN算法- 参数调优
  • (附源码)springboot 个人网页的网站 毕业设计031623
  • * 论文笔记 【Wide Deep Learning for Recommender Systems】
  • .NET/C# 编译期间能确定的相同字符串,在运行期间是相同的实例
  • .Net环境下的缓存技术介绍
  • /etc/fstab和/etc/mtab的区别
  • ??eclipse的安装配置问题!??
  • [Angularjs]asp.net mvc+angularjs+web api单页应用
  • [BZOJ1008][HNOI2008]越狱
  • [c]统计数字
  • [CF703D]Mishka and Interesting sum/[BZOJ5476]位运算
  • [emuch.net]MatrixComputations(7-12)
  • [Firefly-Linux] RK3568 pca9555芯片驱动详解
  • [flask]http请求//获取请求体数据
  • [HJ56 完全数计算]