【Python】计算机视觉应用:OpenCV库图像处理入门

计算机视觉应用:OpenCV库图像处理入门

在当今的数字化时代,计算机视觉(Computer Vision)已经渗透到各行各业,比如自动驾驶、智能监控、医疗影像分析等。而 Python 的 OpenCV 库(Open Source Computer Vision Library)因其强大且开源的特性,被广泛应用于图像处理和计算机视觉应用中。本文将详细介绍 OpenCV 的基本功能和常见的图像处理操作,并通过一个完整的实战项目展示 OpenCV 在图像处理中的应用。
在这里插入图片描述

一、OpenCV简介

OpenCV 是一个开源计算机视觉库,最初由英特尔开发,现在被广泛用于各类图像和视频处理任务。OpenCV 提供了多种图像处理算法,涵盖了从图像基础操作到复杂机器学习应用的各个方面。它支持多种编程语言,如 C++、Python 和 Java,并且能够在多个平台(Windows、Linux、macOS)上运行。

安装OpenCV

可以通过以下命令安装 OpenCV:

pip install opencv-python

安装完成后,导入库进行初始化:

import cv2

在这里插入图片描述

二、图像的基本概念

在开始学习 OpenCV 的功能之前,我们需要了解一些基本的图像概念。

  1. 像素:图像由多个小方块组成,这些方块称为像素。每个像素都有自己的颜色和亮度值。
  2. 颜色模式:图像的颜色模式通常有三种:
    • 灰度图像:每个像素只有一个灰度值(0-255),代表黑白色调。
    • RGB图像:由红、绿、蓝三个通道组成,每个通道的像素值表示颜色的浓度。
    • 二值图像:每个像素只有两个值,0(黑色)和255(白色)。
      在这里插入图片描述

三、OpenCV基础功能

1. 读取和显示图像

cv2.imread() 用于读取图像,cv2.imshow() 用于显示图像,cv2.imwrite() 用于保存图像。

import cv2

# 读取图像
image = cv2.imread("image.jpg")

# 显示图像
cv2.imshow("Image", image)
cv2.waitKey(0)  # 等待用户按键关闭窗口
cv2.destroyAllWindows()  # 关闭窗口

2. 图像的缩放与调整大小

cv2.resize() 函数可以用来调整图像大小。

resized_image = cv2.resize(image, (300, 300))  # 将图像调整为300x300大小
cv2.imshow("Resized Image", resized_image)
cv2.waitKey(0)
cv2.destroyAllWindows()

3. 图像的旋转

cv2.getRotationMatrix2D()cv2.warpAffine() 函数可以实现图像旋转。

(h, w) = image.shape[:2]
center = (w // 2, h // 2)
matrix = cv2.getRotationMatrix2D(center, 45, 1.0)  # 旋转45度
rotated = cv2.warpAffine(image, matrix, (w, h))
cv2.imshow("Rotated Image", rotated)
cv2.waitKey(0)
cv2.destroyAllWindows()

4. 图像的裁剪

裁剪是指截取图像的某一部分。可以通过切片操作直接实现。

cropped = image[50:200, 50:200]  # 截取从(50, 50)到(200, 200)的区域
cv2.imshow("Cropped Image", cropped)
cv2.waitKey(0)
cv2.destroyAllWindows()

5. 图像的颜色转换

OpenCV 支持多种颜色空间的转换。常用的转换包括 BGR 到灰度、BGR 到 HSV 等。

# 转换为灰度图像
gray_image = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)
cv2.imshow("Gray Image", gray_image)
cv2.waitKey(0)
cv2.destroyAllWindows()

6. 边缘检测

边缘检测是图像处理中常见的一项操作。cv2.Canny() 提供了高效的边缘检测方法。

edges = cv2.Canny(gray_image, 100, 200)  # 阈值范围为100到200
cv2.imshow("Edges", edges)
cv2.waitKey(0)
cv2.destroyAllWindows()

7. 图像的模糊处理

模糊处理通常用于降噪或实现特效。OpenCV 提供了多种模糊方法,如均值模糊、Gaussian模糊和中值模糊。

blurred = cv2.GaussianBlur(image, (15, 15), 0)
cv2.imshow("Blurred Image", blurred)
cv2.waitKey(0)
cv2.destroyAllWindows()

在这里插入图片描述

四、图像处理综合应用案例

案例:图像美化与滤镜效果

我们将创建一个简单的图像美化程序,该程序包括亮度调整、对比度增强、锐化处理、边缘增强等步骤,并展示如何利用 OpenCV 实现一款滤镜效果。

