本文整理汇总了C++中BMP::write方法的典型用法代码示例。如果您正苦于以下问题:C++ BMP::write方法的具体用法?C++ BMP::write怎么用?C++ BMP::write使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类BMP
的用法示例。
在下文中一共展示了BMP::write方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: fin
int
main(int argc,char** argv){
BMP fin (argv[1]);
BMP fout;fout.init(fin.w,fin.h);
double (*in )[8];
double (*out )[8];
double (*out2)[8];
fftw_plan p ;
int i,j,idx;
in = (double (*)[8])fftw_malloc( sizeof(double) * 8*8);
out = (double (*)[8])fftw_malloc( sizeof(double) * 8*8);
out2= (double (*)[8])fftw_malloc( sizeof(double) * 8*8);
for(int c=0;c<3;c++){
for(int by=0;by<fin.h/8;by++)
for(int bx=0;bx<fin.w/8;bx++){
for(int dy=0;dy<8;dy++)
for(int dx=0;dx<8;dx++){
int x=bx*8+dx;
int y=by*8+dy;
in[ dy][ dx]=fin(x,y)[c];
}
p = fftw_plan_r2r_2d( 8,8,
(double*)in, (double*)out,
FFTW_REDFT10,FFTW_REDFT10,
FFTW_ESTIMATE );
fftw_execute(p);
for(int dy=0;dy<8;dy++)
for(int dx=0;dx<8;dx++){
out[ dy][ dx]/=8*8*4;
}
for(int dy=0;dy<8;dy++)
for(int dx=0;dx<8;dx++){
// out[ dy][ dx]=round(out[ dy][ dx]/(qt[dy][dx]*quality));
out[ dy][ dx]=round(out[ dy][ dx]/2);
}
for(int dy=0;dy<8;dy++)
for(int dx=0;dx<8;dx++){
// out[ dy][ dx]*=qt[dy][dx]*quality;
out[ dy][ dx]*=2;
}
// for(int dy=0;dy<8;dy++)
// for(int dx=0;dx<8;dx++){
// printf("%04d\n",(int)out[ dy][ dx]);
// }
p = fftw_plan_r2r_2d( 8,8,
(double*)out, (double*)out2,
FFTW_REDFT01,FFTW_REDFT01,
FFTW_ESTIMATE );
fftw_execute(p);
for(int dy=0;dy<8;dy++)
for(int dx=0;dx<8;dx++){
int x=bx*8+dx;
int y=by*8+dy;
fout(x,y)[c]=lmt(out2[ dy][ dx]);
}
}
}
fout.write(argv[2]);
fftw_destroy_plan(p);
fftw_free(in);
fftw_free(out);
fftw_free(out2);
return true;
}