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

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

?? dib.cpp

?? 合成4個代表K,C,M,Y通道的BMP位圖為打印數據
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
// Dib.cpp: implementation of the CDib class.
//
//////////////////////////////////////////////////////////////////////


#include "stdafx.h"
#include "Dib.h"
#include "math.h"

#ifdef _DEBUG
#undef THIS_FILE
static char THIS_FILE[]=__FILE__;
#define new DEBUG_NEW
#endif

//////////////////////////////////////////////////////////////////////
// Construction/Destruction
//////////////////////////////////////////////////////////////////////

	//	IMPLEMENT_DYNCREATE(CDib,CObject)
CDib::CDib()
{
	hdib=NULL;
	lps=NULL;
	dibwidth=0;
	dibheight=0;
	picturesize=0;

}
/////////////////////////////////////////////////////////////////////////////////////////

	
void CDib::LoadDIB(LPCTSTR lpfilename)
{
	HANDLE hfile;
	CString strs(lpfilename); 
	lps=lpfilename;  
	
	strc=strs;
	strc.Delete(strc.GetLength()-5);
	strc.Insert(strc.GetLength()-4,'c');
	//lpc=LPCTSTR(strc);


	strm=strs;
	strm.Delete(strm.GetLength()-5);
	strm.Insert(strm.GetLength()-4,'m');
	//lpm=LPCTSTR(strm);



	stry=strs;
	stry.Delete(stry.GetLength()-5);
	stry.Insert(stry.GetLength()-4,'y');
	//lpy=LPCTSTR(stry);



	strk=strs;
	strk.Delete(strk.GetLength()-5);
	strk.Insert(strk.GetLength()-4,'k');
	//lpk=LPCTSTR(strk);
		
	SetCursor(LoadCursor( NULL,IDC_WAIT ));  
		   
	if((hfile=CreateFile(lpfilename,GENERIC_READ,FILE_SHARE_READ,NULL,OPEN_EXISTING,FILE_ATTRIBUTE_NORMAL|FILE_FLAG_SEQUENTIAL_SCAN,NULL))!=INVALID_HANDLE_VALUE)
	{
		hdib=ReadDIBFile(hfile);
		CloseHandle(hfile);
		SetCursor(LoadCursor(NULL,IDC_ARROW));
		return ;
	}
	else 
	{
		SetCursor(LoadCursor(NULL,IDC_ARROW));
		return ;
	}
}
	

//-------------------------------------------------------------------------


HANDLE CDib::ReadDIBFile(HANDLE hfile)
{
	BITMAPFILEHEADER bmfheader;
	DWORD dwbytesize;//size by byte;
    UINT ncolornum;
	HANDLE hdib;
	HANDLE hdibtmp;//used for globalrealloc()
	LPBITMAPINFOHEADER lpbi;
	DWORD offbits;
	DWORD dwread;

	dwbytesize=GetFileSize(hfile,NULL);
	
	// allocate memory for bitmapinfoheader and color table;
	hdib=GlobalAlloc(GMEM_MOVEABLE,(DWORD)(sizeof(BITMAPINFOHEADER)+256*sizeof(RGBQUAD)));
	if(!hdib)
		return NULL;
	lpbi=(LPBITMAPINFOHEADER)GlobalLock(hdib);
	if(!lpbi)
	{
		GlobalFree(hdib);
		return NULL;
	}
	
	// read the bitmapfileheader from our file;
	if(!ReadFile(hfile,(LPBYTE)&bmfheader,sizeof(BITMAPFILEHEADER),&dwread,NULL))
		goto ErrExit;
	if(sizeof(BITMAPFILEHEADER)!=dwread)
		goto ErrExit;

	if(bmfheader.bfType!='MB')      // is 'MB' not 'BM';
	{
		AfxMessageBox("it is not dib",MB_OK,0);
		goto ErrExit;
	}
	
	// read the bitmapinfoheader from our file;
	if(!ReadFile(hfile,(LPBYTE)lpbi,sizeof(BITMAPINFOHEADER),&dwread,NULL))
		goto ErrExit;
	if(sizeof(BITMAPINFOHEADER)!=dwread)
		goto ErrExit;

	// check is windows DIB or os/2 DIB;
	if(lpbi->biSize==sizeof(BITMAPCOREHEADER))
		goto ErrExit;

	
	// determine the size of the color table and read it.
	if(!(ncolornum=(UINT)lpbi->biClrUsed))																												
	{	if(lpbi->biBitCount!=24)
			ncolornum=1<<lpbi->biBitCount;
	}
	// fill in some default values if they is zero;
	if(lpbi->biClrUsed==0)			//else biClrUsed is actually color number used;
		lpbi->biClrUsed=ncolornum;   

	if(lpbi->biSizeImage==0)
		lpbi->biSizeImage=((((lpbi->biWidth*(DWORD)lpbi->biBitCount+31)&~31)>>3)*lpbi->biHeight);
	

		// get a proper-sized buffer for header, color table and bits;
		GlobalUnlock(hdib);

	    hdibtmp=GlobalReAlloc(hdib,lpbi->biSize+ncolornum*sizeof(RGBQUAD)+lpbi->biSizeImage,
			            GMEM_MOVEABLE);   
		if(!hdibtmp)					
			goto ErrExitNoUnlock;
		
		else
			hdib=hdibtmp;

		lpbi=(LPBITMAPINFOHEADER)GlobalLock(hdib);
        
		
		
		// read color table;
		ReadFile(hfile,(LPBYTE)(lpbi)+lpbi->biSize,ncolornum*sizeof(RGBQUAD),&dwread,NULL);

		offbits=lpbi->biSize+ncolornum*sizeof(RGBQUAD);
		if(bmfheader.bfOffBits!=0L)
			SetFilePointer(hfile,bmfheader.bfOffBits,NULL,FILE_BEGIN);

		   if(ReadFile(hfile,(LPBYTE)lpbi+offbits,lpbi->biSizeImage,&dwread,NULL))
			goto OkExit;


ErrExit:
			GlobalUnlock(hdib);
ErrExitNoUnlock:
			GlobalFree(hdib);
			return NULL;
OkExit:
			GlobalUnlock(hdib);
			return	hdib;
}