第一步:图像的亮度与对比度调整

亮度和对比度是控制图像视觉效果的关键参数。

def adjust_brightness_contrast(image, brightness=30, contrast=50):
    brightness = brightness / 100.0
    contrast = contrast / 100.0
    return cv2.convertScaleAbs(image, alpha=1 + contrast, beta=brightness * 255)

brightened_image = adjust_brightness_contrast(image, brightness=30, contrast=50)
cv2.imshow("Brightened Image", brightened_image)
cv2.waitKey(0)
cv2.destroyAllWindows()
第二步:图像的锐化处理

锐化用于提高图像的清晰度。可以通过卷积操作实现。

kernel = np.array([[0, -1, 0], [-1, 5, -1], [0, -1, 0]])
sharpened_image = cv2.filter2D(image, -1, kernel)
cv2.imshow("Sharpened Image", sharpened_image)
cv2.waitKey(0)
cv2.destroyAllWindows()
第三步:添加边缘增强效果

边缘增强可以通过 Sobel 滤波器或 Laplacian 滤波器实现。

laplacian = cv2.Laplacian(image, cv2.CV_64F)
edge_enhanced_image = cv2.convertScaleAbs(laplacian)
cv2.imshow("Edge Enhanced Image", edge_enhanced_image)
cv2.waitKey(0)
cv2.destroyAllWindows()
第四步:综合滤镜效果

接下来我们将多个效果结合起来,创建一个滤镜效果函数。

def apply_filter(image):
    # 1. 调整亮度和对比度
    bright_contrast = adjust_brightness_contrast(image, brightness=20, contrast=40)
    
    # 2. 模糊处理
    blurred = cv2.GaussianBlur(bright_contrast, (5, 5), 0)
    
    # 3. 锐化处理
    kernel = np.array([[0, -1, 0], [-1, 5, -1], [0, -1, 0]])
    sharpened = cv2.filter2D(blurred, -1, kernel)
    
    # 4. 边缘增强
    laplacian = cv2.Laplacian(sharpened, cv2.CV_64F)
    edge_enhanced = cv2.convertScaleAbs(laplacian)
    
    return edge_enhanced

filtered_image = apply_filter(image)
cv2.imshow("Filtered Image", filtered_image)
cv2.waitKey(0)
cv2.destroyAllWindows()

通过这种方式,我们可以快速为图像添加自定义的滤镜效果。
在这里插入图片描述

五、实战项目:摄像头实时滤镜应用

现在让我们将所学知识应用于一个完整的实战项目:创建一个实时滤镜应用,使用电脑的摄像头捕捉画面并实时显示滤镜效果。

实战步骤

  1. 打开摄像头:使用 cv2.VideoCapture(0) 打开默认摄像头。
  2. 实时捕捉图像:通过循环不断读取摄像头的画面。
  3. 应用滤镜效果:对每一帧应用滤镜效果。
  4. 显示实时滤镜效果:显示实时滤镜后的画面。

实战代码

import cv2
import numpy as np

def apply_filter(image):
    # 调整亮度和对比度
    bright_contrast = adjust_brightness_contrast(image, brightness=20, contrast=40

)
    # 模糊
    blurred = cv2.GaussianBlur(bright_contrast, (5, 5), 0)
    # 锐化
    kernel = np.array([[0, -1, 0], [-1, 5, -1], [0, -1, 0]])
    sharpened = cv2.filter2D(blurred, -1, kernel)
    # 边缘增强
    laplacian = cv2.Laplacian(sharpened, cv2.CV_64F)
    edge_enhanced = cv2.convertScaleAbs(laplacian)
    return edge_enhanced

def adjust_brightness_contrast(image, brightness=30, contrast=50):
    brightness = brightness / 100.0
    contrast = contrast / 100.0
    return cv2.convertScaleAbs(image, alpha=1 + contrast, beta=brightness * 255)

cap = cv2.VideoCapture(0)  # 打开摄像头

while True:
    ret, frame = cap.read()  # 捕捉视频中的一帧
    if not ret:
        break
    
    # 应用滤镜效果
    filtered_frame = apply_filter(frame)
    
    # 显示原始和滤镜效果画面
    cv2.imshow("Original", frame)
    cv2.imshow("Filtered", filtered_frame)
    
    if cv2.waitKey(1) & 0xFF == ord('q'):
        break

cap.release()
cv2.destroyAllWindows()

