博客
关于我
项目【MFC】总结(三)——图像灰度化/彩色化
阅读量:798 次
发布时间:2023-04-15

本文共 1437 字,大约阅读时间需要 4 分钟。

灰度化与彩色化功能的实现

在本项目中,界面右侧的灰度化与彩色化功能主要涉及图像处理,相较于MFC应用程序开发,这一模块的实现更加侧重于OpenCV技术的运用。

灰度化功能的实现相对简单,主要是对读取的图像进行转换,将其从Vector数据结构转换为OpenCV的Mat格式。具体实现如下:

void VecToMat(const vector
>& Vec, Mat& img) { int rows = Vec.size(); int cols = Vec[0].size(); img = cv::Mat::zeros(Size(cols, rows), CV_16UC1); for (int i = 0; i < rows; ++i) { short* ptmp = img.ptr
(i); for (int j = 0; j < cols; ++j) { if (Vec[i][j] < 0) { ptmp[j] = 0; } else { ptmp[j] = Vec[i][j]; } } }}

灰度化完成后,可直接显示转换后的图像。对于彩色化功能,需要对灰度图像应用伪彩色映射。OpenCV中提供了applyColorMap函数来实现这一功能,常用的颜色映射编号包括2(热色调图)及6(冷色调图)。

彩色化的实现代码如下:

Mat get_img(const vector
>>& csvData_Slip, int res_X, int res_Y, int num, bool color) { int rows = csvData_Slip[0].size(); int cols = csvData_Slip[0][0].size(); Mat img = cv::Mat::zeros(Size(cols, rows), CV_16UC1); for (int i = num; i <= num; ++i) { VecToMat(csvData_Slip[i], img); img.convertTo(img, CV_8U, 1, 0); if (color) { cv::applyColorMap(img, img, 2); // 2、6 伪彩色图 } } return img;}

applyColorMap函数的参数解释:

  • img:目标图像。
  • result:应用颜色映射后的图像。
  • color:颜色映射编号。

需要注意的是,该实现代码中包含了许多未声明的全局变量,应根据实际项目需求进行补充和调整。

灰度化与彩色化功能的整体实现流程如下:

  • 调用VecToMat函数将Vector数据转换为OpenCV Mat格式。
  • 根据color标志选择是否应用颜色映射。
  • 调整图像大小以适应显示窗口,并进行比例缩放。
  • 整个灰度化与彩色化功能的核心代码结构如上所述,具体实现细节需根据实际应用需求进行补充和优化。

    转载地址:http://terfk.baihongyu.com/

    你可能感兴趣的文章
    mysql5.7的安装和Navicat的安装
    查看>>
    mysql5.7示例数据库_Linux MySQL5.7多实例数据库配置
    查看>>
    Mysql8 数据库安装及主从配置 | Spring Cloud 2
    查看>>
    mysql8 配置文件配置group 问题 sql语句group不能使用报错解决 mysql8.X版本的my.cnf配置文件 my.cnf文件 能够使用的my.cnf配置文件
    查看>>
    MySQL8.0.29启动报错Different lower_case_table_names settings for server (‘0‘) and data dictionary (‘1‘)
    查看>>
    MYSQL8.0以上忘记root密码
    查看>>
    Mysql8.0以上重置初始密码的方法
    查看>>
    mysql8.0新特性-自增变量的持久化
    查看>>
    Mysql8.0注意url变更写法
    查看>>
    Mysql8.0的特性
    查看>>
    MySQL8修改密码报错ERROR 1819 (HY000): Your password does not satisfy the current policy requirements
    查看>>
    MySQL8修改密码的方法
    查看>>
    Mysql8在Centos上安装后忘记root密码如何重新设置
    查看>>
    Mysql8在Windows上离线安装时忘记root密码
    查看>>
    MySQL8找不到my.ini配置文件以及报sql_mode=only_full_group_by解决方案
    查看>>
    mysql8的安装与卸载
    查看>>
    MySQL8,体验不一样的安装方式!
    查看>>
    MySQL: Host '127.0.0.1' is not allowed to connect to this MySQL server
    查看>>
    Mysql: 对换(替换)两条记录的同一个字段值
    查看>>
    mysql:Can‘t connect to local MySQL server through socket ‘/var/run/mysqld/mysqld.sock‘解决方法
    查看>>