//----------------------------------------------------------------

        // pointer to dib :bitmapinfoheader,color table, bit data;
HPALETTE CDib::CreateDIBPalette(LPBYTE lpbi)
{
	LPLOGPALETTE lppal;
	HANDLE hlogpal;
	HPALETTE hpal=NULL;
	LPBITMAPINFO lpbmi;
	LPBITMAPCOREINFO lpbmc;
	BOOL bwinstyledib;//is win3.0 dib;
	int i,wcolornum;


	if(!lpbi)
		return NULL;

	//get pointer to bitmapinfo(win 3.0)
	lpbmi=(LPBITMAPINFO)lpbi;


    //get point to bitmapcoreinfo(os/2);
	lpbmc=(LPBITMAPCOREINFO)lpbi;

    //get the colornumber in the DIB;
	wcolornum=DIBNumColors(lpbi);

   // whether this is a win 3.0 DIB;
   bwinstyledib=IS_WIN30_DIB(lpbi);

   if(wcolornum)
   {
	hlogpal=GlobalAlloc(GHND,sizeof(LOGPALETTE)+sizeof(PALETTEENTRY)*wcolornum);
	if(!hlogpal)
		return NULL;
	lppal=(LPLOGPALETTE)GlobalLock(hlogpal);

	lppal->palVersion=0x300;
	lppal->palNumEntries=wcolornum;

	for(i=0;i<wcolornum;i++)
	{
		if(bwinstyledib)
		{
			lppal->palPalEntry[i].peRed=lpbmi->bmiColors[i].rgbRed;
			lppal->palPalEntry[i].peGreen=lpbmi->bmiColors[i].rgbGreen;
			lppal->palPalEntry[i].peBlue=lpbmi->bmiColors[i].rgbBlue;
			lppal->palPalEntry[i].peFlags=0;
		}
		else
		{

			lppal->palPalEntry[i].peRed=lpbmc->bmciColors[i].rgbtRed;
			lppal->palPalEntry[i].peGreen=lpbmc->bmciColors[i].rgbtGreen;
			lppal->palPalEntry[i].peBlue=lpbmc->bmciColors[i].rgbtBlue;
			lppal->palPalEntry[i].peFlags=0;
		}
	}

		//create the palette and get handle to it;
		hpal=CreatePalette(lppal);

		if(!hpal)
		{
			GlobalUnlock(hlogpal);
			GlobalFree(hlogpal);
			return NULL;
		}

		// free memory block;
		GlobalUnlock(hlogpal);
		GlobalFree(hlogpal);
   }
   // return dib's palette
		return hpal;
}

//----------------------------------------------------------------
 // get color number from the dib's color table
  // lpdib: pointer to packed-dib memory block

