首页 > 其他分享 >《机器学习》—— OpenCV 对图片的各种操作

《机器学习》—— OpenCV 对图片的各种操作

时间:2024-08-25 21:25:45浏览次数:8  
标签:机器 imshow cv2 jpg OpenCV 图像 imread 500 图片

文章目录

1、安装OpenCV库

  • 使用pip是最简单、最快捷的安装方式

    pip install opencv-python==3.4.2
    
  • 还需要安装一个包含了其他一些图像处理算法函数的opencv扩展库

    pip install opencv-contrib-python==3.4.2
    
  • 注意:安装的版本可以自行选择与自己python适配的进行安装,但是这两个库的版本必须是一致的

2、读取、显示、查看图片

  • 读取图像:使用cv2.imread(filename, flags)函数,其中filename是图像的路径,flags指定读取图像的方式(如灰度图像、彩色图像等)。
  • 显示图像:使用cv2.imshow(window_name, image)函数,其中window_name是窗口名称,image是要显示的图像。之后,通常使用cv2.waitKey(delay)等待用户按键,最后使用cv2.destroyAllWindows()关闭所有窗口。
    Man = cv2.imread('kobe.jpg')
    cv2.imshow('8-24', Man)
    # 可以给定规定显示的时间,单位为毫秒,0表示一直显示
    # 若是想结束显示,可以在英文状态下按下电脑键盘上的任意键
    # 若是用变量接收,再打印出这个变量,则会返回你所按下键的ASCII码值
    b = cv2.waitKey(0)
    print(b)   # 可以显示出所按键的ASCII码值
    # 关闭窗口
    cv2.destroyAllWindows()
    # 可以通过 shape dtype size 来查看图片的每个维度的大小、类型、总体大小
    print(Man.shape)
    print(Man.dtype)
    print(Man.size)
    
    在这里插入图片描述
    在这里插入图片描述

3、对图片进行切割

import cv2
M = cv2.imread('kobe.jpg')
# 给定所想切出的长宽大小范围,并用变量接收
A = M[0:800, 0:800]
B = M[500:800, 500:800]
cv2.imshow('qiepian_A', A)
cv2.imshow('qiepian_B', B)
cv2.waitKey(0)
cv2.destroyAllWindows()

在这里插入图片描述

4、改变图像的大小

import cv2
M = cv2.imread('kobe.jpg')
# 可以直接指定需要的图片大小,也可以指定大小,对长宽进行百分比的缩放
# M_new = cv2.resize(M, (400, 600)) 
M_new = cv2.resize(M, dsize=None, fx=0.6, fy=0.6)  # dsize 不指定规定大小
cv2.imshow('M', M)
cv2.imshow('M_new', M_new)
cv2.waitKey(0)
cv2.destroyAllWindows()

在这里插入图片描述

5、图片打码

import cv2
import numpy as np
M = cv2.imread('kobe.jpg')
# 给出需要打码的区域,运用numpy的方法随机选取[0~255]的像素,并给定打码的大小
# 注意这里打码的长宽大小必须与打码区域的长宽大小相同
M[100:200, 200:300] = np.random.randint(0, 256, (100, 100, 3))  # 矩阵赋值必须是相同大小
cv2.imshow('masaike', M)
cv2.waitKey(1000000)
cv2.destroyAllWindows()

在这里插入图片描述

6、图片组合

M = cv2.imread('kobe.jpg')
# MB.jpg 是 kobe.jpg 灰度图,为了可以让效果看的明显一点
M1 = cv2.imread('MB.jpg')
# 设置第一张需要替换的位置长宽大小必须和第二张图片相同
M[500:700, 500:700] = M1[300:500, 300:500]
cv2.imshow('M', M)
cv2.waitKey(100000)
cv2.destroyAllWindows()

在这里插入图片描述

7、图像运算

  • 图像+号运算

    # 对于+号运算,当对图像a,图像b进行加法求和时,遵循以下规则:
    # 当某位置像素相加得到的数值小于255时,该位置数值为两图像该位置像素相加之和
    # 当某位置像素相加得到的数值大于255时,该位置数值将截断结果并将其减去 256 例如:相加后是260,实际是260-256=4
    M = cv2.imread('kobe.jpg')
    I = cv2.imread('wechat.jpg')
    MM = M + 50 
    # 需要将相加起来的区域大小设置成相同的
    MI = M[500:700, 500:700] + I[500:700, 500:700]
    cv2.imshow('MM', MM)
    cv2.imshow('MI', MI)
    cv2.waitKey(0)
    cv2.destroyAllWindows()
    

    在这里插入图片描述

  • 图像 add 运算

    M = cv2.imread('kobe.jpg')
    I = cv2.imread('wechat.jpg')
    # 将两张图片的大小设置成相同的
    M = cv2.resize(M, (400, 400))
    I = cv2.resize(I, (400, 400))
    MI = cv2.add(M, I)
    cv2.imshow('MI', MI)
    cv2.waitKeyEx(100000)
    cv2.destroyAllWindows()
    

    在这里插入图片描述

