文章目录
- 本专栏代码地址
https://github.com/xiawei20161308104/xv_opencv_tutorials- 本节代码路径
xv_opencv_tutorials/ImageProcessinginOpenCV/load_img.py
namedWindowimreadimshowimwritedestroyWindow destroyAllWindowsopencv提供cv.namedWindow函数实现创建一个窗口功能
import cv2 as cv
# 参数一winname:string类型的窗口名称,参数二flags:窗口类型,使用规定好的类型,默认WINDOW_AUTOSIZE
cv.namedWindow('img', cv.WINDOW_AUTOSIZE)
cv.waitKey(0)

flags窗口类型的可选参数
一般使用cv.WINDOW_NORMAL就可以啦
| 函数名称 | 应用 |
|---|---|
| cv.WINDOW_NORMAL | 可以用鼠标调整窗口大小,将全屏窗口切换正常大小 |
| cv.WINDOW_AUTOSIZE | 不能改变大小,图像显示为其原始大小,但也受到屏幕分辨率的影响 |
| cv.WINDOW_FULLSCREEN | 全屏显示 |
| cv.WINDOW_FREERATIO | 调整图片大小的时候,不考虑原始比率 |
| cv.WINDOW_KEEPRATIO | 调整图片大小的时候,保持原始比率不变 |
| cv.WINDOW_OPENGL | 支持opengl |
注意
winname重复,则函数不执行,例如:
WINDOW_AUTOSIZE可能会出现适配不好的情况。左图img只显示了上半截,显示不完全,右图为原图。
opencv提供cv.imread函数实现读取图像功能。可以读取的类型有:

import cv2 as cv
cv.namedWindow('img WINDOW_NORMAL', cv.WINDOW_NORMAL)
# 读取图像
# 参数一filename:string类型的图片路径,参数二flags:读取方式,比如读取哪个通道,哪些保留哪些丢弃等。使用规定好的类型。
img = cv.imread("../imgs/opencv.png")
cv.imshow('img WINDOW_NORMAL', img)
cv.waitKey(0)
flags读取方式的可选参数
补充:
jpg: 格式是有损压缩 ,24 bit真彩色,不支持动画、不支持透明色。在压缩过程中图像的品质会遭受破坏。一张图片多次上传下载后,图片逐渐会失真。
PNG:格式是无损数据压缩,PNG格式有8位、24位、32位三种形式,其中8位PNG支持两种不同的透明形式(索引透明和alpha透明),24位PNG不支持透明,32位PNG在24位基础上增加了8位透明通道(32-24=8)可展现256级透明程度。
imread函数默认不读取透明度,所以若有一些的特殊格式的图像需要进行flag标记。
| 函数名称 | 应用 |
|---|---|
| cv.IMREAD_UNCHANGED | 读取原始图像不改变,可以读取到png的透明通道 |
| cv.IMREAD_GRAYSCALE | 用编码器内部转换为灰度图 |
| cv.IMREAD_COLOR | 默认配置,转为3通道BGR图像 |
| cv.IMREAD_REDUCED_GRAYSCALE_2/ | 转为灰度图,尺寸减小1/2 |
| cv.IMREAD_REDUCED_GRAYSCALE_4/ | 转为灰度图,尺寸减小1/4 |
| cv.IMREAD_REDUCED_GRAYSCALE_8 | 转为灰度图,尺寸减小1/8 |
| cv.IMREAD_REDUCED_COLOR_2 | 转为BGR彩图,尺寸减少1/2(还可以减小1/4,1/8) |
demo
import cv2 as cv
cv.namedWindow('img IMREAD_GRAYSCALE', cv.WINDOW_NORMAL)
cv.namedWindow('img1 original', cv.WINDOW_NORMAL)
cv.namedWindow('img2 original had alpha', cv.WINDOW_NORMAL)
# 读取图像
# 参数一filename:string类型的图片路径,参数二flags:读取方式,比如读取哪个通道,哪些保留哪些丢弃等。使用规定好的类型。
# 以灰度图形式读取
img = cv.imread("../imgs/opencv.png", cv.IMREAD_GRAYSCALE)
print("灰度图大小为:", img.shape)
# 以默认形式读取原图,没有透明度通道
img1 = cv.imread("../imgs/opencv.png")
print("默认方式读取大小为:", img1.shape)
# 以IMREAD_UNCHANGED形式读取原图,有透明度通道
img2 = cv.imread("../imgs/opencv.png", cv.IMREAD_UNCHANGED)
print("不忽略透明度通道大小为:", img2.shape)
# 展示图像
cv.imshow('img IMREAD_GRAYSCALE', img)
cv.imshow('img1 original', img1)
cv.imshow('img2 original had alpha', img2)
# 窗口停留,0代表无限时停留
cv.waitKey(0)
控制台输出:
灰度图大小为: (610, 570)
默认方式读取大小为: (610, 570, 3)
不忽略透明度通道大小为: (610, 570, 4) 看!有一个透明通道吧