项目总结

该实战项目展示了如何结合 OpenCV 和实时视频处理技术,为摄像头捕捉的画面应用滤镜效果。你可以根据需要进一步自定义滤镜效果,例如添加彩色滤镜、卡通化效果等。
在这里插入图片描述

总结

OpenCV 是一个强大的图像处理库,支持各种图像和视频的操作。从基础的图像读取、显示,到高级的边缘检测、模糊处理和滤镜应用,OpenCV 提供了全面的支持。在本文中,我们学习了 OpenCV 的基本功能,并通过一个实时滤镜应用的实战项目,演示了 OpenCV 在图像处理和计算机视觉中的应用。希望这篇文章能为你打开计算机视觉的大门,激发你在图像处理领域进一步探索的兴趣!
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/909584.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【Ai测评】GPT Search偷偷上线,向Google和微软发起挑战!

最近,OpenAI 又推出了一个令人兴奋的新功能——GPT Search,已经正式上线了! 功能介绍 GPT Search:为你带来全新搜索体验 目前,桌面端和移动端应用程序已经全面上线,所有 GPT Plus 和 Team 用户都可以立即…

iOS用rime且导入自制输入方案

iPhone 16 的 cantonese 只能打传统汉字,没有繁简转换,m d sh d。考虑用「仓」输入法 [1] 使用 Rime 打字,且希望导入自制方案 [2]。 仓输入法有几种导入方案的方法,见 [3],此处记录 wifi 上传法。准备工作&#xff1…

【数据结构】算法的时间复杂度和空间复杂度

写在前面 在我们学习数据结构之前,我们肯定就听过某某大神说,我的排序算法的时间复杂度只需要O(logN),空间复杂度只需要O(1)…听的好唬人,但是实际也真牛。那其中时间复杂度和空间复杂度是什么呢?不才这篇笔记就深入讲…

基于MATLAB的农业病虫害识别研究

matlab有处理语音信号的函数wavread,不过已经过时了,现在处理语音信号的函数名称是audioread选取4.wav进行处理(只有4的通道数为1) 利用hamming窗设计滤波器 Ham.m function [N,h,H,w] Ham(fp,fs,fc)wp 2*pi*fp/fc;ws 2*pi*…

MongoDB基础介绍以及从0~1语法介绍

目录 MongoDB 教程导读 NoSQL 简介 关系型数据库遵循ACID规则 分布式系统 分布式计算的优点 分布式计算的缺点 什么是NoSQL? 为什么使用NoSQL ? RDBMS vs NoSQL NoSQL 简史 CAP定理(CAP theorem) NoSQL的优点/缺点 BASE ACID vs BASE N…

Oracle简介、环境搭建和基础DML语句

第一章 ORACLE 简介 1.1 什么是 ORACLE ORACLE数据库系统是美国ORACLE 公司(甲骨文)提供的以分布式数据库为核心的一组软件产品,是目前最流行的客户/服务器体系结构的数据库之一。 英文官网:Database | Oracle 中文官网&#xff…

前端好用的网站分享——CSS(持续更新中)

1.CSS Scan 点击进入CSS Scan CSS盒子阴影大全 2.渐变背景 点击进入color.oulu 3.CSS简化压缩 点击进入toptal 4.CSS可视化 点击进入CSS可视化 这个强推,话不多说,看图! 5.Marko 点击进入Marko 有很多按钮样式 6.getwaves 点击进入getwaves 生…

黑马官网2024最新前端就业课V8.5笔记---HTML篇

Html 定义 HTML 超文本标记语言——HyperText Markup Language。 标签语法 标签成对出现&#xff0c;中间包裹内容<>里面放英文字母&#xff08;标签名&#xff09;结束标签比开始标签多 /拓展 &#xff1a; 双标签&#xff1a;成对出现的标签 单标签&#xff1a;只有开…

6:arm condition code flags详细的讲解

目录 6.1 arm的 condition code flag 的详细讲解 6.1.1C 6.1.2Z 6.1.3N 6.1.4V 6.1 arm的 condition code flag 的详细讲解 在这篇文章中&#xff0c;我更加严格与严谨的讲解一下 arm的四个condition code flags&#xff0c;因为这个在汇编中还是非常重要的。 6.1.1C 在…

其他节点使用kubectl访问集群,kubeconfig配置文件 详解