WORD CDib::DIBNumColors(LPBYTE lpdib)
	{
		WORD wbitcount=((LPBITMAPINFOHEADER)lpdib)->biBitCount ;

		if(IS_WIN30_DIB(lpdib))
		{
			DWORD dwclrused;
			dwclrused=((LPBITMAPINFOHEADER)lpdib)->biClrUsed;
			if(dwclrused)
				return (WORD)dwclrused;
		     else 
				 return 1<<((LPBITMAPINFOHEADER)lpdib)->biBitCount;              //OR: (WORD)pow(2,((LPBITMAPINFOHEADER)lpdib)->biBitCount);
		}
		else
			return (WORD)pow(2,((LPBITMAPCOREHEADER)lpdib)->bcBitCount);
	}

  
//-----------------------------------------------------------------
   //    copy a rect of a dib to destinate rect; 	
	// hdib: bitmapinfo+imagebits

bool CDib::PaintDIB(HDC hdc, LPRECT lpdcrect,HPALETTE hpal)
{
	LPBYTE lpdibih;        // pointer to BITMAPINFOHEADER;
	LPBYTE lpdibits;       // pointer to DIB image bits;
//	LPBITMAPINFOHEADER lp;
	bool bsuccess;
	HPALETTE holdpal=NULL;

	if(!hdib)
		return NULL;

	lpdibih=(LPBYTE)GlobalLock(hdib);
	lpdibits=lpdibih+sizeof(BITMAPINFOHEADER)+DIBNumColors(lpdibih)*sizeof(RGBQUAD);
		
	// if not palette provided,create one from DIB;
	if(!hpal)
		hpal=CreateDIBPalette(lpdibih);

	if(hpal)
	{
		holdpal=SelectPalette(hdc,hpal,true);
		RealizePalette(hdc);
	}

	// make sure to use the stretching mode for color picture;
	SetStretchBltMode(hdc,COLORONCOLOR);

   if(StretchDIBits(hdc,lpdcrect->left,lpdcrect->top,RECTWIDTH(lpdcrect),RECTHEIGHT(lpdcrect),
	       0,0,((LPBITMAPINFOHEADER)lpdibih)->biWidth,((LPBITMAPINFOHEADER)lpdibih)->biHeight,
	        lpdibits,(LPBITMAPINFO)lpdibih,DIB_RGB_COLORS,SRCCOPY))
		bsuccess=true;


	GlobalUnlock(hdib);

	if(holdpal)
		SelectPalette(hdc,holdpal,false);
	GlobalUnlock(hdib);

	return bsuccess;
}