8、图像加权运算

M = cv2.imread('wechat.jpg')
I = cv2.imread('wechat2.jpg')
M = cv2.resize(M, (600, 500))
I = cv2.resize(I, (600, 500))
# 需要给定每个图像的权重大小(简单来说:谁设定的数值越大其显示的程度越高),10为图像的亮度值
MI = cv2.addWeighted(M, 0.5, I, 0.5, 10)
cv2.imshow('MI', MI)
cv2.waitKey(100000)
cv2.destroyAllWindows()

在这里插入图片描述

标签:机器,imshow,cv2,jpg,OpenCV,图像,imread,500,图片
From: https://blog.csdn.net/weixin_73504499/article/details/141529155

相关文章

  • 机器学习:随机森林决策树学习算法及代码实现
    1、概念        随机森林(RandomForest)是一种集成学习方法,它通过构建多个决策树来进行分类或回归预测。随机森林的核心原理是“集思广益”,即通过组合多个弱学习器(决策树)的预测结果来提高整体模型的准确性和健壮性。2、集成学习(EnsembleLearning):        集......
  • 机器学习之——决策树构建原理
    0前言本文主要讲述了决策树背后的数学原理以及构建方法,并通过实例数据一步步构建决策树,帮助读者理解。本文使用了大量的配图帮助读者理解。1理论基础1.1决策树的原型决策树思想的来源非常朴素,程序设计中的条件分支结构就是if-then结构,最早的决策树就是利用这类结构分割......
  • 机器学习-梯度下降
    介绍试想一下,你在一个山坡上寻找一个最快的下坡方法。首先360360360度旋转一周你会找到一个当前最陡峭的方向,沿着这个方向走一步。重复上面的操作,继续旋转......
  • scrapy--图片管道-ImagesPipeline
    免责声明:本文仅做演示与分享~ 目录介绍 ImagesPipelinepipelines.pyitems.pyzz.pysettings.py介绍scrapy还提供了处理图片、视频、音频等媒体文件的插件,如:-scrapy-images:用于下载和处理图片-scrapy-video:用于下载和处理视频-scrapy-podcast:用于下载和处......
  • 机器学习简介
    机器学习简介Learnfromdata、深度学习经典定义:利用经验改善系统自身的性能[T.Mitchell教科书,1997]。数据->算法->模型基本术语数据:数据集;训练;测试示例(instance);样例(example)样本(sample)属性(attribute);特征(feature);属性值属性空间;样本空间;输入空间特......
  • [行业调研] 2024世界机器人大会
    展会见闻记录看到的零碎信息从身体结构的维度机械臂:吸取小物体,放到另一个区域。这种任务在各种环境下都能精准完成,相对于人类有优势。灵巧手:看到各种自由度的手,手掌/手指正面覆盖了很多触觉传感器,有些甚至还布置了摄像头。AGV:仓库托运重物,物流机器人。仿生机器人:......
  • win10系统图片打开方式为照片查看器的方法
    众多win10用户都知道,当查看图片文件的时候,系统便会默认运行Metro风格的照片运用来打开图片。但是有许多用户更喜欢传统照片查看器来看图片,但是却不知道该怎么设置。小编今天这里就来为大家分享下设置win10系统图片打开方式为照片查看器的方法。工具/原料联想小......
  • 061、Vue3+TypeScript基础,插槽中增加图片和控制视频
    01、main.js代码如下://引入createApp用于创建Vue实例import{createApp}from'vue'//引入App.vue根组件importAppfrom'./App.vue'//引入emitter用于全局事件总线//importemitterfrom'@/utils/emitter'constapp=createApp(App);//App.vue的根元素id为......
  • opencv-python图像增强十五:高级滤镜实现
    文章目录前言二、鲜食滤镜三、巧克力滤镜三,冷艳滤镜:前言在之前两个滤镜文章中介绍了六种简单的滤镜实现,它们大多都是由一个单独函数实现的接下来介绍五种结合了之前图像增强文章提的的算法的复合滤镜。本案例中的算法来自于文章一,文章二,文章三,感兴趣的小伙伴可以看......
  • 最全!万字长文总结opencv-python常用函数(一)
    文章目录一,简介:二,图像的基础操作:2.1,图像的读取显示与保存2.1.1图像的读取cv2.imread:2.1.2图像的显示cv2.imshow与等待cv2.waitKey:2.1.3图像保存cv2.imwrite:2.2,图像属性获取:2.3,图像裁剪cv2.selectROI:2.4,图像通道的拆分cv2.split:2.5,图像通道的合并cv2.merge:三,图像的数值......