数字图像处理(2):图像反相(分别用C语言、OpenCV、Matlab实现)

1. 图像格式

1.1 灰度图像

灰度数字图像是每个像素只有一个采样颜色的图像。这类图像通常显示为从最暗黑色到最亮的白色的灰度。灰度图像与黑白图像不同,在计算机图像领域中黑白图像只有黑白两种颜色,灰度图像在黑色与白色之间还有许多级的颜色深度。

1.2 RGB888图像

RGB色彩模式是工业界的一种颜色标准,是通过对红®、绿(G)、蓝(B)三个颜色通道的变化以及它们相互之间的叠加来得到各式各样的颜色的,RGB即是代表红、绿、蓝三个通道的颜色,这个标准几乎包括了人类视力所能感知的所有颜色,是目前运用最广的颜色系统之一。

256级的RGB色彩总共能组合出约1678万种色彩,即256×256×256=16777216。通常也被简称为1600万色或千万色。也称为24位色(2的24次方)。


2. 图像反相

“反相”即为图像的颜色色相反转。以前照相机的底片就是打印后的照片的反相。比如黑变白,蓝变黄、红变绿。

对灰度级范围为[0 , L-1]的一幅图像进行反转的操作为:s = L - 1 - r

其中r和s分别代表处理前后的像素值。使用这种方式反转一幅图像的灰度级,可得到等效的照片底片。

这种类型的处理特别适用于增强嵌入在一幅图像的暗区域中的白色和灰色细节,特别是当黑色面积在尺寸上占主导地位时。


3. 代码&运行

3.1 平台:VS2015 + C语言

界面截图:

在这里插入图片描述

流程:

开始 -> 读取RAW格式图片 -> 保存至二维数组 -> 数组每个元素进行“255-”操作 -> 将二维数组生成RAW格式文件 -> 用PS查看图片操作结果

结果:

在工程目录下生成了output.raw文件,用PS打开显示结果如下

在这里插入图片描述

对彩色进行操作:

在这里插入图片描述

彩色图像为三通道,故而代码中修改宽度乘以3

在这里插入图片描述

遇到问题:

修改代码后直接运行报错如下——

在这里插入图片描述

经查找原因得知图像较大,静态数组不够。

解决方法:

修改为动态数组进行图片的操作,解决问题

在这里插入图片描述


代码:

#include <stdio.h>  
#include <stdlib.h>  
#define height  600  
#define width   800 
typedef unsigned char  BYTE;    // 定义BYTE类型,占1个字节  
int main(void)
{
    FILE *fp = NULL;
    BYTE Pic[height][width];
    BYTE *ptr;
    int i, j;
    fp = fopen("weiminglake.raw", "rb");       
    ptr = (BYTE*)malloc(width * height * sizeof(BYTE));//创建内存
    for (i = 0; i < height; i++)
    {
        for (j = 0; j < width; j++)
        {
            fread(ptr, 1, 1, fp);
            Pic[i][j] = *ptr;  // 把图像输入到2维数组中,变成矩阵型式  
            ptr++;
        }
    }
    fclose(fp);
    for (i = 0; i < height; i++)
    {
        for (j = 0; j < width; j++)
        {
            Pic[i][j] = 255 - Pic[i][j];  // 图像反相  
        }
    }
    fp = fopen("output.raw", "wb");
    for (i = 0; i < height; i++)
    {
        for (j = 0; j < width; j++)
        {
            fwrite(&Pic[i][j], 1, 1, fp);
        }
    }
    fclose(fp);
    return 0;
}


3.2 平台:VS2015+OpenCv3.4.1

界面截图:

在这里插入图片描述

运行结果:

灰度图像反相

在这里插入图片描述


彩色图像反相

在这里插入图片描述


代码:

