程序如下

#include "opencv2/opencv.hpp"
using namespace cv; int main()
{
Mat file1 = imread("girl.jpg",CV_LOAD_IMAGE_UNCHANGED);
Mat file2 = imread("girl.jpg", CV_LOAD_IMAGE_GRAYSCALE); namedWindow("Color", CV_WINDOW_FREERATIO);
namedWindow("Fixed", CV_WINDOW_AUTOSIZE); imshow("Color", file1);
imshow("Fixed", file2); resizeWindow("Color", file1.cols / 2, file1.rows / 2);
resizeWindow("Fixed", file2.cols / 2, file2.rows / 2); moveWindow("Color", 600, 400);
moveWindow("Fixed", 600 + file1.cols + 5, 400); waitKey(0);
}

运行结果如下:

图片中的这把尺是测量图片像素的,不是图片本身。

1. imread函数,读取图片

函数原型:

Mat imread(const String& filename, int flag = CV_LOAD_IMAGE_COLOR)

参数说明:

  1. filename: 待打开图片的文件名,支持常见的图片格式
  2. flag: 这里只简单说明例子中用到的二个参数
    • CV_LOAD_IMAGE_UNCHANGED: 不进行转化,以原有图片的格式读取
    • CV_LOAD_IMAGE_GRAYSCALE: 转化为灰度图,类型为CV_8UC1

通过调试器,我们可以看到本例中,file1 = {UINT8, 3 x 389 x 292},

file2 = {UINT8, 1 x 389 x 292}。这里选择file1作为说明,其中:

file1.cols = 389, 表示图片水平方向

file1.rows = 292, 表示图片的垂直方向

file1.channels = 3, 表示图片的通道数

2. namedWindow函数, 生成一个窗口

函数原型如下:

void namedWindow(const String& winname, int flags = WINDOW_AUTOSIZE)

参数说明:

  1. winname: 窗口标识符,也就是窗口的名字,见图片中的 Color, Fixed 等
  2. flags: 窗口的类型
    • CV_WINDOW_FREERATIO, 窗口自适应图片大小,可以窗口用鼠标调整大小
    • CV_WINDOW_AUTOSIZE, 窗口自适应图片大小,但窗口不能通过鼠标调整大小

3. imshow函数,显示图片

函数原型:

void imshow(const String& winname, InputArray mat)

参数说明:

  1. winname: 显示窗口的名字
  2. mat: 待显示的图像

4. resizedWindow函数,调整窗口的大小

函数原型:

void resizeWindow(const String& winname, int width, int height)

参数说明:

  1. winname: 指定调整窗口的名字
  2. width: 新窗口的宽度
  3. height: 新窗口的高度

注意:对于namedWindow函数,选用 CV_WINDOW_AUTOSIZE 参数,如果width和height小于原图片,那么调整后的图片是不能全部显示图片。Fixed 和 Color 图中区别很明显。

4. moveWindow函数,移动窗口

函数原型:

void moveWindow(const String& winname, int x, int y)

函数说明:

  1. winname: 移动窗口的名字
  2. x: 窗口左边到屏幕左边的距离,单位为像素
  3. y: 窗口上边到屏幕上边的距离,单位为像素

本例中,Fixed 相对于 Color 右移了 file1.cols + 5 个像素,file1.cols = 389, 从图片中的标尺可以看到,正好 394 个像素。注意都是以窗口的左侧边框为基准。

