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

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

?? tiff2dib.c

?? tiff格式傳真源碼例子
?? C
字號:
/************************************************************************* * * Source file for Windows 95/Win32.  * * The function LoadTIFFinDIB in this source file let you load  * a TIFF file and build a memory DIB with it and return the  * HANDLE (HDIB) of the memory bloc containing the DIB. * *  Example :  *  *   HDIB   hDIB; *   hDIB = LoadTIFFinDIB("sample.tif"); * * * To build this source file you must include the TIFF library    * in your project. * * 4/12/95   Philippe Tenenhaus   100423.3705@compuserve.com * ************************************************************************/#include "tiffio.h" #define HDIB HANDLE#define IS_WIN30_DIB(lpbi)  ((*(LPDWORD)(lpbi)) == sizeof(BITMAPINFOHEADER))#define CVT(x)      (((x) * 255L) / ((1L<<16)-1))static HDIB CreateDIB(DWORD dwWidth, DWORD dwHeight, WORD wBitCount);static LPSTR FindDIBBits(LPSTR lpDIB);static WORD PaletteSize(LPSTR lpDIB);static WORD DIBNumColors(LPSTR lpDIB);static int checkcmap(int n, uint16* r, uint16* g, uint16* b);/************************************************************************* * * HDIB LoadTIFFinDIB(LPSTR lpFileName)  * * Parameter: * * LPSTR lpDIB      - File name of a tiff imag * * Return Value: * * LPSTR            - HANDLE of a DIB * * Description: * * This function load a TIFF file and build a memory DIB with it * and return the HANDLE (HDIB) of the memory bloc containing * the DIB. * * 4/12/95   Philippe Tenenhaus   100423.3705@compuserve.com * ************************************************************************/HDIB LoadTIFFinDIB(LPSTR lpFileName)    {    TIFF          *tif;    unsigned long imageLength;     unsigned long imageWidth;     unsigned int  BitsPerSample;    unsigned long LineSize;    unsigned int  SamplePerPixel;    unsigned long RowsPerStrip;      int           PhotometricInterpretation;    long          nrow;	unsigned long row;    char          *buf;              LPBITMAPINFOHEADER lpDIB;     HDIB          hDIB;    char          *lpBits;    HGLOBAL       hStrip;    int           i,l;    int           Align;         tif = TIFFOpen(lpFileName, "r");        if (!tif)        goto TiffOpenError;        TIFFGetField(tif, TIFFTAG_IMAGEWIDTH, &imageWidth);    TIFFGetField(tif, TIFFTAG_IMAGELENGTH, &imageLength);      TIFFGetField(tif, TIFFTAG_BITSPERSAMPLE, &BitsPerSample);    TIFFGetField(tif, TIFFTAG_ROWSPERSTRIP, &RowsPerStrip);      TIFFGetField(tif, TIFFTAG_ROWSPERSTRIP, &RowsPerStrip);       TIFFGetField(tif, TIFFTAG_PHOTOMETRIC, &PhotometricInterpretation);               LineSize = TIFFScanlineSize(tif); //Number of byte in ine line    SamplePerPixel = (int) (LineSize/imageWidth);    //Align = Number of byte to add at the end of each line of the DIB    Align = 4 - (LineSize % 4);    if (Align == 4)	Align = 0;        //Create a new DIB    hDIB = CreateDIB((DWORD) imageWidth, (DWORD) imageLength, (WORD)(BitsPerSample*SamplePerPixel));    lpDIB  = (LPBITMAPINFOHEADER) GlobalLock(hDIB);    if (!lpDIB)          goto OutOfDIBMemory;              if (lpDIB)       lpBits = FindDIBBits((LPSTR) lpDIB);    //In the tiff file the lines are save from up to down 	//In a DIB the lines must be save from down to up    if (lpBits)      {        lpBits = FindDIBBits((LPSTR) lpDIB);        lpBits+=((imageWidth*SamplePerPixel)+Align)*(imageLength-1);		//now lpBits pointe on the bottom line                hStrip = GlobalAlloc(GHND,TIFFStripSize(tif));        buf = GlobalLock(hStrip);                           if (!buf)           goto OutOfBufMemory;                //PhotometricInterpretation = 2 image is RGB        //PhotometricInterpretation = 3 image have a color palette                      if (PhotometricInterpretation == 3)        {          uint16* red;          uint16* green;          uint16* blue;          int16 i;          LPBITMAPINFO lpbmi;             int   Palette16Bits;                               TIFFGetField(tif, TIFFTAG_COLORMAP, &red, &green, &blue); 		  //Is the palette 16 or 8 bits ?          if (checkcmap(1<<BitsPerSample, red, green, blue) == 16)              Palette16Bits = TRUE;          else             Palette16Bits = FALSE;                       lpbmi = (LPBITMAPINFO)lpDIB;                                                //load the palette in the DIB          for (i = (1<<BitsPerSample)-1; i >= 0; i--)             {                          if (Palette16Bits)                {                  lpbmi->bmiColors[i].rgbRed =(BYTE) CVT(red[i]);                  lpbmi->bmiColors[i].rgbGreen = (BYTE) CVT(green[i]);                  lpbmi->bmiColors[i].rgbBlue = (BYTE) CVT(blue[i]);                           }             else                {                  lpbmi->bmiColors[i].rgbRed = (BYTE) red[i];                  lpbmi->bmiColors[i].rgbGreen = (BYTE) green[i];                  lpbmi->bmiColors[i].rgbBlue = (BYTE) blue[i];                        }            }                           }                //read the tiff lines and save them in the DIB		//with RGB mode, we have to change the order of the 3 samples RGB<=> BGR        for (row = 0; row < imageLength; row += RowsPerStrip)           {                 nrow = (row + RowsPerStrip > imageLength ? imageLength - row :RowsPerStrip);            if (TIFFReadEncodedStrip(tif, TIFFComputeStrip(tif, row, 0),                buf, nrow*LineSize)==-1)                  {                     goto TiffReadError;                  }             else                  {                      for (l = 0; l < nrow; l++)                       {                         if (SamplePerPixel  == 3)                           for (i=0;i< (int) (imageWidth);i++)                              {                               lpBits[i*SamplePerPixel+0]=buf[l*LineSize+i*SamplePerPixel+2];                                lpBits[i*SamplePerPixel+1]=buf[l*LineSize+i*SamplePerPixel+1];                               lpBits[i*SamplePerPixel+2]=buf[l*LineSize+i*SamplePerPixel+0];                              }                         else                           memcpy(lpBits, &buf[(int) (l*LineSize)], (int)imageWidth*SamplePerPixel);                                                    lpBits-=imageWidth*SamplePerPixel+Align;                      }                 }          }        GlobalUnlock(hStrip);        GlobalFree(hStrip);        GlobalUnlock(hDIB);         TIFFClose(tif);      }          return hDIB;        OutOfBufMemory:           TiffReadError:       GlobalUnlock(hDIB);        GlobalFree(hStrip);    OutOfDIBMemory:       TIFFClose(tif);    TiffOpenError:       return (HANDLE) 0;                }static int checkcmap(int n, uint16* r, uint16* g, uint16* b){    while (n-- > 0)        if (*r++ >= 256 || *g++ >= 256 || *b++ >= 256)        return (16);        return (8);}/************************************************************************* * All the following functions were created by microsoft, they are * parts of the sample project "wincap" given with the SDK Win32. * * Microsoft says that : * *  You have a royalty-free right to use, modify, reproduce and *  distribute the Sample Files (and/or any modified version) in *  any way you find useful, provided that you agree that *  Microsoft has no warranty obligations or liability for any *  Sample Application Files which are modified. * ************************************************************************/HDIB CreateDIB(DWORD dwWidth, DWORD dwHeight, WORD wBitCount){   BITMAPINFOHEADER bi;         // bitmap header   LPBITMAPINFOHEADER lpbi;     // pointer to BITMAPINFOHEADER   DWORD dwLen;                 // size of memory block   HDIB hDIB;   DWORD dwBytesPerLine;        // Number of bytes per scanline   // Make sure bits per pixel is valid   if (wBitCount <= 1)      wBitCount = 1;   else if (wBitCount <= 4)      wBitCount = 4;   else if (wBitCount <= 8)      wBitCount = 8;   else if (wBitCount <= 24)      wBitCount = 24;   else      wBitCount = 4;  // set default value to 4 if parameter is bogus   // initialize BITMAPINFOHEADER   bi.biSize = sizeof(BITMAPINFOHEADER);   bi.biWidth = dwWidth;         // fill in width from parameter   bi.biHeight = dwHeight;       // fill in height from parameter   bi.biPlanes = 1;              // must be 1   bi.biBitCount = wBitCount;    // from parameter   bi.biCompression = BI_RGB;       bi.biSizeImage = (dwWidth*dwHeight*wBitCount)/8; //0;           // 0's heremean "default"   bi.biXPelsPerMeter = 2834; //0;   bi.biYPelsPerMeter = 2834; //0;   bi.biClrUsed = 0;   bi.biClrImportant = 0;   // calculate size of memory block required to store the DIB.  This   // block should be big enough to hold the BITMAPINFOHEADER, the color   // table, and the bits   dwBytesPerLine =   (((wBitCount * dwWidth) + 31) / 32 * 4);   dwLen = bi.biSize + PaletteSize((LPSTR)&bi) + (dwBytesPerLine * dwHeight);   // alloc memory block to store our bitmap   hDIB = GlobalAlloc(GHND, dwLen);   // major bummer if we couldn't get memory block   if (!hDIB)   {      return NULL;   }   // lock memory and get pointer to it   lpbi = (VOID FAR *)GlobalLock(hDIB);   // use our bitmap info structure to fill in first part of   // our DIB with the BITMAPINFOHEADER   *lpbi = bi;   // Since we don't know what the colortable and bits should contain,   // just leave these blank.  Unlock the DIB and return the HDIB.   GlobalUnlock(hDIB);   /* return handle to the DIB */   return hDIB;}LPSTR FAR FindDIBBits(LPSTR lpDIB){   return (lpDIB + *(LPDWORD)lpDIB + PaletteSize(lpDIB));}WORD FAR PaletteSize(LPSTR lpDIB){   /* calculate the size required by the palette */   if (IS_WIN30_DIB (lpDIB))      return (DIBNumColors(lpDIB) * sizeof(RGBQUAD));   else      return (DIBNumColors(lpDIB) * sizeof(RGBTRIPLE));}WORD DIBNumColors(LPSTR lpDIB){   WORD wBitCount;  // DIB bit count   /*  If this is a Windows-style DIB, the number of colors in the    *  color table can be less than the number of bits per pixel    *  allows for (i.e. lpbi->biClrUsed can be set to some value).    *  If this is the case, return the appropriate value.    */   if (IS_WIN30_DIB(lpDIB))   {      DWORD dwClrUsed;      dwClrUsed = ((LPBITMAPINFOHEADER)lpDIB)->biClrUsed;      if (dwClrUsed)     return (WORD)dwClrUsed;   }   /*  Calculate the number of colors in the color table based on    *  the number of bits per pixel for the DIB.    */   if (IS_WIN30_DIB(lpDIB))      wBitCount = ((LPBITMAPINFOHEADER)lpDIB)->biBitCount;   else      wBitCount = ((LPBITMAPCOREHEADER)lpDIB)->bcBitCount;   /* return number of colors based on bits per pixel */   switch (wBitCount)      {   case 1:      return 2;   case 4:      return 16;   case 8:      return 256;   default:      return 0;      }}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲色图欧洲色图婷婷| 欧美视频精品在线观看| 精品国产乱码久久久久久浪潮 | 亚洲v精品v日韩v欧美v专区| av电影天堂一区二区在线观看| 国产精品狼人久久影院观看方式| 不卡的看片网站| 亚洲一区免费在线观看| 欧美嫩在线观看| 国产麻豆9l精品三级站| 亚洲国产高清aⅴ视频| 97精品国产露脸对白| 亚洲电影一区二区| 精品久久久网站| 99视频在线精品| 日日夜夜免费精品| 久久久亚洲国产美女国产盗摄| jizz一区二区| 午夜欧美电影在线观看| 日韩一区二区三区电影在线观看| 国产成人av福利| 亚洲综合视频在线| 精品99一区二区| 一本久久综合亚洲鲁鲁五月天 | 色综合 综合色| 蜜臀av一区二区在线观看| 亚洲国产高清不卡| 欧美精选午夜久久久乱码6080| 久草热8精品视频在线观看| 中文字幕在线播放不卡一区| 欧美性高清videossexo| 韩国欧美一区二区| 一级中文字幕一区二区| 日韩视频在线一区二区| 色综合久久久久综合体| 国产一区二区三区av电影| 亚洲国产视频直播| 国产精品女人毛片| 欧美videossexotv100| av一本久道久久综合久久鬼色| 免费看精品久久片| 一区二区三区精密机械公司| 久久久精品国产免费观看同学| 欧美在线一区二区三区| 丁香激情综合五月| 精品一区二区三区视频 | 国产成人99久久亚洲综合精品| 日韩欧美的一区| 精品一区二区免费看| 欧美日韩在线三区| 日韩av不卡一区二区| 亚洲色图.com| 国产精品午夜电影| 久久久久久日产精品| 欧美成人官网二区| 日韩三级高清在线| 亚洲丝袜自拍清纯另类| 69成人精品免费视频| 69堂成人精品免费视频| 精品国精品自拍自在线| 欧美国产精品专区| 国产精品久久久久久户外露出| 一区二区三区中文在线观看| 亚洲bt欧美bt精品| 麻豆精品一二三| 成人免费av网站| 欧美性受极品xxxx喷水| 欧美成人精品3d动漫h| 国产网站一区二区| 亚洲欧美色一区| 蜜桃久久久久久久| 成人爱爱电影网址| 欧美日韩国产免费| 国产日产欧美一区| 亚洲国产成人tv| 国产美女精品在线| 91国产成人在线| 久久综合九色综合97婷婷女人| 中文字幕一区视频| 日本不卡在线视频| 99精品欧美一区二区三区小说| 欧美日韩精品三区| 日本一区二区三级电影在线观看| 一级做a爱片久久| 国产一区二区三区黄视频| 91年精品国产| 久久综合中文字幕| 亚洲已满18点击进入久久| 激情成人综合网| 欧美中文字幕一二三区视频| 久久久久久久综合日本| 亚洲午夜在线电影| 成人性生交大片| 精品日本一线二线三线不卡 | 亚洲欧洲美洲综合色网| 免费观看成人鲁鲁鲁鲁鲁视频| 99久久久国产精品| 日韩美女一区二区三区| 一区2区3区在线看| 成人动漫在线一区| 精品国产91久久久久久久妲己| 亚洲一区中文日韩| 9人人澡人人爽人人精品| 日韩女优电影在线观看| 亚洲一区二区三区视频在线播放| 国产福利精品导航| 日韩一区二区在线免费观看| 又紧又大又爽精品一区二区| 丁香五精品蜜臀久久久久99网站| 日韩亚洲欧美成人一区| 亚洲一区二区免费视频| 97超碰欧美中文字幕| 国产午夜精品福利| 韩国av一区二区三区四区| 337p亚洲精品色噜噜狠狠| 艳妇臀荡乳欲伦亚洲一区| www.日韩大片| 日本一区二区成人在线| 国产乱码字幕精品高清av| 91精品国产综合久久久久久久久久 | 国产精品888| 欧美成人高清电影在线| 五月婷婷久久综合| 欧美日韩在线播放一区| 亚洲一级二级在线| 欧美无砖专区一中文字| 亚洲精品国久久99热| 99这里只有精品| 亚洲图片激情小说| 97精品国产露脸对白| 最新国产成人在线观看| 99riav一区二区三区| 最新成人av在线| 91原创在线视频| 亚洲欧美日韩中文字幕一区二区三区 | 国产激情一区二区三区四区| 欧美电影免费观看高清完整版在| 青青草国产成人av片免费 | 亚洲国产成人午夜在线一区| 黑人巨大精品欧美黑白配亚洲| 欧美精品一区二区久久婷婷| 激情综合色丁香一区二区| 精品成人一区二区三区四区| 国产美女精品一区二区三区| 久久久精品人体av艺术| 成人综合婷婷国产精品久久| 国产精品久久午夜| 99re成人精品视频| 一区二区三区在线免费观看 | 日韩一级二级三级| 激情综合亚洲精品| 国产亚洲一二三区| 成人aa视频在线观看| 中文字幕亚洲欧美在线不卡| 色偷偷成人一区二区三区91| 亚洲综合色丁香婷婷六月图片| 欧美美女激情18p| 精品一区二区三区影院在线午夜| 久久久激情视频| 色婷婷一区二区三区四区| 亚洲成人精品一区| 精品国产乱码久久久久久闺蜜| 粉嫩一区二区三区性色av| 亚洲欧美日韩综合aⅴ视频| 欧美电影在线免费观看| 九九国产精品视频| 中文字幕亚洲精品在线观看| 欧美日本乱大交xxxxx| 国内成人免费视频| 亚洲日本韩国一区| 欧美一级日韩一级| 国产成人精品综合在线观看 | 日韩女优毛片在线| 成人国产在线观看| 亚洲成av人片一区二区三区| 精品久久久久久久人人人人传媒| 成人免费毛片aaaaa**| 亚洲高清不卡在线观看| 精品99一区二区三区| 91福利国产成人精品照片| 美国十次综合导航| 亚洲精选一二三| 精品欧美乱码久久久久久1区2区 | 91.com视频| 大尺度一区二区| 日韩精品成人一区二区在线| 国产天堂亚洲国产碰碰| 欧美网站大全在线观看| 国产精品538一区二区在线| 亚洲一二三四区不卡| 亚洲国产高清在线观看视频| 51精品视频一区二区三区| www.色综合.com| 国产伦理精品不卡| 午夜精品福利在线| 国产精品久久久久久久久免费樱桃| 4438亚洲最大| 欧美在线观看一区| 成人性生交大片免费看视频在线 | 亚洲色图视频网站|