Python OpenCV中的resize()函数的使用


Posted in Python onJune 20, 2019

改变图像大小意味着改变尺寸,无论是单独的高或宽,还是两者。也可以按比例调整图像大小。

这里将介绍resize()函数的语法及实例。

语法

函数原型

cv2.resize(src, dsize[, dst[, fx[, fy[, interpolation]]]])

参数:

参数 描述
src 【必需】原图像
dsize 【必需】输出图像所需大小
fx 【可选】沿水平轴的比例因子
fy 【可选】沿垂直轴的比例因子
interpolation 【可选】插值方式

【可选】插值方式

其中插值方式有很多种:

cv.INTER_NEAREST 最近邻插值
cv.INTER_LINEAR 双线性插值
cv.INTER_CUBIC 双线性插值
cv.INTER_AREA 使用像素区域关系重新采样。它可能是图像抽取的首选方法,因为它可以提供无莫尔条纹的结果。但是当图像被缩放时,它类似于INTER_NEAREST方法。

通常的,缩小使用cv.INTER_AREA,放缩使用cv.INTER_CUBIC(较慢)和cv.INTER_LINEAR(较快效果也不错)。默认情况下,所有的放缩都使用cv.INTER_LINEAR。

例子

保留高宽比

以下是我们将在其上进行实验的尺寸(149,200,4)(高度,宽度,通道数)的原始图像:

Python OpenCV中的resize()函数的使用

import cv2
 
img = cv2.imread('./Pictures/python.png', cv2.IMREAD_UNCHANGED)
 
print('Original Dimensions : ',img.shape)
 
scale_percent = 60  # percent of original size
width = int(img.shape[1] * scale_percent / 100)
height = int(img.shape[0] * scale_percent / 100)
dim = (width, height)
# resize image
resized = cv2.resize(img, dim, interpolation = cv2.INTER_AREA)
 
print('Resized Dimensions : ',resized.shape)
 
cv2.imshow("Resized image", resized)
cv2.waitKey(0)
cv2.destroyAllWindows()

结果:

Original Dimensions : (149, 200, 4)
Resized Dimensions : (89, 120, 4)

Python OpenCV中的resize()函数的使用

调节scale_percent可以放大或缩小。需要准备shape先高再宽,参数是先宽再高。

还有一种方式,就是使用自带的参数fx和fy,更加方便。

import cv2
img = cv2.imread("./Pictures/python.png")
print('Original Dimensions : ', img.shape)

resized = cv2.resize(img, None, fx=0.6, fy=0.6, interpolation=cv2.INTER_AREA)

print('Resized Dimensions : ',resized.shape)

cv2.imshow("resized_img", resized)
cv2.waitKey(0)

不保留高宽比

例如,改变宽度,高度不变:

import cv2

img = cv2.imread("./Pictures/python.png")

print('Original Dimensions : ',img.shape)
 
width = 440
height = img.shape[0] # keep original height
dim = (width, height)
 
# resize image
resized = cv2.resize(img, dim, interpolation = cv2.INTER_AREA)
 
print('Resized Dimensions : ',resized.shape)
 
cv2.imshow("Resized image", resized)
cv2.waitKey(0)
cv2.destroyAllWindows()

结果:

Original Dimensions : (149, 200, 4)
Resized Dimensions : (149, 440, 4)

Python OpenCV中的resize()函数的使用

指定高和宽

给定高和宽的像数值。

import cv2

img = cv2.imread("./Pictures/python.png")

print('Original Dimensions : ',img.shape)
 
width = 350
height = 450
dim = (width, height)
 
# resize image
resized = cv2.resize(img, dim, interpolation = cv2.INTER_AREA)
 
print('Resized Dimensions : ',resized.shape)
 
cv2.imshow("Resized image", resized)
cv2.waitKey(0)
cv2.destroyAllWindows()

结果:

Original Dimensions : (149, 200, 4)
Resized Dimensions : (450, 350, 4)