opencv3 学习三 - 图像输入输出显示等的更多相关文章

  1. opencv3 学习四 - 图像减色

    程序如下 #include "opencv2/opencv.hpp" using namespace cv; int main() { // 灰度图 Mat original = ...

  2. 从视频文件中读入数据-->将数据转换为灰度图-->对图像做canny边缘检测-->将这三个结构显示在一个图像中

    //从视频文件中读入数据-->将数据转换为灰度图-->对图像做canny边缘检测-->将这三个结构显示在一个图像中 //作者:sandy //时间:2015-10-10 #inclu ...

  3. Struts2框架学习(三) 数据处理

    Struts2框架学习(三) 数据处理 Struts2框架框架使用OGNL语言和值栈技术实现数据的流转处理. 值栈就相当于一个容器,用来存放数据,而OGNL是一种快速查询数据的语言. 值栈:Value ...

  4. Python学习 Part5:输入输出

    Python学习 Part5:输入输出 1. 格式化输出 三种输出值的方法: 表达式语句 print()函数 使用文件对象的write()方法 两种方式格式化输出: 由自己处理整个字符串,通过使用字符 ...

  5. DjangoRestFramework学习三之认证组件、权限组件、频率组件、url注册器、响应器、分页组件

    DjangoRestFramework学习三之认证组件.权限组件.频率组件.url注册器.响应器.分页组件   本节目录 一 认证组件 二 权限组件 三 频率组件 四 URL注册器 五 响应器 六 分 ...

  6. [ZZ] 深度学习三巨头之一来清华演讲了,你只需要知道这7点

    深度学习三巨头之一来清华演讲了,你只需要知道这7点 http://wemedia.ifeng.com/10939074/wemedia.shtml Yann LeCun还提到了一项FAIR开发的,用于 ...

  7. day91 DjangoRestFramework学习三之认证组件、权限组件、频率组件、url注册器、响应器、分页组件

    DjangoRestFramework学习三之认证组件.权限组件.频率组件.url注册器.响应器.分页组件   本节目录 一 认证组件 二 权限组件 三 频率组件 四 URL注册器 五 响应器 六 分 ...

  8. 深度学习与计算机视觉(12)_tensorflow实现基于深度学习的图像补全

    深度学习与计算机视觉(12)_tensorflow实现基于深度学习的图像补全 原文地址:Image Completion with Deep Learning in TensorFlow by Bra ...

  9. SCARA——OpenGL入门学习三

    OpenGL入门学习[三] 在第二课中,我们学习了如何绘制几何图形,但大家如果多写几个程序,就会发现其实还是有些郁闷之处.例如:点太小,难以看清楚:直线也太细,不舒服:或者想画虚线,但不知道方法只能用 ...

随机推荐

  1. web.xml配置错误页面,及输出错误信息

    1.需要在web.xml中配置相关信息 <!-- 默认的错误处理页面 --> <error-page> <error-code>403</error-code ...

  2. eclipse tomcat jdk 版本引用

    今日遇到一个问题,因为比较难找,所以记录下来,方便日后查阅,也许也可以帮助同行. 一个Java project工程,使用了solr6.2,所以需要引用jdk8才可以正常使用. 代码编写好了,已经提交s ...

  3. js 获取 网页屏幕高度 窗口高度 元素高度 滚动高度

    常用: JS 获取浏览器窗口大小 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 // 获取窗口宽度 if (window.innerWidth) winWidth = ...

  4. cocos2d-x 3.1 编译脚本android-build.py

    写在前面: 前段时间下载了cocos2d-x 3.1,按照官网的教程,配置环境,编译打包,走了一遍,感觉不错,顺便发现其中用了很多python的脚本文件,比如今天要说的android-build.py ...

  5. sql语句浅谈以及mysql遇到的问题解决见解

    mysql数据库基本操作: .显示数据库和查看mysql版本 show databases; select version(); select user();查看用户 .选择数据库 use 数据库名; ...

  6. Android Studio 独立引入(非友盟)微博分享和回调时问题

    最近同事在做一个小项目时,由于产品的要求,Wap页面的分享规定不能使用友盟的社会化组件.他则不得不手动一个一个渠道的引入分享,好在渠道不多就三个,但是第一微博分享引入的时候问题就出现了. 问题一:li ...

  7. Codeforces Round #435 (Div. 2)【A、B、C、D】

    //在我对着D题发呆的时候,柴神秒掉了D题并说:这个D感觉比C题简单呀!,,我:[哭.jpg](逃 Codeforces Round #435 (Div. 2) codeforces 862 A. M ...

  8. Pollard_rho 因数分解

    Int64以内Rabin-Miller强伪素数测试和Pollard 因数分解的算法实现 选取随机数\(a\) 随机数\(b\),检查\(gcd(a - b, n)\)是否大于1,若大于1则\(a - ...

  9. CF#538(div2) B. Yet Another Array Partitioning Task 【YY】

    任意门:http://codeforces.com/contest/1114/problem/B B. Yet Another Array Partitioning Task time limit p ...

  10. Codeforces Round #528 (Div. 2, based on Technocup 2019 Elimination Round 4) C. Connect Three 【模拟】

    传送门:http://codeforces.com/contest/1087/problem/C C. Connect Three time limit per test 1 second memor ...