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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? xrit2image.cpp

?? HRIT讀取,用于在LINUX下顯示高束數(shù)據(jù)圖像
?? CPP
字號(hào):
//---------------------------------------------------------------------------////  File        :   XRIT2Image.cpp//  Description :   Export MSG HRIT format in Image format//  Project     :   Lamma 2004//  Author      :   Graziano Giuliani (Lamma Regione Toscana)//  Source      :   n/a////  This program is free software; you can redistribute it and/or modify//  it under the terms of the GNU General Public License as published by//  the Free Software Foundation; either version 2 of the License, or//  (at your option) any later version.////  This program is distributed in the hope that it will be useful,//  but WITHOUT ANY WARRANTY; without even the implied warranty of//  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the//  GNU General Public License for more details.////  You should have received a copy of the GNU General Public License//  along with this program; if not, write to the Free Software//  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA////---------------------------------------------------------------------------#include <Magick++.h>#undef PACKAGE_BUGREPORT#undef PACKAGE_NAME#undef PACKAGE_STRING#undef PACKAGE_TARNAME#undef PACKAGE_VERSION#include <config.h>#include <iostream>#include <fstream>#include <hrit/MSG_HRIT.h>#include <getopt.h>#include <glob.h>#define PATH_SEPARATOR "/"// For windows use #define PATH_SEPARATOR "\"void usage(char *pname);std::string underscoreit(std::string base, int final_len);int main(int argc, char *argv[ ]){  char *directory = NULL;  char *overlay_image = NULL;  char *resolution = NULL;  char *productid1 = NULL;  char *productid2 = NULL;  char *timing = NULL;  char *format = NULL;  char *pname = strdup(argv[0]);  float geometry = 1.0;  bool normalize = false;  bool do_overlay = false;  while (1) {    int option_index = 0;    int c;    static struct option long_options[] = {      {"directory", 1, 0, 'd'},      {"resolution", 1, 0, 'r'},      {"productid1", 1, 0, 's'},      {"productid2", 1, 0, 'c'},      {"outformat", 1, 0, 'f'},      {"outscale", 1, 0, 'g'},      {"overlay", 1, 0, 'o'},      {"time", 1, 0, 't'},      {"normalize", 0, 0, 'n'},      {"version", 0, 0, 'V'},      {"help", 0, 0, 'h'},      {0, 0, 0, 0}    };    c = getopt_long (argc, argv, "d:r:s:c:f:g:o:t:nVh?",                     long_options, &option_index);    if (c == -1)      break;    switch (c)    {      case 'd':       directory = strdup(optarg);       break;      case 'r':       resolution = strdup(optarg);       break;      case 's':       productid1 = strdup(optarg);       break;      case 'c':       productid2 = strdup(optarg);       break;      case 'f':       format = strdup(optarg);       break;      case 'g':       geometry = strtod(optarg, (char **)NULL);       break;      case 'o':       do_overlay = true;       overlay_image = strdup(optarg);       break;      case 't':       timing = strdup(optarg);       break;      case 'n':       normalize = true;       break;      case 'V':       std::cout << pname << " " << PACKAGE_STRING << std::endl;       return 0;      case '?':      case 'h':       usage(pname);       return(0);       break;      default:       std::cerr << "?? getopt returned character code"                 << std::oct << c << "??" << std::endl;       usage(pname);       return(1);    }  }  if (resolution == NULL || productid1 == NULL ||      productid2 == NULL || timing == NULL)  {    usage(pname);    return(1);  }  std::string filename;  if (directory) filename = directory;  else filename = ".";  filename = filename + PATH_SEPARATOR + resolution;  filename = filename + "-???-??????-";  filename = filename + underscoreit(productid1, 12) + "-";  filename = filename + underscoreit(productid2, 9) + "-";  filename = filename + "0?????___" + "-";  filename = filename + timing + "-" + "?_";  glob_t globbuf;  globbuf.gl_offs = 1;  if ((glob(filename.c_str( ), GLOB_DOOFFS, NULL, &globbuf)) != 0)  {    std::cerr << "No such file(s)." << std::endl;    return 1;  }  int nsegments = globbuf.gl_pathc;  MSG_header *header;  MSG_data *msgdat;  header = new MSG_header[nsegments];  msgdat = new MSG_data[nsegments];  for (int i = 0; i < nsegments; i ++)  {    std::ifstream hrit(globbuf.gl_pathv[i+1],                       (std::ios::binary | std::ios::in));    if (hrit.fail())    {      std::cerr << "Cannot open input hrit file "                << globbuf.gl_pathv[i+1] << std::endl;      return 1;    }    header[i].read_from(hrit);    msgdat[i].read_from(hrit, header[i]);    hrit.close( );    std::cout << header[i];  }  globfree(&globbuf);  if (header[0].segment_id->data_field_format == MSG_NO_FORMAT)  {    std::cout << "Product dumped in binary format." << std::endl;    return 0;  }  int totalsegs = header[0].segment_id->planned_end_segment_sequence_number;  int *segsindexes = new int[totalsegs];   for (int i = 0; i < totalsegs; i ++)    segsindexes[i] = -1;  for (int i = 0; i < nsegments; i ++)    segsindexes[header[i].segment_id->sequence_number-1] = i;  filename = resolution;  filename = filename + "-" + productid1 + "-" + productid2 + "-" +             timing;  if (format)    filename = filename + "." + format;  else    filename = filename + ".jpg";  int npix = header[0].image_structure->number_of_columns;  int nlin = header[0].image_structure->number_of_lines;  size_t npixperseg = npix*nlin;  size_t total_size = totalsegs*npixperseg;  MSG_SAMPLE *pixels = new MSG_SAMPLE[total_size];  memset(pixels, 0, total_size*sizeof(MSG_SAMPLE));  size_t pos = 0;  for (int i = 0; i < totalsegs; i ++)  {    if (segsindexes[i] >= 0)      memcpy(pixels+pos, msgdat[segsindexes[i]].image->data,             npixperseg*sizeof(MSG_SAMPLE));    pos += npixperseg;  }  Magick::Image *image = new Magick::Image(npix, nlin*totalsegs,                                     "I", Magick::ShortPixel, pixels);  if (normalize) image->normalize( );  image->rotate(180.0);  if (header[0].segment_id->spectral_channel_id < 12)  {    if (do_overlay)    {      Magick::Image overlay;      overlay.read(overlay_image);      image->composite(overlay, 0, 0, Magick::PlusCompositeOp);    }  }  if (geometry < 1.0)  {    Magick::Geometry geom((int) ((float) npix*geometry),                  (int) ((float) nlin*totalsegs*geometry));    image->scale(geom);  }  image->write(filename);  delete image;  delete [ ] pixels;  delete [ ] header;  delete [ ] msgdat;  delete [ ] segsindexes;  return 0;}void usage(char *pname){  std::cout << pname << ": Convert HRIT/LRIT files to pgm format." << std::endl;  std::cout << std::endl << "Usage:" << std::endl << "\t"            << pname << " [-d directory] [-f format] [-n] [-g scale]"            << " [-o overlay_image] -r resol"            << " -s prodid1 -c prodid2 -t time"            << std::endl << std::endl            << "Example: " << std::endl << "\t" << pname            << " -d data/HRIT -f jpg -g 0.2 -r H -s MSG1 -c HRV -t 200402101315"            << std::endl;  return;}std::string underscoreit(std::string base, int final_len){  char *tmp;  int mlen;  tmp = (char *) malloc((final_len+1) * sizeof(char));  tmp[final_len] = 0;  memset(tmp, 0x5F, final_len);  mlen = strlen(base.c_str( ));  if (mlen > final_len) mlen = final_len;  memcpy(tmp, base.c_str( ), mlen);  std::string retval = tmp;  free(tmp);  return retval;}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩午夜精品| 日韩精品亚洲专区| 亚洲免费视频成人| 日本欧美韩国一区三区| 国产九九视频一区二区三区| 99在线精品观看| 欧美亚洲自拍偷拍| 欧美激情一区在线观看| 亚洲成人资源在线| 成人深夜视频在线观看| 9191成人精品久久| 亚洲人成人一区二区在线观看| 亚洲国产毛片aaaaa无费看 | 乱一区二区av| 91久久久免费一区二区| 中国色在线观看另类| 久久99国产精品免费| 欧美日韩第一区日日骚| 亚洲一区二区三区四区在线免费观看| 日产精品久久久久久久性色| 日本精品免费观看高清观看| 亚洲私人黄色宅男| 欧美性高清videossexo| 亚洲精品久久7777| 91麻豆123| 亚洲精品视频在线看| 91福利资源站| 性久久久久久久| 日韩午夜激情电影| 国产在线精品不卡| 国产精品久久久久久久久快鸭| 99久久精品免费看国产| 国产精品毛片大码女人| 色国产综合视频| 免费观看91视频大全| 欧美www视频| 91蝌蚪porny九色| 免费成人av资源网| 亚洲天堂成人在线观看| 精品视频1区2区| 国产高清在线精品| 一区二区久久久久| 久久天堂av综合合色蜜桃网| 色婷婷亚洲一区二区三区| 五月婷婷激情综合| 亚洲视频资源在线| xf在线a精品一区二区视频网站| 欧美日韩中字一区| 91免费版在线| 粗大黑人巨茎大战欧美成人| 日本欧美在线观看| 午夜伊人狠狠久久| 一区二区国产盗摄色噜噜| 欧美国产综合色视频| 精品国偷自产国产一区| 欧美老年两性高潮| 欧美性生活影院| 91在线视频免费观看| 成人免费黄色在线| www..com久久爱| 国产成人精品影院| 成人18视频日本| 99视频在线精品| 色丁香久综合在线久综合在线观看| 国产成人a级片| av一区二区三区| av一区二区不卡| 色诱视频网站一区| 欧美精品国产精品| 久久综合久色欧美综合狠狠| 久久午夜老司机| 最近日韩中文字幕| 五月综合激情日本mⅴ| 精一区二区三区| 成人av在线看| 欧美精品在线观看一区二区| 久久亚洲综合色| 亚洲成人7777| 国产成人在线影院| 色婷婷精品久久二区二区蜜臀av | 久久综合狠狠综合久久激情| 国产精品高潮久久久久无| 亚洲午夜国产一区99re久久| 国产综合色在线| 欧美日韩中文一区| 国产欧美日韩视频一区二区| 午夜精品在线看| 在线亚洲高清视频| 久久久www免费人成精品| 亚洲午夜日本在线观看| 成人免费观看视频| 国产午夜亚洲精品理论片色戒| 五月天国产精品| 欧美三级蜜桃2在线观看| 国产精品动漫网站| 国产精品一级片| 欧美成人精品1314www| 五月综合激情婷婷六月色窝| 在线观看视频91| 一区二区三区中文在线观看| 国产福利一区二区三区在线视频| 欧美日韩激情一区| 亚洲a一区二区| 99国产精品一区| 欧美大片一区二区| 美腿丝袜在线亚洲一区| 91.麻豆视频| 国产高清不卡一区| 一区在线中文字幕| 色婷婷激情综合| 日本亚洲电影天堂| 久久综合色之久久综合| 国产乱码字幕精品高清av| 精品国产91乱码一区二区三区| 日本不卡一二三区黄网| 久久毛片高清国产| 色婷婷精品久久二区二区蜜臀av| 亚洲成人黄色小说| 久久精品男人天堂av| 欧美丝袜丝nylons| 国产精品一区二区久久精品爱涩| 国产精品区一区二区三| 日韩视频在线观看一区二区| 日韩精品电影一区亚洲| 95精品视频在线| 麻豆91在线播放免费| 国产精品久久久久久妇女6080| 欧美视频日韩视频| 国产在线麻豆精品观看| 亚洲高清免费观看| 亚洲免费观看高清在线观看| 欧美va亚洲va香蕉在线| 欧美视频你懂的| 在线亚洲免费视频| 成人性生交大片免费看中文网站| 亚洲美女屁股眼交3| 国产日韩欧美综合一区| 日韩一区二区免费视频| 91麻豆精品国产自产在线观看一区| 色婷婷综合久久久久中文 | 国产三级三级三级精品8ⅰ区| 欧美影院一区二区三区| 日本韩国一区二区| 欧美性videosxxxxx| 91国偷自产一区二区三区成为亚洲经典 | 日韩一区二区三区av| 欧美一区二区三区视频免费| 欧美日韩一卡二卡| 欧美在线短视频| 日韩一卡二卡三卡国产欧美| 日韩一区二区影院| 久久九九99视频| ww久久中文字幕| 亚洲精品在线观| 亚洲一区二区三区四区在线免费观看| 一区二区三区在线视频观看| 日韩电影免费在线观看网站| 久草中文综合在线| 99r精品视频| 欧美mv和日韩mv的网站| 中文字幕精品一区二区精品绿巨人 | 中文乱码免费一区二区| 亚洲福利视频三区| 丁香婷婷综合色啪| 精品国产凹凸成av人导航| 亚洲欧洲精品天堂一级| 亚洲成人你懂的| 成人a免费在线看| 国产日韩欧美精品在线| 日本成人在线看| 欧美二区在线观看| 亚洲精品乱码久久久久久久久| 国产主播一区二区三区| 日韩欧美不卡在线观看视频| 亚洲国产欧美日韩另类综合| 91蜜桃视频在线| 自拍偷拍欧美激情| 色婷婷综合久久久| 亚洲一区二区欧美日韩| 色先锋久久av资源部| 亚洲综合精品自拍| 欧美亚州韩日在线看免费版国语版| 国产精品美女一区二区三区| 成人网男人的天堂| 综合av第一页| 欧美性猛片aaaaaaa做受| 热久久一区二区| 欧美精品一区二区三区一线天视频 | 婷婷国产v国产偷v亚洲高清| 中文成人av在线| 欧美成人国产一区二区| 欧美色大人视频| 韩国女主播成人在线| 中文字幕亚洲电影| 欧美成人猛片aaaaaaa| 欧美亚洲综合另类| 成人一二三区视频| 久久精品久久精品| 日韩国产欧美在线观看| 亚洲三级小视频|