亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? inrcast.cpp

?? this a image processing program
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
  // Compute false colors  if (a_falsecolors) {    std::fprintf(stderr,"\n- Compute false colors\t"); std::fflush(stderr);    cimglist_for(src,l) {      CImg<unsigned char> tmp = src[l].get_normalize((T)0,(T)255);      cimg_forXYZV(tmp,x,y,z,k) src[l](x,y,z,k) = (T)cimg::ror((unsigned char)tmp(x,y,z,k),4);    }  }  // Compute image histogram  if (a_histo) {    std::fprintf(stderr,"\n- Compute histogram(s)\t"); std::fflush(stderr);    cimglist_for(src,l) src[l] = src[l].get_histogram(a_histo);  }  // Image break  if (a_break) {    int nb = 0;    std::sscanf(a_break,"%*[xyzvXYZV]%d",&nb);    std::fprintf(stderr,"\n- Break image along axis '%c'\t",a_break[0]); std::fflush(stderr);    CImgList<T> tmp;    cimglist_for(src,l) tmp.insert(src[l].get_split(a_break[0],nb));    src = tmp;  }  // Images append  if (a_append!='\0') {    std::fprintf(stderr,"\n- Append images along axis '%c'\t",a_append); std::fflush(stderr);    src = CImgList<T>(src.get_append(a_append,'p'));  }  // User-selected crop  if (a_ucrop) {    std::fprintf(stderr,"\n- User crop : Please select the image region to crop.\t"); std::fflush(stderr);    int selection[6] = {-1,-1,-1,-1,-1,-1};    src[0].feature_selection(selection,2);    if (selection[0]<0 || selection[1]<0 || selection[2]<0 ||	selection[3]<0 || selection[4]<0 || selection[5]<0) std::fprintf(stderr,".. Aborted..");    else {      std::fprintf(stderr,"-> Crop [%d,%d,%d]-[%d,%d,%d]",		   selection[0],selection[1],selection[2],		   selection[3],selection[4],selection[5]);      cimglist_for(src,l) src[l].crop(selection[0],selection[1],selection[2],selection[3],selection[4],selection[5]);    }  }  // Apply logarithm, square root or square  if (a_log) cimglist_for(src,l) (src[l]+=(T)1e-10f).log();  if (a_sqrt) cimglist_for(src,l) src[l].sqrt();  if (a_sqr) cimglist_for(src,l) src[l].pow(2.0);  // Unroll image  if (a_unroll) {    std::fprintf(stderr,"\n- Unroll image along axis '%c'.\t",a_unroll); std::fflush(stderr);    cimglist_for(src,l) src[l].unroll(a_unroll);  }  // Permute image axes  if (a_permute) {    std::fprintf(stderr,"\n- Permute axes with permutation '%s'.\t",a_permute); std::fflush(stderr);    cimglist_for(src,l) src[l].permute_axes(a_permute);  }  // Annotate images  if (a_annot) {    std::fprintf(stderr,"\n- Annotate image with \"%s\".\t",a_annot); std::fflush(stderr);    cimglist_for(src,l) {      const CImg<T> col(src[l].dimv(),1,1,1,(T)CImgStats(src[l],false).max);      src[l].draw_text(a_annot,5,5,col.ptr());    }  }  // Reverse image list  if (a_reverse) {    std::fprintf(stderr,"\n- Reverse image list"); std::fflush(stderr);    src.reverse();  }  // Convert image to destination type  std::fprintf(stderr,"\n- Conversion to '%s' pixels\t",cimg::type<t>::id()); std::fflush(stderr);  CImgList<t> dest(src);  std::fprintf(stderr,"\n- Output images list : %d image(s)\n",dest.size);  {cimglist_for(dest,l) {    const CImgStats stats(dest[l]);    std::fprintf(stderr,"\t> [%d] : size=%dx%dx%dx%d, min=%g, mean=%g, max=%g, var=%g\n",		 l,dest[l].dimx(),dest[l].dimy(),dest[l].dimz(),dest[l].dimv(),		 stats.min,stats.mean,stats.max,stats.variance);  }}  // Save destination image  if (file_o) {    std::fprintf(stderr,"\n- Save image(s) to '%s'\t",file_o); std::fflush(stderr);    dest.save(file_o);  }  // Display destination image  if (a_visu || !file_o) {    std::fprintf(stderr,"\n- Visualize image(s)\n"); std::fflush(stderr);    if ( dest.size==1 && (	 ( dest[0].dimy()==1 && dest[0].dimz()==1  ) ||	 ( dest[0].dimx()==1  && dest[0].dimz()==1  ) ||	 ( dest[0].dimx()==1  && dest[0].dimy()==1 ) ||	 ( dest[0].dimx()==1  && dest[0].dimy()==1 && dest[0].dimz()==1))) { // 1D plot representation      CImg<t> resized_img;      const CImg<t>& img = dest[0].dimv()<=8?dest[0]:(resized_img=dest[0].get_resize(-100,-100,-100,8,0));      CImgStats stats(img,false);      CImg<unsigned char> palette = CImg<unsigned char>(3,img.dimv(),1,1,0).noise(300,1);      const unsigned char gray[3]={128,128,128},white[3]={255,255,255};      unsigned long trame = 0x0F0F0F0F;      char message[1024];      palette[0]=255; palette[1]=0; palette[2]=0;      if (img.dimv()>1) { palette[3]=0; palette[4]=255; palette[5]=0; }      if (img.dimv()>2) { palette[6]=0; palette[7]=0; palette[8]=255; }      CImgDisplay disp(500,300,"1D plot of the output image",0);      CImg<unsigned char> visu0;      do {	if (!visu0.data || disp.is_resized) { // plot graphics	  disp.resize();	  visu0 = CImg<unsigned char>(disp.dimx(),disp.dimy(),1,3,0);	  if (img.dimv()==1) visu0.draw_graph(img,palette.ptr(),1,stats.max,stats.min,0.4f);	  cimg_forV(img,k) visu0.draw_graph(img.get_shared_channel(k),&palette(0,k),0,stats.max,stats.min);	  visu0.draw_axis(CImg<unsigned int>::sequence(1+visu0.width/60,0,(int)img.size()-1),			  CImg<double>::sequence(1+visu0.height/60,stats.max,stats.min),			  gray);	}	CImg<unsigned char> visu(visu0);	if (disp.mouse_x>=0) {	  visu.draw_line(disp.mouse_x,0,disp.mouse_x,visu.dimy()-1,gray,trame,0.5);	  trame = cimg::rol(trame);	  const unsigned x = disp.mouse_x*img.size()/(img.dimv()*disp.dimx());	  std::sprintf(message,"x=%d\n[ ",x);	  cimg_forV(img,k) std::sprintf(message+std::strlen(message),"%s%g%s",k==0?"":"  ",					(float)img(x,0,0,k),k==img.dimv()-1?"":"\n");	  std::sprintf(message+std::strlen(message)," %s]",dest[0].dimv()<=8?"":"\n...");	  visu.draw_text(message,disp.mouse_x-20,10,white,NULL,1);	} else visu=visu0;	disp.display(visu).wait(40);      } while (!disp.is_closed && !disp.key);    }    else dest.display("inrcast");  }}//---------------------------------------------------------// Read input image and do conversion to output pixel type//---------------------------------------------------------template<typename T> void input_file(int argc, char **argv, T& pixel_type) {  pixel_type = 0;  // Read input image list  std::fprintf(stderr,"- Load image(s)...\t"); std::fflush(stderr);  CImgList<T> src;  CImgList<char> filename;  bool opt = false;  for (int k=1; k<argc; k++)    if (argv[k][0]=='-' && argv[k][1]!='\0' && argv[k][1]!='.') opt=true;    else {      if (!opt ||	  !cimg::strcasecmp(argv[k-1],"-h") ||	  !cimg::strcasecmp(argv[k-1],"-orient") ||	  !cimg::strcasecmp(argv[k-1],"-norm") ||	  !cimg::strcasecmp(argv[k-1],"-equalize") ||	  !cimg::strcasecmp(argv[k-1],"-crop") ||	  !cimg::strcasecmp(argv[k-1],"-plot") ||	  !cimg::strcasecmp(argv[k-1],"-visu") ||	  !cimg::strcasecmp(argv[k-1],"-get_size") ||	  !cimg::strcasecmp(argv[k-1],"-get_width") ||	  !cimg::strcasecmp(argv[k-1],"-get_height") ||	  !cimg::strcasecmp(argv[k-1],"-get_depth") ||	  !cimg::strcasecmp(argv[k-1],"-get_dim")	  ) {	std::fprintf(stderr,"\n\t> Loading [%d]='%s'\t",k-1,argv[k]); std::fflush(stderr);	CImgList<T> tmpl;	const char *ext = cimg::filename_split(argv[k]);	if (!cimg::strcasecmp(ext,"yuv")) {	  unsigned int w=352,h=288;	  const char *geom = cimg_option("-g","352x288",NULL);	  if (geom) std::sscanf(geom,"%u%*c%u",&w,&h);	  unsigned int frame_first=0;	  int frame_last=-1;	  const char *frames = cimg_option("-yuvframes",(const char*)NULL,"YUV range of frames");	  if (frames) std::sscanf(frames,"%u%*c%d",&frame_first,&frame_last);	  tmpl.load_yuv(argv[k],w,h,frame_first,frame_last,true);	} else {	  if (!cimg::strcasecmp(ext,"raw")) {	    unsigned int w=0,h=1,d=1,v=1;	    const char *geom = cimg_option("-g",(char*)NULL,NULL);	    if (geom) std::sscanf(geom,"%u%*c%u%*c%u%*c%u",&w,&h,&d,&v);	    else {	      std::fprintf(stderr,"\ninrcast : You must specify an input geometry (option -g) for .raw images\n");	      std::exit(0);	    }	    const bool multiplexed = cimg_option("-multiplexed",false,"Use multiplexed mode");	    const bool endian_swap = cimg_option("-endian",false,"Big/Little endian mode");	    tmpl = CImgList<T>(CImg<T>::get_load_raw(argv[k],w,h,d,v,multiplexed,endian_swap));	  } else {	    if (!cimg::strcasecmp(ext,"rgb")) {	      unsigned int w=0,h=1;	      const char *geom = cimg_option("-g",(char*)NULL,NULL);	      if (geom) std::sscanf(geom,"%u%*c%u",&w,&h);	      else {		std::fprintf(stderr,"\ninrcast : You must specify an input geometry (option -g) for .rgb images\n");		std::exit(0);	      }	      tmpl = CImgList<T>(CImg<T>::get_load_rgb(argv[k],w,h));	    } else {	      if (!cimg::strcasecmp(ext,"rgba")) {		unsigned int w=0,h=1;		const char *geom = cimg_option("-g",(char*)NULL,NULL);		if (geom) std::sscanf(geom,"%u%*c%u",&w,&h);		else {		  std::fprintf(stderr,"\ninrcast : You must specify an input geometry (option -g) for .rgba images\n");		  std::exit(0);		}		tmpl = CImgList<T>(CImg<T>::get_load_rgba(argv[k],w,h));	      } else tmpl = CImgList<T>(argv[k]);	    }	  }	}	const CImg<char> name(argv[k],cimg::strlen(argv[k])+1);	if (tmpl.size==1) filename.insert(name);	else cimglist_for(tmpl,l) {	  char s[1024];	  std::sprintf(s,"%s [%d]",name.data,l);	  filename.insert(CImg<char>(s,cimg::strlen(s)+1));	}	src.insert(tmpl);      }      opt=false;    }  std::fputc('\n',stderr);  // Convert to output pixel type (if specified)  const char *typei = cimg_option("-i","float",NULL);  const char *typeo = cimg_option("-t",typei,NULL);  bool saved = false;  if (!saved && !cimg::strcasecmp(typeo,"bool"))   { bool t=false;       output_file(argc,argv,src,filename,t); saved=true; }  if (!saved && !cimg::strcasecmp(typeo,"char"))   { char t=0;           output_file(argc,argv,src,filename,t); saved=true; }  if (!saved && !cimg::strcasecmp(typeo,"uchar"))  { unsigned char t=0;  output_file(argc,argv,src,filename,t); saved=true; }  if (!saved && !cimg::strcasecmp(typeo,"ushort")) { unsigned short t=0; output_file(argc,argv,src,filename,t); saved=true; }  if (!saved && !cimg::strcasecmp(typeo,"short"))  { short t=0;          output_file(argc,argv,src,filename,t); saved=true; }  if (!saved && !cimg::strcasecmp(typeo,"uint"))   { unsigned int t=0;   output_file(argc,argv,src,filename,t); saved=true; }  if (!saved && !cimg::strcasecmp(typeo,"int"))    { int t=0;            output_file(argc,argv,src,filename,t); saved=true; }  if (!saved && !cimg::strcasecmp(typeo,"ulong"))  { unsigned long t=0;  output_file(argc,argv,src,filename,t); saved=true; }  if (!saved && !cimg::strcasecmp(typeo,"long"))   { long t=0;           output_file(argc,argv,src,filename,t); saved=true; }  if (!saved && !cimg::strcasecmp(typeo,"float"))  { float t=0;          output_file(argc,argv,src,filename,t); saved=true; }  if (!saved && !cimg::strcasecmp(typeo,"double")) { float t=0;          output_file(argc,argv,src,filename,t); saved=true; }  if (!saved) { std::fprintf(stderr,"inrcast : Cannot save image with pixel type '%s' (see help)",typeo); std::exit(0); }}//----------------// Main procedure//----------------int main(int argc,char **argv) {  cimg_usage("1D/2D/3D Image(s) converter and visualizer.\n\t\tusage : inrcast [options] image_in1 [image_in2] [...] [-o image_out]");  if (argc==1) { std::fprintf(stderr,"Try '%s -h' to get help\n",cimg::basename(argv[0])); std::exit(0); }  // Read input image and call converter  bool casted = false;  const char *typei = cimg_option("-i","float",NULL);  if (!casted && !cimg::strcasecmp(typei,"bool"))   { bool t=false;       input_file(argc,argv,t); casted=true; }  if (!casted && !cimg::strcasecmp(typei,"char"))   { char t=0;           input_file(argc,argv,t); casted=true; }  if (!casted && !cimg::strcasecmp(typei,"uchar"))  { unsigned char t=0;  input_file(argc,argv,t); casted=true; }  if (!casted && !cimg::strcasecmp(typei,"ushort")) { unsigned short t=0; input_file(argc,argv,t); casted=true; }  if (!casted && !cimg::strcasecmp(typei,"short"))  { short t=0;          input_file(argc,argv,t); casted=true; }  if (!casted && !cimg::strcasecmp(typei,"uint"))   { unsigned int t=0;   input_file(argc,argv,t); casted=true; }  if (!casted && !cimg::strcasecmp(typei,"int"))    { int t=0;            input_file(argc,argv,t); casted=true; }  if (!casted && !cimg::strcasecmp(typei,"ulong"))  { unsigned long t=0;  input_file(argc,argv,t); casted=true; }  if (!casted && !cimg::strcasecmp(typei,"long"))   { long t=0;           input_file(argc,argv,t); casted=true; }  if (!casted && !cimg::strcasecmp(typei,"float"))  { float t=0;          input_file(argc,argv,t); casted=true; }  if (!casted && !cimg::strcasecmp(typei,"double")) { float t=0;          input_file(argc,argv,t); casted=true; }  if (!casted) { std::fprintf(stderr,"Cannot load image pixel type '%s' (see help)",typei); std::exit(0); }  // Return to shell  std::fprintf(stderr,"Done !\n");  std::exit(0);  return 0;}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