注意:
文件丢失、权限不正确、格式不受支持或无效等情况,会返回空矩阵- 按照
BGR通道读取- 读取类型为
IMREAD_GRAYSCALE时候,和cvtColor()转灰度图的结果可能不同- 根据图片本身内容决定类型,而不是根据文件的扩展名
- 标志位为
IMREAD_UNCHANGED是原始的不会改变的读取方式- 默认情况下,像素数必须小于
2^30。可以使用系统变量OPENCV_IO_MAX_IMAGE_PIXELS设置限制
opencv提供imshow()函数,来在指定窗口加载图像
cv.namedWindow('img IMREAD_GRAYSCALE', cv.WINDOW_NORMAL)
# 参数一winname:string类型的窗口名称,参数二mat:图像。配合cv.namedWindow使用。
# 展示效果受到图像本身和namedWindow的类型影响。WINDOW_NORMAL能显示大于屏幕分辨率的图像。
cv.imshow('img IMREAD_GRAYSCALE', img)
注意
当图像大小不是255的时候,一般采取除法或者乘法转为0-255显示
- 如果图像像素大小为8bit,也就是2的8次方=256像素的,直接显示。
- 如果图像是16bit的,也就是2的16次方=256*256=25536像素的,会映射为0-255大小显示。
- 如果是浮点数0-1的,会映射为0-255大小显示
保存图像有两种方法
按下Ctrl+S将显示本地对话框自行选择保存图像。按下Ctrl+C会复制图像到剪切板

结合waitKey用代码控制
# waitKey(0)将无限显示窗口,直到按下任何键为止,适用于想显示图像的时候。
# waitKey(25)将显示一帧并等待大约25ms的按键,适用于逐帧显示视频的时候。
k=cv.waitKey(0)
# 在无限显示窗口的时候,按下s,则保存到本地路径
#imwrite参数一filename:保存的路径,参数二img要保存的图像,参数三params可选,对特定格式进行编码
if k == ord("s"):
cv.imwrite("opencv1.png", img)
注意
保存的时候可以决定图像的保存形式。
只有8bit的单通道或者BGR三通道能用这个函数直接保存,其他的需要特定格式或者特殊处理,例如16bit需要特定保存为PNG, JPEG 2000, 和TIFF 形式。
程序最后加cv.destroyAllWindows()就好啦,释放一下资源。其实在简单程序中,加不加都行,关闭程序就自动释放了。
以上所有知识点的整合,通常图片读取步骤,按需取用。
文件结构:

