资源描述:
《图形图像隐写代码》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、毕业设计图形图像隐写,因而有一些代码,放上来,有的人可能做隐写的时候会难于处理这个,有自带的一个隐写代码。可以没事拿来玩。LSB使用文件头记录长度DCT使用随机选块设计的算法,选择相邻相同区域代码均经过调试。给一个网盘地址,里面有不带界面和带界面的代码各一份,界面可能有bug但是毕业设计完成也懒得找了。这些代码看懂大约花费时间在1周左右,DCT相关运算请不用考虑,看懂流程就行。为了答辩方便代码的注释都删了,有点抱歉LSB隐写Picture=imread('f:\123LSB.png');Double_Picture=double(Picture);file=fopen('f:\123
2、\²âÊÔ.jpg','r');[M,len]=fread(file,'ubit1');len=len/8;[m,n,x]=size(Picture);leniflen>m*n-20error('载体太小无法隐写');break;endiflen<256number=0;elseif256<=len&&4095>=lennumber=1;elseif4096>=len&&65535>=lennumber=2;elsenumber=3;endendendnumberifnumber==0Guide=8;elseifnumber==1Guide=12;elseifnumber==2Guide
3、=16;elseGuide=20;endendendnumLen=dec2bin(number);num=dec2bin(len);[u,v]=size(numLen);fori=1:20Picture(1,i,1)=Picture(1,i,1)-mod(Picture(1,i,1),2);endfori=1:vPicture(1,i,1)=mod(numLen(1,v+1-i),2)+Picture(1,i,1);end[u,v]=size(num);fori=3:v+2Picture(1,i,1)=mod(num(1,v+3-i),2)+Picture(1,i,1);endp=1;%Ð
4、ÅÏ¢¼ÆÊýlen=len*8;forj=Guide+3:nPicture(1,j,1)=Picture(1,j,1)-mod(Picture(1,j,1),2)+M(p,1);ifp==lenbreak;endp=p+1;endfori=2:mforj=1:nPicture(i,j,1)=Picture(i,j,1)-mod(Picture(i,j,1),2)+M(p,1);ifp==lenbreakendp=p+1;end;ifp==lenbreakendendimwrite(Picture,'f:\123\Xlsb.png');OriPicture=imread('f:\12
5、3LSB.png');subplot(121);imshow(OriPicture);title('修改前图片');subplot(122);imshow(Picture);title('修改后图片');LSB隐写提取Picture=imread('f:\123\xLSB.png');Double_Picture=double(Picture);frr=fopen('f:\123\xl.jpg','w');number=0;fori=1:2number=mod(Double_Picture(1,i,1),2)*2^(i-1)+number;endnumberifnumber==0
6、numLen=8;elseifnumber==1numLen=12;elseifnumber==2numLen=16;elsenumLen=20;endendendnumber=0;fori=3:numLennumber=mod(Double_Picture(1,i,1),2)*2^(i-3)+number;endlen=number*8;Double_Picture=uint8(Double_Picture);[m,n,x]=size(Double_Picture);p=1;forj=numLen+3:nifmod(Picture(1,j,1),2)==1fwrite(frr,1,'ub
7、it1');endifmod(Picture(1,j,1),2)==0fwrite(frr,0,'ubit1');endif(p==len)break;endp=p+1;endfori=2:mif(p==len)break;endforj=1:nifmod(Picture(i,j,1),2)==1fwrite(frr,1,'ubit1');elsefwrite(frr,0,'ubit1');endif(p==len)br