http://blog.sina.com.cn/s/blog_4a93ccea0100d1lw.html

一、图像基本操作

1.读取图像并显示:

>> clear;close all         %清空Matlab工作平台所有变量(准备工作)

>> I=imread('pout.tif');  % 该图像是Matlab图形工具箱中自带的图像(\toolbox\images\imdemos)

>> imshow(I)

2.检查内存(数组)中的图像:

>> whos

Name      Size                    Bytes   Class

I       291x240                   69840  uint8 array

Grand total is 69840 elements using 69840 bytes

表示该图像采用8位存储方式并占用了69840B的存储空间。

3.实现图像直方图均衡化:

>> figure,imhist(I)    % 在新图中显示图像I的直方图

>> I2=histeq(I);  % 均衡化以后的图像存在I2数组中(图像灰度值扩展到整个灰度范围,对比度提高)

>> figure,imshow(I2)  % 显示均衡化后的图像

>> figure,imhist(I2)   % 显示均衡后的灰度值分布情况

8位图像取值范围:[0,255],16位图像取值范围:[0,655351],双精度图像取值范围:[0,1]

4.保存图像:

>> imwrite(I2,'pout2.png');    % 将图像由原先的tif格式另存为png格式

5.检查新生成文件的信息:

>> imfinfo('pout2.png')     % 观察保存图像的文件信息

ans =

Filename: 'pout2.png'       % 文件名

FileModDate: '11-Apr-2009 21:55:35'   % 文件修改日期

FileSize: 36938       % 文件大小

Format: 'png'       % 文件格式

FormatVersion: []          % 格式

Width: 240        % 文件宽度

Height: 291        % 文件高度

BitDepth: 8          % 文件位深度

ColorType: 'grayscale'  % 颜色类型

……

二、图像处理Matlab的应用:

实例:消除rice.png图像中亮度不一致的背景,并使用阈值将修改后的图像转换为二值图像,使用成员标记返回图像中对象的个数以及统计特性。按照如下步骤进行:

1.读取和显示图像

>> clear;close all

>> I=imread('rice.png');

>> imshow(I)

2.估计图像背景:

图像中心位置背景亮度强于其他部分亮度,用imopen函数和一个半径为15的圆盘结构元素对输入的图像I进行形态学开操作,去掉那些不完全包括在圆盘中的对象,从而实现对背景亮度的估计。

>> clear;close all

>> I=imread('rice.png');

>> imshow(I)

>> background=imopen(I,strel('disk',15));

>> imshow(background)

>> figure,surf(double(background(1:8:end,1:8:end))),zlim([0,255]);

>> set(gca,'ydir','reverse');

显示了背景图(左)和背景表面图(右)

3.从原始图像中减去背景图像(原始图像I减去背景图像得到背景较为一致的图像):

>> I2=imsubtract(I,background);

>> figure,imshow(I2)

4.调节图像的对比度 (图像较暗,可用imadjust函数命令来调节图像的对比度)

>> I3=imadjust(I2,stretchlim(I2),[0 1]);

>> figure,imshow(I3);

5.使用阈值操作将图像转换为二进制(二值)图像(bw),调用whos命令查看图像的存储信息.

>> level=graythresh(I3);   % 图像灰度处理

>> bw=im2bw(I3,level);     % 图像二值化处理

>> figure,imshow(bw)       % 显示处理后的图片

>> whos

Name             Size                    Bytes  Class

I              256x256                   65536  uint8 array

I2             256x256                   65536  uint8 array

I3             256x256                   65536  uint8 array

background     256x256                   65536  uint8 array

bw             256x256                   65536  logical array

level            1x1                         8  double array

Grand total is 327681 elements using 327688 bytes

6.检查图像中对象个数(bwlabel函数表示了二值图像中的所有相关成分并返回在图像中找到的对象个数)

>> [labeled,numObjects]=bwlabel(bw,4);

>> numObjects

numObjects =

101

表示图像中的米粒对象个数是101.

7.检查标记矩阵:(imcrop命令进行交互式操作,图像内拉出较小矩形并显示已标记的对象和部分背景内的像素)

>> grain=imcrop(labeled)

grain =

0     0    42    42    42    42    42    42    42     0

0     0    42    42    42    42    42    42    42    42

0     0    42    42    42    42    42    42    42    42

0     0    42    42    42    42    42    42    42    42

0     0    42    42    42    42    42    42    42    42

0     0    42    42    42    42    42    42    42    42

0    42    42    42    42    42    42    42    42    42

0    42    42    42    42    42    42    42    42    42

8.观察标记矩阵(用label2rgb将其显示为一副伪彩色的索引图像):

>> RGB_label=label2rgb(labeled,@spring,'c','shuffle');

>> imshow(RGB_label);

9.测量图像对象或区域的属性(Regionprops,返回一个结构数据)

>> graindata=regionprops(labeled,'basic')

graindata =

101x1 struct array with fields:

Area

Centroid

BoundingBox

>> graindata(40).Area   % 显示矩阵中第40个元素的属性

ans =

197

>> graindata(40).BoundingBox,graindata(40).Centroid    % 寻找最近的边缘和中心点

ans =

82.5000   59.5000   24.0000   20.0000

ans =

95.4213   70.4924

>> allgrains=[graindata.Area];     % 创建一个新的向量allgrains,其包含每个米粒的范围

>> whos allgrains

Name            Size                    Bytes  Class