//--------------------------------------------------------------------------------------------------------

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产一区二区三区免费看| 色综合久久中文字幕综合网| 国产乱码精品一品二品| 色综合天天天天做夜夜夜夜做| 制服丝袜亚洲网站| 国产精品国产三级国产有无不卡| 亚洲国产精品一区二区久久 | 精品伊人久久久久7777人| 成人免费毛片片v| 日韩欧美精品在线| 亚洲成人免费观看| 99久久精品国产网站| 久久久久久毛片| 免费在线观看精品| 精品视频一区 二区 三区| 国产精品丝袜在线| 国产精品综合视频| 日韩精品中文字幕一区二区三区| 亚洲福利电影网| 99精品久久免费看蜜臀剧情介绍| 久久精品一区四区| 国产一区二三区| 精品国产乱码久久久久久蜜臀| 婷婷国产在线综合| 欧美日韩电影一区| 午夜精品福利一区二区蜜股av | 国产精品乱人伦| 国产福利精品导航| 久久久久青草大香线综合精品| 免费视频一区二区| 欧美一区二区三区视频| 午夜成人免费电影| 欧美一区二区视频在线观看| 天天色 色综合| 69av一区二区三区| 另类综合日韩欧美亚洲| 91麻豆精品国产91久久久使用方法 | 欧美精品第1页| 三级亚洲高清视频| 日韩手机在线导航| 久久99精品久久久久久久久久久久| 日韩免费一区二区三区在线播放| 美日韩一级片在线观看| 日韩精品专区在线影院重磅| 日韩制服丝袜av| 欧美不卡在线视频| 国产黄色成人av| 亚洲欧美色图小说| 欧美中文字幕一二三区视频| 日韩中文字幕av电影| 欧美成人精品高清在线播放| 国产精品一二三区在线| 国产精品电影一区二区| 在线免费观看一区| 秋霞国产午夜精品免费视频| 久久久国产精品不卡| 成人av在线影院| 亚洲va国产天堂va久久en| 日韩三级在线免费观看| 丁香啪啪综合成人亚洲小说| 亚洲另类在线制服丝袜| 欧美一卡二卡三卡四卡| 国产激情一区二区三区四区| 亚洲美女在线一区| 91精品国产综合久久婷婷香蕉 | 精品少妇一区二区三区免费观看| 国产成人午夜99999| 一区二区三区美女视频| 日韩欧美电影在线| 色婷婷国产精品| 黄色成人免费在线| 一区二区三区在线视频免费 | 爽好久久久欧美精品| 精品久久久久久无| 一本到不卡精品视频在线观看| 日日摸夜夜添夜夜添精品视频| 国产三级一区二区三区| 欧美日韩精品免费观看视频 | 色综合天天性综合| 另类人妖一区二区av| 亚洲三级电影全部在线观看高清| 91精品国产美女浴室洗澡无遮挡| 99久久久无码国产精品| 日本不卡1234视频| 一卡二卡欧美日韩| 国产欧美久久久精品影院| 欧美色成人综合| eeuss国产一区二区三区| 极品少妇xxxx精品少妇| 亚洲国产精品视频| 亚洲丝袜美腿综合| 亚洲国产高清在线观看视频| 4438x成人网最大色成网站| 91免费观看视频| 国产精品一线二线三线精华| 奇米影视7777精品一区二区| 亚洲国产欧美在线人成| **欧美大码日韩| 国产精品日日摸夜夜摸av| 久久综合一区二区| 精品日韩欧美在线| 欧美一区二区三区四区久久| 欧美日韩在线精品一区二区三区激情 | 日韩一区二区三区免费观看| 99国产精品国产精品毛片| 国产99精品视频| 国产福利精品一区| 粉嫩aⅴ一区二区三区四区| 国产一区二区三区在线观看免费视频 | www国产亚洲精品久久麻豆| 91精品久久久久久久99蜜桃 | 首页国产欧美久久| 亚洲精品国产精华液| 亚洲老司机在线| 国产精品国产成人国产三级| 欧美高清在线一区| 国产精品美女www爽爽爽| 中文字幕欧美日韩一区| 国产精品网站在线观看| 国产色爱av资源综合区| 国产精品美女久久久久久久久 | 懂色av中文字幕一区二区三区| 韩国成人精品a∨在线观看| 韩国v欧美v日本v亚洲v| 国产精品自产自拍| 成人自拍视频在线观看| 99久久婷婷国产综合精品电影| 不卡电影一区二区三区| 91首页免费视频| 在线观看日产精品| 欧美日韩国产一级片| 欧美一级黄色片| 精品国产欧美一区二区| 国产精品视频一二三区| 亚洲伦在线观看| 亚洲成人激情综合网| 麻豆一区二区三| 国产91精品露脸国语对白| 91丨九色丨蝌蚪富婆spa| 欧美日韩精品专区| 久久久五月婷婷| 日韩美女啊v在线免费观看| 夜夜操天天操亚洲| 美女尤物国产一区| 粉嫩蜜臀av国产精品网站| 99久久99精品久久久久久 | 成人的网站免费观看| 91久久免费观看| 欧美成人精品二区三区99精品| 国产日韩精品一区二区浪潮av| 亚洲人成在线播放网站岛国| 日韩福利电影在线| 成人动漫一区二区| 91精品国产综合久久久久久久| 久久久综合网站| 亚洲午夜视频在线| 国产精品小仙女| 欧美另类videos死尸| 国产午夜精品久久久久久久| 亚洲自拍都市欧美小说| 激情综合色综合久久综合| www.成人网.com| 精品久久久久久久久久久久久久久 | 欧美在线观看一区| xvideos.蜜桃一区二区| 亚洲综合一区二区三区| 国产精品一二三四| 制服丝袜中文字幕一区| 综合网在线视频| 国产精品88888| 欧美精品在线观看播放| 亚洲特黄一级片| 国产精品一区二区三区四区| 欧美午夜片在线观看| 中文字幕一区二区三区不卡| 丝袜诱惑亚洲看片| 在线精品视频一区二区| 国产欧美日韩视频一区二区| 蜜桃av一区二区三区电影| 欧美三级电影在线看| 国产精品成人网| 国产精品一二三区在线| 欧美电影免费观看高清完整版在| 亚洲一区二区黄色| 色综合久久88色综合天天| 国产精品国产三级国产普通话蜜臀 | 精品一区二区三区免费播放| 91久久一区二区| 亚洲色图视频网| 暴力调教一区二区三区| 国产亚洲精品aa午夜观看| 久久国产乱子精品免费女| 欧美性做爰猛烈叫床潮| 亚洲精品福利视频网站| 成人av高清在线| 国产精品人人做人人爽人人添 | 理论电影国产精品| 欧美一级专区免费大片| 男男gaygay亚洲| 日韩视频不卡中文|