关于 OpenCV 图像处理工具包 imutils 简单认知

news2025/1/18 17:08:12

写在前面


  • 博文内容涉及 基本的图像处理工具包 imutils 的简单介绍以及使用Demo
  • 理解不足小伙伴帮忙指正

对每个人而言,真正的职责只有一个:找到自我。然后在心中坚守其一生,全心全意,永不停息。所有其它的路都是不完整的,是人的逃避方式,是对大众理想的懦弱回归,是随波逐流,是对内心的恐惧 ——赫尔曼·黑塞《德米安》


imutils 是一个基于 OpenCV 的 Python 图像处理库。它包含了许多函数来简化常见的操作,如调整大小、旋转和显示图像等。一些关键特性包括:

  • 调整图像大小并保持纵横比
  • 以指定角度旋转图像
  • 在任何方向上平移(即移动)图像
  • 图像 骨架化,检测边缘
  • 点透视变换
  • 显示 Matplotlib 图像
  • 对轮廓进行排序

该项目的 demos 目录下 https://github.com/PyImageSearch/imutils/tree/master/demos,提供了一些常用的图片操作demo

常见方法以及参数解释

  • translate(image, x, y):将图像向右移动 x 个像素,向下移动 y 个像素。image 是输入图像,x 是要将图像向右移动的像素数,y 是要将图像向下移动的像素数。
  • rotate(image, angle, center=None, scale=1.0):围绕中心点旋转 angle 度的图像。image 是输入图像,angle 是旋转角度(以度为单位),center 是旋转中心(默认为图像中心),scale 是缩放因子(默认为 1.0)。
  • rotate_bound(image, angle):旋转图像 angle 度而不裁剪图像。image 是输入图像,angle 是旋转角度(以度为单位)。
  • resize(image, width=None, height=None, inter=cv2.INTER_AREA):将图像调整为指定的 width 和 height。image 是输入图像,width 是输出图像的期望宽度,height 是输出图像的期望高度,inter 是插值方法(默认为 cv2.INTER_AREA)。
  • skeletonize(image, size=(3, 3)):对图像应用形态学骨架化操作。image 是输入图像,size 是结构元素的大小(默认为 (3, 3))。
  • opencv2matplotlib(image):将 OpenCV 图像转换为 Matplotlib 兼容格式。image 是输入图像。
  • url_to_image(url):从 URL 下载图像并将其作为 NumPy 数组返回。url 是图像的 URL。
  • auto_canny(image, sigma=0.33):使用自动确定的阈值将 Canny 边缘检测算法应用于图像。image 是输入图像,sigma 是高斯滤波器的标准差(默认为 0.33)。
  • grab_contours(cnts):从 cv2.findContours 函数的输出中提取轮廓。cnts 是 cv2.findContours 函数的输出。
  • is_cv2():如果安装了 OpenCV 2,则返回 True,否则返回 False。
  • is_cv3():如果安装了 OpenCV 3,则返回 True,否则返回 False。
  • is_cv4():如果安装了 OpenCV 4,则返回 True,否则返回 False。
  • check_opencv_version(major, minor, patch=None):检查安装的 OpenCV 版本是否至少为指定版本。major、minor 和 patch 分别是主要、次要和补丁版本号。
  • build_montages(images, image_shape, montage_shape):构建图像的拼贴画。images 是输入图像的列表,image_shape 是每个输入图像的形状,montage_shape 是拼贴画的形状。
  • adjust_brightness_contrast(image, alpha=1.0, beta=0.0):调整图像的亮度和对比度。image 是输入图像,alpha 是对比度控制(默认为 1.0),beta 是亮度控制(默认为 0.0)。
  • find_function(name):按名称查找 imutils 包中的函数。name 是要查找的函数的名称。
  • paths.list_images: 获取指定目录下的所有图片路径
  • put_text和put_centered_text。这两个函数都是用来在图像上绘制文本的。put_text函数可以在指定的位置绘制一段文本,而put_centered_text函数可以在图像中央绘制一段文本。

个别 Demo

依赖环境

# pip install matplotlib==3.7.1
# pip install numpy==1.23.5
# pip install opencv-contrib-python==4.7.0.72
# pip install opencv-python==4.7.0.72
# pip install imutils==0.5.4


import imutils
import cv2

Demo

图片上添加文字

def  demo1():
    import cv2
    from imutils.text import put_text

    # Load image
    img = cv2.imread('W:\python_code\deepface\database\yz_W.jpg')

    # Define text parameters
    text = 'Hello, world!\nThis is a test.'
    org = (50, 50)
    font_face = cv2.FONT_HERSHEY_SIMPLEX
    font_scale = 1
    color = (255, 255, 255)
    thickness = 2
    line_type = 8
    bottom_left_origin = False

    # Draw text on image
    put_text(img, text, org, font_face, font_scale, color, thickness, line_type, bottom_left_origin)

    # Display image
    cv2.imshow('Image', img)
    cv2.waitKey(0)
    cv2.destroyAllWindows()

# demo1()