Python OpenCV中的resize()函数的使用

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python用来获得图片exif信息的库实例分析
Mar 16 Python
python文件操作之目录遍历实例分析
May 20 Python
python类装饰器用法实例
Jun 04 Python
Python守护进程和脚本单例运行详解
Jan 06 Python
Python3中类、模块、错误与异常、文件的简易教程
Nov 20 Python
Python使用base64模块进行二进制数据编码详解
Jan 11 Python
selenium+python自动化测试之多窗口切换
Jan 23 Python
Django框架模型简单介绍与使用分析
Jul 18 Python
Django-xadmin后台导入json数据及后台显示信息图标和主题更改方式
Mar 11 Python
Pyspark获取并处理RDD数据代码实例
Mar 27 Python
Python爬虫模拟登陆哔哩哔哩(bilibili)并突破点选验证码功能
Dec 21 Python
python中的时区问题
Jan 14 Python
python中的句柄操作的方法示例
Jun 20 #Python
使用python获取(宜宾市地震信息)地震信息
Jun 20 #Python
一篇文章了解Python中常见的序列化操作
Jun 20 #Python
python集合是否可变总结
Jun 20 #Python
Django如何自定义model创建数据库索引的顺序
Jun 20 #Python
pyqt 多窗口之间的相互调用方法
Jun 19 #Python
pyqt5 实现多窗口跳转的方法
Jun 19 #Python
You might like
解析php中mysql_connect与mysql_pconncet的区别详解
2013/05/15 PHP
WordPress导航菜单的滚动和淡入淡出效果的实现要点
2015/12/14 PHP
ThinkPHP框架搭建及常见问题(XAMPP安装失败、Apache/MySQL启动失败)
2016/04/15 PHP
PHP7新特性之抽象语法树(AST)带来的变化详解
2018/07/17 PHP
JS解密入门 最终变量劫持
2008/06/25 Javascript
javascript十个最常用的自定义函数(中文版)
2009/09/07 Javascript
JavaScript 常用函数库详解
2009/10/21 Javascript
JavaScript 笔记二 Array和Date对象方法
2010/05/22 Javascript
DLL+ ActiveX控件+WEB页面调用例子
2010/08/07 Javascript
关于div自适应高度/左右高度自适应一致的js代码
2013/03/22 Javascript
图片img的src不变让浏览器重新加载实现方法
2013/03/29 Javascript
JavaScript开发人员的10个关键习惯小结
2014/12/05 Javascript
浏览器中url存储的JavaScript实现
2015/07/07 Javascript
jquery实现仿新浪微博带动画效果弹出层代码(可关闭、可拖动)
2015/10/12 Javascript
微信小程序开发一键登录 获取session_key和openid实例
2016/11/23 Javascript
基于JavaScript实现滑动门效果
2017/03/16 Javascript
jquery实现下拉菜单的手风琴效果
2017/07/23 jQuery
jquery实现企业定位式导航效果
2018/01/01 jQuery
vue项目中公用footer组件底部位置的适配问题
2018/05/10 Javascript
使用vue-router完成简单导航功能【推荐】
2018/06/28 Javascript
详解vantUI框架在vue项目中的应用踩坑
2018/12/06 Javascript
vue子传父关于.sync与$emit的实现
2019/11/05 Javascript
JS实现简单移动端鼠标拖拽
2020/07/23 Javascript
element el-table表格的二次封装实现(附表格高度自适应)
2021/01/19 Javascript
Python的shutil模块中文件的复制操作函数详解
2016/07/05 Python
Anaconda2 5.2.0安装使用图文教程
2018/09/19 Python
Python从数据库读取大量数据批量写入文件的方法
2018/12/10 Python
某公司.Net方向面试题
2014/04/24 面试题
中级会计职业生涯规划书
2014/03/01 职场文书
机械设计制造及其自动化专业求职信
2014/06/17 职场文书
教师节活动总结
2014/08/29 职场文书
爱岗敬业事迹材料
2014/12/24 职场文书
关于国庆节的广播稿
2015/08/19 职场文书
2019下半年英语教师的教学工作计划(3篇)
2019/09/25 职场文书
JavaScript中isPrototypeOf函数
2021/11/07 Javascript
hive数据仓库新增字段方法
2022/06/25 数据库