丁香桃色午夜亚洲一区二区三区| 欧美高清在线一区| 亚洲成人av中文| 欧美日韩精品免费观看视频 | 色婷婷av一区二区三区软件 | 日本网站在线观看一区二区三区| 欧美三日本三级三级在线播放| 亚洲一区二区欧美日韩| 91精品在线观看入口| 麻豆成人综合网| 国产欧美一区二区精品仙草咪| 风流少妇一区二区| 亚洲日穴在线视频| 欧美肥大bbwbbw高潮| 国产真实乱对白精彩久久| 日本一区二区在线不卡| 色吊一区二区三区| 欧美aaa在线| 欧美激情综合网| 欧美三级中文字幕| 国产麻豆成人传媒免费观看| 国产精品久久久久久久久久久免费看| 色婷婷综合中文久久一本| 五月天国产精品| 国产蜜臀97一区二区三区| 在线日韩国产精品| 国产伦精品一区二区三区视频青涩 | 在线中文字幕一区二区| 日本不卡中文字幕| 中文字幕一区视频| 91精品国产入口| 不卡av电影在线播放| 日韩va欧美va亚洲va久久| 欧美国产激情一区二区三区蜜月| 欧美视频一区二区三区四区 | 六月婷婷色综合| 国产精品婷婷午夜在线观看| 欧美撒尿777hd撒尿| 国产乱码精品一区二区三区忘忧草| 亚洲欧美韩国综合色| 精品少妇一区二区三区免费观看 | 欧美网站一区二区| 国产成人av网站| 午夜精品久久久久影视| 中文字幕中文字幕在线一区 | 韩国欧美国产一区| 九九热在线视频观看这里只有精品| 中文字幕亚洲区| 久久综合狠狠综合久久激情| 成人黄色小视频| 久久99精品久久久久久国产越南| 一区二区高清在线| 国产精品色噜噜| 久久综合九色综合97婷婷女人 | 26uuu亚洲综合色欧美| 色婷婷亚洲精品| 成人性生交大片免费看中文| 久久99热这里只有精品| 五月开心婷婷久久| 一区二区三区久久| 亚洲少妇屁股交4| 中文成人av在线| 中文字幕免费在线观看视频一区| 欧美一区二区在线看| 欧美日韩黄色一区二区| 日本丶国产丶欧美色综合| 成人av免费在线观看| 国产成人午夜精品影院观看视频| 久久国产精品露脸对白| 日日夜夜精品视频免费| 午夜国产精品影院在线观看| 一二三四区精品视频| 亚洲永久免费视频| 亚洲一本大道在线| 亚洲国产日产av| 一个色在线综合| 亚洲香肠在线观看| 亚洲一区二区欧美激情| 亚洲成a人片在线不卡一二三区| 亚洲久本草在线中文字幕| 一区二区在线观看免费视频播放| 亚洲欧美日韩在线播放| 亚洲日本va午夜在线电影| 一区二区三区四区国产精品| 亚洲黄色小视频| 亚洲国产精品久久人人爱| 亚洲伊人伊色伊影伊综合网| 午夜精品影院在线观看| 乱中年女人伦av一区二区| 99re这里只有精品视频首页| 成人综合在线观看| 波多野结衣精品在线| 一本一道波多野结衣一区二区 | 国产91精品久久久久久久网曝门| 国产一区亚洲一区| 成人av免费观看| 色成年激情久久综合| 欧美日韩和欧美的一区二区| 欧美大胆一级视频| 久久久久久97三级| 成人免费一区二区三区在线观看| 亚洲一区二区在线观看视频 | 亚洲一区二区三区四区的| 午夜精品福利久久久| 韩国v欧美v亚洲v日本v| 成人午夜激情影院| 欧美日韩国产小视频| 精品国产一区二区三区久久影院| 国产精品免费丝袜| 午夜激情一区二区三区| 国产成人免费视频精品含羞草妖精| 99久久精品久久久久久清纯| 欧美三级三级三级| 国产无一区二区| 亚洲精品国产无天堂网2021| 日韩一区欧美二区| 成人性视频免费网站| 欧美日韩国产在线观看| 欧美激情一区二区三区全黄| 亚洲国产成人tv| 国产成人精品一区二 | 在线观看91精品国产麻豆| 久久久www成人免费无遮挡大片| 日韩美女视频一区| 狠狠色综合日日| 欧美性猛交xxxxxx富婆| 国产欧美一区二区三区沐欲| 性做久久久久久久久| 成人污污视频在线观看| 欧美二区乱c少妇| 亚洲精品日韩专区silk| 黄网站免费久久| 911精品国产一区二区在线| 国产精品高潮久久久久无| 美腿丝袜亚洲色图| 欧美专区日韩专区| 国产精品成人午夜| 国产一区福利在线| 欧美日韩精品一区二区三区| 中文字幕一区二区三区在线不卡 | 国产麻豆日韩欧美久久| 欧美日韩大陆在线| 中文字幕综合网| 国产高清一区日本| 欧美成人三级电影在线| 亚洲bdsm女犯bdsm网站| 成人免费福利片| 久久久另类综合| 免费在线成人网| 欧美日韩免费观看一区二区三区| 欧美国产日韩在线观看| 国产麻豆精品在线| 一区二区三区在线免费视频 | 亚洲永久精品大片| 91同城在线观看| 国产精品三级视频| 国产黄人亚洲片| 久久人人爽爽爽人久久久| 九九精品视频在线看| 日韩精品一区二| 奇米色777欧美一区二区| 欧美精品久久久久久久多人混战 | 欧美日韩中文精品| 亚洲小说欧美激情另类| 在线观看区一区二| 一区二区三区国产精华| 91久久线看在观草草青青| 亚洲精选免费视频| 欧美在线观看一二区| 一区二区三区久久| 欧美人体做爰大胆视频| 日韩精品一二区| 日韩欧美国产麻豆| 精品综合免费视频观看| 精品久久久久香蕉网| 久久99精品国产.久久久久久| 日韩三区在线观看| 国产精品亚洲人在线观看| 欧美激情一区二区三区全黄| 成人av电影免费观看| 亚洲男同性视频| 欧美日韩在线三区| 日韩在线a电影| 久久综合久久综合久久| 波多野洁衣一区| 亚洲自拍偷拍图区| 日韩欧美区一区二| 国产麻豆视频精品| 亚洲欧美色图小说| 91精品国产综合久久国产大片| 久久国产福利国产秒拍| 久久婷婷久久一区二区三区| jizzjizzjizz欧美| 亚洲一卡二卡三卡四卡无卡久久 | 日韩一级黄色大片| 国产一区二区三区免费看| 国产精品久久午夜| 欧美日韩成人综合在线一区二区| 久久爱另类一区二区小说| 专区另类欧美日韩|