上述两种方式&#xff1a;可使用kubectl连接k8s集群。 $HOME/.kube/config 是config文件默认路径&#xff0c;要么直接定义环境变量&#xff0c;要么就直接把文件拷过去 config文件里面&#xff0c;定义了context&#xff0c;里面指定了用户和对应的集群信息&#xff1a; ku…

新世联科技:NG2-A-7在DAC空气捕集提取CO2的应用

一、DAC空气捕集提取CO2的介绍 直接空气碳捕获&#xff08;Direct Air Capture&#xff0c;简称DAC&#xff09;是一种直接从大气中提取二氧化碳的技术。 二、DAC空气捕集提取CO2的前景 从大气中提取的这种二氧化碳可以作为循环经济的一部分以各种不同方式使用。未来&#xf…

十四届蓝桥杯STEMA考试Python真题试卷第二套第五题

来源:十四届蓝桥杯STEMA考试Python真题试卷第二套编程第五题 本题属于迷宫类问题,适合用DFS算法解决,解析中给出了Python中 map() 和列表推导式的应用技巧。最后介绍了DFS算法的两种常见实现方式——递归实现、栈实现,应用场景——迷宫类问题、图的连通性、树的遍历、拓朴排…

js WebAPI黑马笔记(万字速通)

此笔记来自于黑马程序员&#xff0c;pink老师yyds 复习&#xff1a; splice() 方法用于添加或删除数组中的元素。 注意&#xff1a; 这种方法会改变原始数组。 删除数组&#xff1a; splice(起始位置&#xff0c; 删除的个数) 比如&#xff1a;1 let arr [red, green, b…

【C++】踏上C++学习之旅(五):auto、范围for以及nullptr的精彩时刻(C++11)

文章目录 前言1. auto关键字&#xff08;C11&#xff09;1.1 为什么要有auto关键字1.2 auto关键字的使用方式1.3 auto的使用细则1.4 auto不能推导的场景 2. 基于范围的for循环&#xff08;C11&#xff09;2.1 范围for的语法2.2 范围for的使用条件 3. 指针空值nullptr&#xff0…

【Spring】Spring的简单创建和使用

前言 Spring Bean 可以通过两种主要方式定义&#xff1a;基于 XML 配置文件和基于注解。今天我们讲解基于 XML 配置文件‌来定义 Bean &#xff0c;在 XML 配置文件中&#xff0c;使用 <bean> 元素定义 Bean&#xff0c;描述 Bean 的创建、配置和依赖关系&#xff0c;并存…

二次封装 el-pagination 组件存在的问题

在使用 Element Plus 组件时&#xff0c;有时会遇到组件不完全符合需求的情况&#xff0c;这时可能需要对其进行二次封装。在封装 Pagination 组件时&#xff0c;我们会发现一些属性和函数无法正常使用&#xff0c;下面将详细探讨这些问题&#xff0c;并提供一下思路和想法。 …

想唱就唱 2.15.63| 电视免VIP唱K软件,支持手机点歌

想唱就唱是一款实用性强的K歌软件&#xff0c;支持歌曲搜索、歌手搜索及排行榜。软件支持歌曲下载、点歌、插队&#xff0c;还支持手机扫码点歌&#xff0c;功能与KTV软件一致&#xff0c;让用户在家也能享受KTV体验。首次加载较慢&#xff0c;因采用先下载后播放方式。会员版已…

图文深入介绍Oracle DB link(一)

1. 引言&#xff1a; 本文图文深入介绍Oracle DB link&#xff0c;先介绍基本概念。 2.DB link的定义 数据库链接&#xff08;Database Link&#xff0c;简称 DB Link&#xff09;是 Oracle 数据库中的一个重要功能。它是一种在一个 Oracle 数据库实例中访问另一个 Oracle 数…

江协科技STM32学习- P34 I2C通信外设

&#x1f680;write in front&#x1f680; &#x1f50e;大家好&#xff0c;我是黄桃罐头&#xff0c;希望你看完之后&#xff0c;能对你有所帮助&#xff0c;不足请指正&#xff01;共同学习交流 &#x1f381;欢迎各位→点赞&#x1f44d; 收藏⭐️ 留言&#x1f4dd;​…

vxe-table 表格中实现多行文本的编辑

Vxe UI vue vxe-table 表格中实现多行文本的编辑 vxe-table v4.8 要在表格中使用多行文本编辑&#xff0c;可以通过设置行高方式&#xff0c;再设置 cell-config.verticalAlign: ‘top’ 单元格垂直对齐方式&#xff0c;实现顶部对齐&#xff0c;因为默认是居中对齐。 代码 …