def  demo2():
    import cv2
    from imutils.text import put_centered_text

    # Load image
    img = cv2.imread('W:\python_code\deepface\database\yz_W.jpg')

    # Define text parameters
    text = 'Hello, world!\nThis is a test.'
    font_face = cv2.FONT_HERSHEY_SIMPLEX
    font_scale = 1
    color = (255, 255, 255)
    thickness = 2
    line_type = 8

    # Draw centered text on image
    put_centered_text(img, text, font_face, font_scale, color, thickness, line_type)

    # Display image
    cv2.imshow('Image', img)
    cv2.waitKey(0)
    cv2.destroyAllWindows()

demo2()
添加文字
在这里插入图片描述
在这里插入图片描述

平移

img = cv2.imread(img_path)
translated = imutils.translate(img, 100, 30)
cv2.imwrite(out_path + 'translate.jpg', translated)
原图平移后的图
在这里插入图片描述在这里插入图片描述

获取当前目录下的所有图片文件路径

def paths():
    from imutils import paths
    for imagePath in paths.list_images("W:\python_code\deepface\database"):
        print(imagePath)

等比例缩放

        resized = imutils.resize(img, width=width)
        cv2.imwrite(out_path + 'resize' + str(width) + '.jpg', resized)
100的等比例缩放400 的等比例缩放
在这里插入图片描述在这里插入图片描述

博文部分内容参考

© 文中涉及参考链接内容版权归原作者所有,如有侵权请告知,这是一个开源项目,如果你认可它,不要吝啬星星哦 😃


https://github.com/PyImageSearch/imutils/

https://pypi.org/project/imutils/


© 2018-2023 liruilonger@gmail.com, All rights reserved. 保持署名-非商用-相同方式共享(CC BY-NC-SA 4.0)

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

2023年真无线蓝牙耳机品牌有哪些推荐?无线蓝牙耳机选购指南

今天就来给大家测评一下2023年最受用户欢迎的蓝牙耳机,在不断地测试耳机,并挖掘好的耳机出来,不得不说,蓝牙和麦克风以及音频技术的驱动的迭代更新,性能确实惊叹不已。 对于刚接触无线耳机的小白来说,选购…

【服务器】支付宝SDK接口调试

​ 文章目录 1.测试环境2.本地配置3. 内网穿透3.1 下载安装cpolar内网穿透3.2 创建隧道 4. 测试公网访问5. 配置固定二级子域名5.1 保留一个二级子域名5.2 配置二级子域名 6. 使用固定二级子域名进行访问 转发自cpolar内网穿透的文章:Java支付宝沙箱环境支付&#…

低代码的“钱景”——专业的事交给专业的人来做

你需要知道的低代码 低代码通常是指一种可视化的开发方法,用较少的代码、较快的速度来交付应用程序,相似的概念还有“无代码”,也是一种开发方法,通常是面向非技术性员工,让业务人员也可以成为“技术人员”&#xff0…

首发Yolov8涨点神器:华为诺亚2023极简的神经网络模型 VanillaNet---VanillaBlock助力检测,实现暴力涨点

强烈推荐:博主多个数据集亲测有效,实现暴力涨点,可快速迁移到论文创新性十足,刚新鲜出炉的论文,华为诺亚共同提出!!! 1.VanillaNet 论文:https://arxiv.org/pdf/2305.12972.pdf 来自华为诺亚、悉尼大学的研究者们提出了一种极简的神经网络模型 VanillaNet,以极简主义…

表情包APP小程序制作开发功能有哪些?

表情包小程序在实际的开发过程中所具备的功能都是至关重要的,功能完善好操作才能更受用户青睐。表情包小程序制作开发功能包括但不仅限于以下几点: 1、热门表情包推荐。表情包制作小程序为用户推荐最热门的表情包,让用户可以紧跟当下流…

串口屏-迪文10寸T5串口屏简单上手

先看效果 调试所需软件 DGUS上位机 下载链接 调试所需硬件 SD卡一张 读卡器一个 USB转TTL一个 DGUS上位机调试 点击新建工程(会让你选尺寸) 分别生成0号字库和DWIN ICL文件 0号字库文件在你软件的安装目录可以找到 ICL文件输出到你能找到的位置 等会要用 添加背景图片 …

异常检测论文1

本文仅作为个人阅读文献&#xff0c;做笔记记录。 <> \usepackage[dvipsnames]{xcolor} 一、摘要部分&#xff1a; 我们发现&#xff0c;现有的数据集偏向于局部结构异常&#xff0c;如划痕、凹痕或污染。特别是&#xff0c;它们缺乏违反逻辑约束形式的异常&#xff0…

【redis】Stream、String 超详细介绍

文章目录 一、Stream1.1 写入数据XADD条目 ID 的格式 1.2 获取数据XRANGE 和 XREVRANGEXREAD 监听新条目非阻塞形式阻塞形式 1.3 消费者组XGROUP 创建消费者组XREADGROUP 通过消费者组消费XACK 确认消息消费者组示例 1.4 XPENDING 和 XCLAIM 认领 其他消费者 的待处理消息XPEND…

