clc;clear all;close all;
workDir=‘D:\aida\matlab’;
fileName=‘Wildlife’;
vidObj =VideoReader(‘Wildlife.wmv’);
vidHeight = vidObj.Height;
vidWidth = vidObj.Width;
k= vidObj.NumberOfFrames;%k是指视频的帧数
s_f=read(vidObj);%将读取的视频保存到s_f中
j=0;%作图,显示窗口的编号,figure
for i=1💯k %从第一帧开始,间隔100帧取图像,直到最后
j=j+1;
I=s_f(:,:,:,i); %读取视频的第i帧,彩色视频是四维,灰度图像视频是三维。
I=double(I);%将数据转化为double类型,
R=I(:,:,1);G=I(:,:,2);B=I(:,:,3); %I指彩色图像,是三维,灰度图像是二维,视频是由一系列图像组成,1是r分量,2是g分量,3是b分量
Y = 0.299R + 0.587G + 0.114B; %RGB转换YUV公式
U = -0.147R - 0.289G + 0.436B;
V = 0.615R - 0.515G - 0.100B;
J=cat(3,Y,U,V); % 3表示构造出的矩阵维数,将A,B两个数组连结
figure(j);
subplot(1,3,1);imshow(uint8(I));title(‘原图’);
subplot(1,3,2);
imshow(J,[]),title(‘RGB转化为YUV的图像’);
R1 = Y + 1.14V;%YUV转RGB公式
G1 = Y - 0.39U - 0.58V;
B1= Y + 2.03*U; I1=cat(3,R1,G1,B1);
subplot(1,3,3);
imshow(uint8(I1)),title(‘YUV转化为RGB的图像’);
end
注释: