zoukankan      html  css  js  c++  java
  • openCV for python 学习(一):环境搭建与图片显示

    我的上创课题和HCI的期末作业都要用到图像处理方面的东西,是时候玩玩儿openCV了。

    但是Visual Studio又周期性地出问题了,而且我也不怎么想写C++。恰好openCV官方已经开始支持python了,那就二话不说,dive into openCV for python。

    在配置openCV之前,首先要确认你已正确安装了NumPy,这个是必须要安装的。

    另外一个很有用的包是matplotlib,是一个很方便的绘图工具包。假如你之前用过matlab绘图的话,那么这个包用起来应该很顺手了。

    我之前下载过Anaconda,一个用python进行科学计算的平台,里面集成了诸如NumPy, SciPy, PIL, matplotlib等常用的图像处理包。如果你自己配不好这些包,可以先下载Anaconda或之类的科学平台,然后在它的安装目录下找到python2XLibsite-packages,把需要的包粘贴到你自己的python路径下就可以了。

    在python下配置openCV还是比较简单的。从openCV的官网下载安装包。解压完成后,在buildpython2.7x86下找到cv2.pyd文件(64位系统在x64文件夹下),复制到%PYTHON27%Libsite-packages下就可以了。打开IDLE,输入:

    import cv2
    print cv2.__version__

    如果显示出openCV的版本号,那么环境就搭建好了。简直不能比VS简单更多。

    注意:openCV目前只支持python2.x版本。

    装好之后,我们先小试一把。如下脚本文件:

    import cv2
    import numpy as np
    from matplotlib import pyplot as plt
    if __name__ == '__main__':
        
        #show image with imshow
        img = cv2.imread('3dsmax.jpg',1)
        cv2.namedWindow('image', cv2.WINDOW_NORMAL)
        cv2.imshow('image',img)
        cv2.waitKey(0)
        cv2.destroyAllWindows()

    导入包什么的我就不介绍了,下文如果没有特别表明的话,默认包含了上述的三个导入语句。

    至于if __name__ == '__main__':  , 加上这个条件后,双击脚本文件就可以直接运行了,相当于一个main函数。

    接着我们来逐个解释用到的函数:

    (1)cv2.imread() :这个函数用于读入图片,应输入两个参数:图片路径,显示模式。返回一个nparray(NumPy中的数组,与python自带的list有很多不同,此处暂且不提)。显示模式有三种,分别是: 色彩模式——1, 灰度模式——0,带透明度参数模式—— -1. 输入模式对应的数字,或者直接使用常量:

    cv2.IMREAD_COLOR , cv2.IMREAD_GRAYSCALE , cv.IMREAD_UNCHANGED。

    (2)cv2.namedWindow() :这个没什么好介绍的,就是初始化一个窗口。

    (3)cv2.imshow() : 这个函数用于在窗口中显示图片,有两个参数 :窗口名称与图片变量。此处的变量来自函数(1)的返回值,是一个nparray。

    (4)cv2.waitKey(0) :这个函数是一个绑定键盘动作的函数,它的参数是一个数字,表示在相应的毫秒之后监听键盘动作。我觉得它就是加入了一个阻塞,满足条件之后解除阻塞,执行之后的语句。

    (5)cv2.destroyAllWindows() : 这个函数就是关闭窗口,和(4)连起来就是按下任意键关闭显示图片的窗口。

    所以,这段代码就是读入图片,显示图片,按任意键关闭窗口。一段十分简单的Hello world to openCV~~美丽的优胜美地公园!

    接着我们再试一下matplotlib中的图片显示:

    img = cv2.imread('yosemeti.jpg',0)
    plt.imshow(img,cmap='gray', interpolation='bicubic')
    plt.show()

    (1)plt.imshow(): 这个函数用于将图片放入显示窗口中,但并不会弹出窗口。有三个参数:图像的nparray,显示类型cmap以及插值算法。前两个参数前面介绍过了。第三个参数是用于选择插值算法,填补图像由于拉伸放大造成的不平滑的像素块,保持一定的图片质量。此处选择的是双三次插值算法,是一种精度很高但速度偏慢的算法。

    (2)plt.show():弹出包含了图片的窗口,像这个样子:

    此处有一个细节问题,那就是cv2.imread()读入彩色图像时,返回的nparray是按照B,G,R的顺序排列的,而matplotlib中的plt.imshow()显示彩色图像时,是按照RGB的顺序显示的,因此就会造成红蓝色的错乱,写段代码看下效果:

        img = cv2.imread('yosemeti.jpg',1)
        b,g,r = cv2.split(img)
        img2 = cv2.merge([r,g,b])
        plt.subplot(121)
        plt.imshow(img)
        plt.subplot(122)
        plt.imshow(img2)
        plt.show()

    效果如下:

    左边是红蓝对调的图片,右边是正常的原图。嗯,黄昏与清晨的区别。。。

    最后推荐一个很好的网站 http://opencv-python-tutroals.readthedocs.org/en/latest/index.html#

    我基本就是跟着他走,讲的挺详细的,还有一些小练习。顺便也锻炼了英文文献阅读能力了~

  • 相关阅读:
    H公司以及我的目标
    新的起点
    apache服务器配置Net的实践
    会计简要学习
    二、MongoDB的简单增删改查
    一、MongoDB安装与启动
    KnockOutJs初次体验
    DevExpress 全体窗口换肤的功能 winform
    DevExporess 右键菜单的实现
    使用gridControl gridview总结
  • 原文地址:https://www.cnblogs.com/gaminoliu/p/4493710.html
Copyright © 2011-2022 走看看