(2022,MaskedGAN)掩蔽的生成对抗网络是数据高效生成学习者

Masked Generative Adversarial Networks are Data-Efficient Generation Learners 公众号&#xff1a;EDPJ 目录 0. 摘要 1. 简介 2. 相关工作 3. 方法 3.1 任务定义 3.2 掩蔽的生成对抗网络 3.3 理论见解 4. 实验 4.1 在 CIFAR-10、CIFAR-100 和 ImageNet 上使用…

算法基础学习笔记——④前缀和\差分\双指针\位运算

✨博主&#xff1a;命运之光 ✨专栏&#xff1a;算法基础学习 目录 ✨前缀和 ✨一维前缀和 &#x1f353;一维前缀和模板&#xff1a; ✨二维前缀和 &#x1f353;二位前缀和模板&#xff1a; 前言&#xff1a;算法学习笔记记录日常分享&#xff0c;需要的看哈O(∩_∩)O&a…

Python二级编程:分词去重

一、原题 参考编程模板&#xff0c;完善代码&#xff0c;实现以下功能。‪‪‪‪‪‫‫‪‪‪‪‪‪‪‪‪‪‪‪‪‪‪‪‪‫‪‪‪‪‪‪‪‪‪‪‪‪‪‫ 利用 jieba 库实现中文分词。对分词后的列表进行去重处理&#xff0c;然后将分词结果中字符数大于等于 3 的词语&…

大话手游原始服务端搭建教程Centos

大话手游原始服务端搭建教程Centos 大家好&#xff0c;我是艾西&#xff0c;今天给大家分享一款回合制的ARPG大话手游搭建教程。游戏场景、精美的画面以及多元的人物做的非常棒。在游戏中可以穿越神话世界&#xff0c;同时也可以结交好友&#xff0c;加入团队&#xff0c;共同…

按键的单击、双击、连续按、短按和长按实现思路

概念区分 看到好多教程说了这些概念&#xff0c;有的说单击就是短按&#xff0c;连续按就是长按等等。 其实&#xff0c;仔细想想&#xff0c;这几个概念是有一些区别的。 假如一个按键&#xff0c;没按下时是高电平&#xff0c;按下时是低电平&#xff0c;以此来理解这些概念。…

JVM—Class类文件结构详解

Class类文件的结构 要了解Class文件的结构首先得了解Class文件所采用的数据类型&#xff1a; Class文件格式采用一种类似C语言结构体的伪结构来存储数据&#xff0c;这种伪结构只有两种数据结构&#xff0c;即无符号数和表&#xff0c;解析Class文件全是以这两个数据结构为基础…

【数据结构】什么是堆,如何使用无序数组生成一个堆?

文章目录 一、堆的概念及其介绍二、如何使用无序序列构建一个堆&#xff1f;三、C语言实现堆的基本操作结构体创建与销毁获取堆顶数据与个数及堆的判空堆的插入与删除 源代码分享 一、堆的概念及其介绍 堆(Heap)是计算机科学中一类特殊的数据结构的统称&#xff0c;堆通常是一…

LEETCODE 每日一题 1093.大样本统计

题目描述 前往leetcode1093题 我们对 0 到 255 之间的整数进行采样&#xff0c;并将结果存储在数组 count 中&#xff1a;count[k] 就是整数 k 在样本中出现的次数。 计算以下统计数据: minimum &#xff1a;样本中的最小元素。 maximum &#xff1a;样品中的最大元素。 mean &…

【Log】About these two years

文章目录 第一篇博客&#xff1f;成长收获的季节Future 第一篇博客&#xff1f; 第一次在CSDN发布博客&#xff0c;是当初我学习嵌入式的时候&#xff0c;那个时候我们做了一个大创&#xff0c;其中使用到了激光雷达&#xff0c;然后我就负责激光雷达部分代码的编写和设计&…

AI-新手玩转RKNN

关于RKNN RKNN 是Rockchip npu 平台使用的模型类型&#xff0c;以.rknn后缀结尾的模型文件。Rockchip 提供了完整了模型转换 Python 工具&#xff0c;方便用户将自主研发的算法模型转换成 RKNN 模型&#xff0c;同时 Rockchip 也提供了C/C和Python API 接口。 #mermaid-svg-M7l…

电子器件系列37:SD卡座(Push-Push和Push-Pull)

SD卡座是目前最通用的数据存储卡座、记忆卡座。在各种通讯数码产品、安防产品、带储存类产品等设备上都有所应用。有着性价比高、存储容量大、使用便捷、通用性以及安全性强等特点。自弹式SD卡座的卡槽底部会设有一个小直径、小线径的弹簧或一种切口式弹片。当装入SD卡时&#…

Kafka如何保证数据高可靠

这节课给大家分享一下Kafka的数据高可靠。为什么要讲这个&#xff1f;因为Kafka它本身不是一个金融级别数据可靠的分布式消息系统。 虽然说它存储到某个topic里的数据会先拆分多个partition&#xff0c;这体现了分治的一个思想。每一个partition在最终存储的时候会保存多个副本…