allgrains       1x101                     808  double array

Grand total is 101 elements using 808 bytes

>> allgrains(51)     % 相当于整个矩阵的索引为51的属性是多少,可见与原来得到的结果相同

ans =

140

>> max(allgrains)    % 获取最大的米粒大小

ans =

404

>> biggrain=find(allgrains==404)    % 使用find命令返回这个最大尺寸米粒的标记号

biggrain =

59

>> mean(allgrains)   % 获取米粒的平均大小

ans =

175.0396

9.绘制包含30个柱的直方图来说明米粒大小的分布情况

>> hist(allgrains,30)

(米粒大小分布柱状图)

matlab修改图片位深度_Matlab 图像处理基本操作相关推荐

  1. matlab修改图片位深度_MATLAB 图像处理

    MATLAB 图像处理 基础 简介 图像类型 灰度图像 二值图像 RGB图像 索引图像 颜色图 colorcube 获取颜色图 colormap 更改颜色图 HSV彩色空间 rgb2hsv 将RGB颜 ...

  2. matlab修改图片位深度_如何利用matlab统一处理照片亮度对比度

    第一:下软件MATLAB,和插件SHINEtoolbox.安装路径最好不要有中文. 将插件复制到文件夹下见图片 注意:不用学习matlab的具体应用,会使用插件就行了,插件是已经做好的编程,仅需把插件 ...

  3. matlab修改图片位深度_BMP位图32位转为24位深度

    帮朋友做一个视频采集和基本处理功能,要求的是.bmp格式 几天下来,通过directshow进行视频采集,并抓去图片保存,按照要求进行业务处理,以前的处理程序是基于RGB24 而显示器是32位真彩色, ...

  4. matlab 图像读取长宽_MATLAB图像处理基本操作

    本文中对于大多数的操作,是对数字图像处理领域中最为著名的"lena"图片进行操作的.原图如下(Figure 1): 本文中对于大多数的操作,是对数字图像处理领域中最为著名的&quo ...

  5. 【图片位深度改变】24位深度转8位深度

    代码如下: """ 2020.09.26:alian 改变图片的位深度 """ from PIL import Image import n ...

  6. 关于修改ico图片位深度的方法

    在vs08中载入待修改的图片,并打开,右键选择新建图片类型,然后选择自定义,定义自己需要的位深度的图片.再把以前的那个类型删掉就好了

  7. 32位java怎么改_java修改24位深度png图片为32位深度

    前言 在做图片切割时,发现切除来的图片空白部分变成了黑色背景,发现属性是24位深度 解决方案 1.先上代码 BufferedImage image = readImage(url); Buffered ...

  8. C# 图片位深度转至8位灰度图像,8位灰度图像转为1位灰度图像

    #region 二值化 #region Otsu阈值法二值化模块 /// <summary>            /// Otsu阈值            /// </summa ...

  9. matlab计算多张图像的灰度直方图_MATLAB图像处理基本操作

    本文中对于大多数的操作,是对数字图像处理领域中最为著名的"lena"图片进行操作的.原图如下(Figure 1): 本文中对于大多数的操作,是对数字图像处理领域中最为著名的&quo ...

最新文章

  1. 最近实际项目中遇到的技术问题与解决思路
  2. 基于Java语言构建区块链(五)—— 地址(钱包)
  3. jvm 参数_6个提高性能的JVM参数
  4. Hadoop用户配置免密登陆
  5. genymotion+android studio Android 搭建开发环境
  6. python双人格斗游戏代码_百行 HTML5 代码实现四种双人对弈游戏
  7. 河南理工大学计算机软件考研857数据结构
  8. 计算机网络实用技术教程txt,计算机网络实用技术教程
  9. 模电和数电复习资料//2021-2-18
  10. 重读经典:《End-to-End Object Detection with Transformers》
  11. TP 全系列调试通用参考说明
  12. Orcal 用户权限
  13. [转]NFA/DFA算法
  14. 【人脸检测】centerface唐人街探案50fps
  15. go语言 第三方包安装方法_安装第三方软件到电视的方法,看直播应该下载什么软件?...
  16. CUIT第七届智能小车(基础四轮电磁组)比赛总结
  17. 按照分数进行名次计算、名次排序
  18. MySQL之数据库引擎及修改引擎的方法
  19. Unity3D FPS Game:第一人称射击游戏(二)
  20. python模拟登陆淘宝

热门文章

  1. 计算机网络桂电北海期末题,2078电大《网络信息制作与发布》试题和答案200407...
  2. 网络教育计算机 判断,重庆网络教育计算机应用基础练习题(3)
  3. 台式计算机激光头,cd机激光头维修论坛-CD机维修,我家台式CD机坏了,进仓后激光头只动动,但是不发红光,懂的朋友来指点。-电气资讯 - 电工屋...
  4. 石河子大学师生为荣获2018年“马云乡村教师奖”校友点赞
  5. 巨控GRM110系列的LORA无线通信模块,短距离无线数据传输,巨控无线433无线通信技术
  6. 7-229 sdut-C语言实验- 排序7-227 sdut- C语言实验-计算1到n的和(循环结构)
  7. 【无标题】No qualifying bean of type ‘javax.sql.DataSource‘ available: expected at least 1
  8. setsockopt用法描述
  9. 藏在爱情里的那些咒语,你被下蛊了么?
  10. Vue微信网页微信支付