#include <iostream>  
#include <opencv2/core/core.hpp>  
#include <opencv2/highgui/highgui.hpp>  
using namespace cv;
int main() 
{   
    Mat src;
    int height, width;
    int i,j;
    src = imread("weiminglake_huidu.jpg");     //载入图片
    height = src.rows;                       //获取图像信息
    width = src.cols* src.channels();          // 列项要乘通道数
    namedWindow("src", CV_WINDOW_AUTOSIZE);     //创建窗口
    namedWindow("dst", CV_WINDOW_AUTOSIZE);
    imshow("src", src);                       //显示原图
    //图像反转
    for (i = 0; i< height; i++)
    {
        for (j = 0; j< width; j++)
        {
            src.at<uchar>(i, j) = 255 - src.at<uchar>(i, j);   // 每一个像素反转
        }
    }
    imshow("dst", src);                       //显示反相图片
    waitKey(0);
    return 0;
}

当然直接用现成的函数也可以:)

3.3 平台:Matlab

界面截图:

在这里插入图片描述


运行结果:

在这里插入图片描述


分别为:
彩色图像,灰度图像
彩色反相图像,灰度反相图像

代码:

a=imread('weiminglake.jpg');
b=rgb2gray(a);
c = 255 - a;
%c=imcomplement(a); 
%c = intmax(class(a)) - a;
d = 255 - b;
%d=imcomplement(b);
subplot(2,2,1);
imshow(a);
subplot(2,2,2);
imshow(b);
subplot(2,2,3);
imshow(c)
subplot(2,2,4);
imshow(d)

本工程源码已更新至github,欢迎star,欢迎PR:)

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


学习编程是顺着互联网的发展潮流,是一件好事。新手如何学习编程?其实不难,不过在学习编程之前你得先了解你的目的是什么?这个很重要,因为目的决定你的发展方向、决定你的发展速度。
IT行业是什么工作做什么?IT行业的工作有:产品策划类、页面设计类、前端与移动、开发与测试、营销推广类、数据运营类、运营维护类、游戏相关类等,根据不同的分类下面有细分了不同的岗位。
女生学Java好就业吗?女生适合学Java编程吗?目前有不少女生学习Java开发,但要结合自身的情况,先了解自己适不适合去学习Java,不要盲目的选择不适合自己的Java培训班进行学习。只要肯下功夫钻研,多看、多想、多练
Can’t connect to local MySQL server through socket \'/var/lib/mysql/mysql.sock问题 1.进入mysql路径
oracle基本命令 一、登录操作 1.管理员登录 # 管理员登录 sqlplus / as sysdba 2.普通用户登录
一、背景 因为项目中需要通北京网络,所以需要连vpn,但是服务器有时候会断掉,所以写个shell脚本每五分钟去判断是否连接,于是就有下面的shell脚本。
BETWEEN 操作符选取介于两个值之间的数据范围内的值。这些值可以是数值、文本或者日期。
假如你已经使用过苹果开发者中心上架app,你肯定知道在苹果开发者中心的web界面,无法直接提交ipa文件,而是需要使用第三方工具,将ipa文件上传到构建版本,开...
下面的 SQL 语句指定了两个别名,一个是 name 列的别名,一个是 country 列的别名。**提示:**如果列名称包含空格,要求使用双引号或方括号:
在使用H5混合开发的app打包后,需要将ipa文件上传到appstore进行发布,就需要去苹果开发者中心进行发布。​
+----+--------------+---------------------------+-------+---------+
数组的声明并不是声明一个个单独的变量,比如 number0、number1、...、number99,而是声明一个数组变量,比如 numbers,然后使用 nu...
第一步:到appuploader官网下载辅助工具和iCloud驱动,使用前面创建的AppID登录。
如需删除表中的列,请使用下面的语法(请注意,某些数据库系统不允许这种在数据库表中删除列的方式):
前不久在制作win11pe,制作了一版,1.26GB,太大了,不满意,想再裁剪下,发现这次dism mount正常,commit或discard巨慢,以前都很快...
赛门铁克各个版本概览:https://knowledge.broadcom.com/external/article?legacyId=tech163829
实测Python 3.6.6用pip 21.3.1,再高就报错了,Python 3.10.7用pip 22.3.1是可以的
Broadcom Corporation (博通公司,股票代号AVGO)是全球领先的有线和无线通信半导体公司。其产品实现向家庭、 办公室和移动环境以及在这些环境...
发现个问题,server2016上安装了c4d这些版本,低版本的正常显示窗格,但红色圈出的高版本c4d打开后不显示窗格,
TAT:https://cloud.tencent.com/document/product/1340