完整代码:
import cv2 as cv
import sys
# 创建窗口
# 参数一winname:string类型的窗口名称,参数二flags:窗口类型,使用规定好的类型,默认WINDOW_AUTOSIZE
cv.namedWindow('img IMREAD_GRAYSCALE', cv.WINDOW_NORMAL)
cv.namedWindow('img1 original', cv.WINDOW_NORMAL)
cv.namedWindow('img2 original had alpha', cv.WINDOW_NORMAL)
# 读取图像
# 参数一filename:string类型的图片路径,参数二flags:读取方式,比如读取哪个通道,哪些保留哪些丢弃等。使用规定好的类型。
# 以灰度图形式读取
img = cv.imread("../imgs/opencv.png", cv.IMREAD_GRAYSCALE)
# 因为imread读取不到的时候不会报错,所有这里需要判空
if img is None:
sys.exit("Could not read the image.")
print("灰度图大小为:", img.shape)
# 以默认形式读取原图,没有透明度通道
img1 = cv.imread("../imgs/opencv.png")
print("默认方式读取大小为:", img1.shape)
# 以IMREAD_UNCHANGED形式读取原图,有透明度通道
img2 = cv.imread("../imgs/opencv.png", cv.IMREAD_UNCHANGED)
print("不忽略透明度通道大小为:", img2.shape)
# 展示图像
# 参数一winname:string类型的窗口名称,参数二mat:图像。配合cv.namedWindow使用。
cv.imshow('img IMREAD_GRAYSCALE', img)
cv.imshow('img1 original', img1)
cv.imshow('img2 original had alpha', img2)
# waitKey(0)将无限显示窗口,直到按下任何键为止,适用于想显示图像的时候。
# waitKey(25)将显示一帧并等待大约25ms的按键,适用于逐帧显示视频的时候。
k = cv.waitKey(0)
if k == ord("s"):
cv.imwrite("../imgs/opencv1.png", img)
cv.destroyAllWindows()
出于纯粹的兴趣,我很好奇如何按顺序创建PI,而不是在过程结果之后生成数字,而是让数字在过程本身生成时显示。如果是这种情况,那么数字可以自行产生,我可以对以前看到的数字实现垃圾收集,从而创建一个无限系列。结果只是在Pi系列之后每秒生成一个数字。这是我通过互联网筛选的结果:这是流行的计算机友好算法,类机器算法:defarccot(x,unity)xpow=unity/xn=1sign=1sum=0loopdoterm=xpow/nbreakifterm==0sum+=sign*(xpow/n)xpow/=x*xn+=2sign=-signendsumenddefcalc_pi(digits
关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭4年前。Improvethisquestion我想在固定时间创建一系列低音和高音调的哔哔声。例如:在150毫秒时发出高音调的蜂鸣声在151毫秒时发出低音调的蜂鸣声200毫秒时发出低音调的蜂鸣声250毫秒的高音调蜂鸣声有没有办法在Ruby或Python中做到这一点?我真的不在乎输出编码是什么(.wav、.mp3、.ogg等等),但我确实想创建一个输出文件。
我得到了一个包含嵌套链接的表单。编辑时链接字段为空的问题。这是我的表格:Editingkategori{:action=>'update',:id=>@konkurrancer.id})do|f|%>'Trackingurl',:style=>'width:500;'%>'Editkonkurrence'%>|我的konkurrencer模型:has_one:link我的链接模型:classLink我的konkurrancer编辑操作:defedit@konkurrancer=Konkurrancer.find(params[:id])@konkurrancer.link_attrib
我主要使用Ruby来执行此操作,但到目前为止我的攻击计划如下:使用gemsrdf、rdf-rdfa和rdf-microdata或mida来解析给定任何URI的数据。我认为最好映射到像schema.org这样的统一模式,例如使用这个yaml文件,它试图描述数据词汇表和opengraph到schema.org之间的转换:#SchemaXtoschema.orgconversion#data-vocabularyDV:name:namestreet-address:streetAddressregion:addressRegionlocality:addressLocalityphoto:i
Rackup通过Rack的默认处理程序成功运行任何Rack应用程序。例如:classRackAppdefcall(environment)['200',{'Content-Type'=>'text/html'},["Helloworld"]]endendrunRackApp.new但是当最后一行更改为使用Rack的内置CGI处理程序时,rackup给出“NoMethodErrorat/undefinedmethod`call'fornil:NilClass”:Rack::Handler::CGI.runRackApp.newRack的其他内置处理程序也提出了同样的反对意见。例如Rack
使用带有Rails插件的vim,您可以创建一个迁移文件,然后一次性打开该文件吗?textmate也可以这样吗? 最佳答案 你可以使用rails.vim然后做类似的事情::Rgeneratemigratonadd_foo_to_bar插件将打开迁移生成的文件,这正是您想要的。我不能代表textmate。 关于ruby-使用VimRails,您可以创建一个新的迁移文件并一次性打开它吗?,我们在StackOverflow上找到一个类似的问题: https://sta
我对最新版本的Rails有疑问。我创建了一个新应用程序(railsnewMyProject),但我没有脚本/生成,只有脚本/rails,当我输入ruby./script/railsgeneratepluginmy_plugin"Couldnotfindgeneratorplugin.".你知道如何生成插件模板吗?没有这个命令可以创建插件吗?PS:我正在使用Rails3.2.1和ruby1.8.7[universal-darwin11.0] 最佳答案 随着Rails3.2.0的发布,插件生成器已经被移除。查看变更日志here.现在
鉴于我有以下迁移:Sequel.migrationdoupdoalter_table:usersdoadd_column:is_admin,:default=>falseend#SequelrunsaDESCRIBEtablestatement,whenthemodelisloaded.#Atthispoint,itdoesnotknowthatusershaveais_adminflag.#Soitfails.@user=User.find(:email=>"admin@fancy-startup.example")@user.is_admin=true@user.save!ende
如何使用RSpec::Core::RakeTask初始化RSpecRake任务?require'rspec/core/rake_task'RSpec::Core::RakeTask.newdo|t|#whatdoIputinhere?endInitialize函数记录在http://rubydoc.info/github/rspec/rspec-core/RSpec/Core/RakeTask#initialize-instance_method没有很好的记录;它只是说:-(RakeTask)initialize(*args,&task_block)AnewinstanceofRake
所以我在关注Railscast,我注意到在html.erb文件中,ruby代码有一个微弱的背景高亮效果,以区别于其他代码HTML文档。我知道Ryan使用TextMate。我正在使用SublimeText3。我怎样才能达到同样的效果?谢谢! 最佳答案 为SublimeText安装ERB包。假设您安装了SublimeText包管理器*,只需点击cmd+shift+P即可获得命令菜单,然后键入installpackage并选择PackageControl:InstallPackage获取包管理器菜单。在该菜单中,键入ERB并在看到包时选择