# Matlab 小程序 yuv图片融合

1、读取yuv文件中Y、U、V数据
2、处理Y、U、V数据。因为是4:2:0，所以U、V数据是Y数据的1/4，填充存储U、V数据的矩阵，使它们与存储Y数据的矩阵维度一致
3、读取bmp文件，将rgb转为yuv
4、按照小图片的宽和高，将对应大图片的位置的yuv数据替换为小图片的yuv数据，左上对齐
5、将yuv转为rgb，并显示出来

function [] = homework1( )
%UNTITLED 此处显示有关此函数的摘要
%   此处显示详细说明
fid=fopen('horseriding.yuv','r');
% fseek(fid,0,'bof');
row=720;
col=576;

UU=zeros(row,col);
VV=zeros(row,col);

fclose(fid);

UU(1:2:row-1,1:2:col-1)=U0;%使数组维度保持一致
UU(1:2:row-1,2:2:col)=U0;
UU(2:2:row,1:2:col-1)=U0;
UU(2:2:row,2:2:col)=U0;

VV(1:2:row-1,1:2:col-1)=V0;
VV(1:2:row-1,2:2:col)=V0;
VV(2:2:row,1:2:col-1)=V0;
VV(2:2:row,2:2:col)=V0;

% figure,imshow(I),title('原始图像')
% I=double(I);
R=I(:,:,1);
G=I(:,:,2);
B=I(:,:,3);
Y1 = 0.299*R' + 0.587*G' + 0.114*B';
U1 = -0.147*R' - 0.289*G' + 0.436*B';
V1 = 0.615*R' - 0.515*G' - 0.100*B';

for i=1:1:320
for j=1:1:200
Y0(i,j)=Y1(i,j);
UU(i,j)=U1(i,j)+128;
VV(i,j)=V1(i,j)+128;
%             end
end
%     end
end

R = Y0 + 1.140 * (VV-128 );
G = Y0 + 0.395 * (UU-128 ) - 0.581 *(VV-128);
B = Y0 + 2.032 *(UU-128);

for i=1:row %按照RGB阀值255进行值调整后输出RGB图像
for j=1:col
if R(i,j)<0
R(i,j)=0;
end
if R(i,j)>255
R(i,j)=255;
end
if G(i,j)<0
G(i,j)=0;
end
if G(i,j)>255
G(i,j)=255;
end
if B(i,j)<0
B(i,j)=0;
end
if B(i,j)>255
B(i,j)=255;
end
end
end
R=R/255;G=G/255;B=B/255;
%X=[R',G',B'];
images(:,:,1)=R';
images(:,:,2)=G';
images(:,:,3)=B';
figure,imshow(images);

end



10-26

11-05 295
12-06 1544
12-06 1760
04-11 2398
06-21 2万+
10-09 1万+
11-19 4070