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

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

?? dib.cpp

?? matlab source code very useful to science study
?? CPP
字號:
// Dib.cpp: implementation of the CDib class.
//
//////////////////////////////////////////////////////////////////////

#include "StdAfx.h"
#include "Dib.h"

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

//////////////////////////////////////////////////////////////////////
// C
//////////////////////////////////////////////////////////////////////
//構造與析構函數
CDib::CDib()
{
	m_hDrawDib=NULL;
	m_pDib=NULL;
}

CDib::~CDib()
{
	Close();
}
//在設備環境上繪制圖象
void CDib::Draw(CDC *pDC,int nWidth, int nHeight)
{
	if(m_pDib!=NULL)
	{
	ASSERT(IsValid());
	DrawDibRealize(m_hDrawDib,pDC->GetSafeHdc(),TRUE);
	//采用VFW組件繪圖
	DrawDibDraw(m_hDrawDib,pDC->GetSafeHdc(),
				0,  
				0,  
				nWidth,
				nHeight,
				(BITMAPINFOHEADER *)m_pDib,
				(LPVOID) GetBits(),
				0,  
				0,  
				((BITMAPINFOHEADER *)m_pDib)->biWidth,
				((BITMAPINFOHEADER *)m_pDib)->biHeight,
				DDF_BACKGROUNDPAL);
	}
}
//獲得位圖的CSize結構
CSize CDib::GetSize()
{
	return CSize(((BITMAPINFOHEADER *)m_pDib)->biWidth,
				 ((BITMAPINFOHEADER *)m_pDib)->biHeight);	
}
//獲得位圖的寬度
DWORD CDib::GetWidth()
{
	return ((BITMAPINFOHEADER *)m_pDib)->biWidth;
}
//獲得位圖每行的字節數
DWORD CDib::GetWidthBytes()
{
BITMAPINFOHEADER *lpDib=(BITMAPINFOHEADER *)m_pDib;
WORD wBitCount=lpDib->biBitCount;
WORD wWidth=lpDib->biWidth;
//WidthBytes=(((biWidth*biBitCount)+31)&~31)>>3
DWORD bytes_per_line=(((wWidth*wBitCount)+31)&~31)>>3;
return bytes_per_line;
}
//獲得位圖的高度
DWORD CDib::GetHeight()
{
	return	((BITMAPINFOHEADER *)m_pDib)->biHeight;
}
//釋放位圖資源
void CDib::Close()
{
	if(m_hDrawDib!=NULL)
	{
		DrawDibClose(m_hDrawDib);
		m_hDrawDib=NULL;
	}

	if(m_pDib!=NULL)
	{
		delete m_pDib;
		m_pDib=NULL;
		m_pDibBits=NULL;
	}
}
//將位圖文件中的位圖讀入內存中
BOOL CDib::Open(const char * pzFileName)
{
	CFile file;
	int nBmpFileHeaderSize;
	Close(); 
	//初始化DrawDib函數組
	if(!(m_hDrawDib=DrawDibOpen()))
		goto exit;

 	//打開位圖文件并讀取位圖的BITMAPFILEHEADER數據
	nBmpFileHeaderSize=sizeof(BITMAPFILEHEADER);

	if(!file.Open(pzFileName,CFile::modeRead | CFile::typeBinary))
		goto exit;

	if(file.Read((void *)&bmpFileHeader,nBmpFileHeaderSize)!=(UINT)nBmpFileHeaderSize)
		goto failure;

	//判斷位圖文件的有效性
	if(bmpFileHeader.bfType!=*((WORD *)"BM"))
		goto failure;

	//為位圖數據分配空間
	m_pDib=(BYTE *)new char [bmpFileHeader.bfSize-nBmpFileHeaderSize];

	if(!m_pDib)
		goto failure;

	//將位圖數據讀入到內存中
	file.ReadHuge(m_pDib,bmpFileHeader.bfSize-nBmpFileHeaderSize);

	if(((BITMAPINFOHEADER *)m_pDib)->biSizeImage==0)
	{
		
		BITMAPINFOHEADER *pDib=(BITMAPINFOHEADER *)m_pDib;

	//scan lines must be DWord aligned, hence the strange bit stuff
	pDib->biSizeImage=((((pDib->biWidth*pDib->biBitCount)+31)&~31)>>3)*pDib->biHeight;
	}

	m_pDibBits=GetBits();

	file.Close();
	return TRUE;

failure:
	file.Close();
exit:
	Close();
	return FALSE;
}
//保存位圖
BOOL CDib::Save(const char * pzFileName)
{

	CFile file;
	int nBmpFileHeaderSize;

	nBmpFileHeaderSize=sizeof(BITMAPFILEHEADER);

	if(!file.Open(pzFileName,CFile::modeCreate | CFile::modeWrite | CFile::typeBinary))
		goto exit;
     //將文件頭信息寫入
	file.Write(&bmpFileHeader,nBmpFileHeaderSize); 
	if(!m_pDib)
		goto failure;

	//將文件其它信息寫入
	file.WriteHuge(m_pDib,bmpFileHeader.bfSize-nBmpFileHeaderSize);

	file.Close();
	return TRUE;

failure:
	file.Close();
exit:
	return FALSE;
}
//獲得位圖數據的指針
BYTE * CDib::GetBits()
{
	
	DWORD dwNumColors,dwColorTableSize;
	BITMAPINFOHEADER *lpDib=(BITMAPINFOHEADER *)m_pDib;
	//獲取顏色數
	WORD wBitCount=lpDib->biBitCount;
	if(lpDib->biSize>=36)
		dwNumColors=lpDib->biClrUsed;
	else
		dwNumColors=0;
	if(dwNumColors==0)
	{    
		if(wBitCount!=24)
			dwNumColors=1L<<wBitCount;
		else 
			dwNumColors=0;
	}

	dwColorTableSize=dwNumColors*sizeof(RGBQUAD);

	return m_pDib+lpDib->biSize+dwColorTableSize;
}

DWORD CDib::GetBiBitCount()
{
	if(m_pDib!=NULL)
		return ((BITMAPINFOHEADER *)m_pDib)->biBitCount; 
	return 0;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产麻豆一精品一av一免费| av不卡免费电影| 日韩欧美国产高清| 日韩高清在线不卡| 91精品国产综合久久精品| 亚洲高清免费观看高清完整版在线观看| 91麻豆国产香蕉久久精品| 中文字幕一区二区三区色视频| 成人av在线资源网站| 国产精品免费视频网站| 波多野结衣亚洲一区| 国产精品色呦呦| 91丨九色丨蝌蚪丨老版| 亚洲人成电影网站色mp4| 色综合久久88色综合天天6 | 色婷婷av一区二区三区gif| 中文字幕亚洲欧美在线不卡| jlzzjlzz亚洲日本少妇| 亚洲三级在线免费观看| 91在线porny国产在线看| 综合在线观看色| 欧美系列一区二区| 午夜激情综合网| 日韩三级免费观看| 国内精品久久久久影院薰衣草| 精品国产乱码久久久久久蜜臀| 国产精品一区二区不卡| 亚洲国产成人在线| 91丝袜美腿高跟国产极品老师 | 欧美三级资源在线| 天堂久久一区二区三区| 日韩精品一区二区三区中文精品| 国产酒店精品激情| 国产精品久久久久久久久动漫 | 欧美激情一区三区| 91同城在线观看| 亚洲图片自拍偷拍| 日韩免费一区二区| 粉嫩aⅴ一区二区三区四区 | 一区二区三区欧美亚洲| 欧美精品日韩综合在线| 国产又黄又大久久| 亚洲欧美成aⅴ人在线观看| 欧美理论片在线| 国产一区二区三区不卡在线观看| 中文字幕乱码久久午夜不卡| 在线免费精品视频| 蜜桃久久久久久久| 中文字幕永久在线不卡| 欧美唯美清纯偷拍| 国产综合久久久久久久久久久久| 国产精品色呦呦| 欧美日韩精品三区| 国产麻豆成人传媒免费观看| 亚洲人成精品久久久久| 日韩三级视频在线观看| 99免费精品视频| 日韩黄色小视频| 中文字幕免费不卡| 在线观看91精品国产麻豆| 国模一区二区三区白浆| 亚洲少妇30p| 精品久久免费看| 一本一本久久a久久精品综合麻豆| 欧美a一区二区| 中文字幕一区日韩精品欧美| 欧美日韩精品一区二区在线播放| 国产一区二区h| 午夜久久久影院| 国产精品天干天干在线综合| 欧美日韩精品一区视频| 成人午夜免费av| 亚洲成人第一页| 中文字幕va一区二区三区| 欧美精品日韩一本| 成人自拍视频在线| 亚洲一区二区欧美| 欧美国产日韩精品免费观看| 91超碰这里只有精品国产| 成人sese在线| 精品午夜一区二区三区在线观看| 亚洲欧美另类久久久精品| 精品成人佐山爱一区二区| 欧美在线高清视频| 成人国产精品免费网站| 久久99国产精品麻豆| 一区二区三区精品在线| 国产日韩精品一区二区三区 | 中文字幕中文字幕一区二区| 日韩一本二本av| 欧美性色综合网| 成人免费观看视频| 激情六月婷婷综合| 三级亚洲高清视频| 亚洲精品视频自拍| 国产精品嫩草影院av蜜臀| 精品国产乱码91久久久久久网站| 欧美色倩网站大全免费| 99精品国产视频| 丁香天五香天堂综合| 精品一区二区影视| 日韩激情视频在线观看| 亚洲一卡二卡三卡四卡| 最好看的中文字幕久久| 亚洲国产精品成人综合| 久久久久久久久久看片| 日韩亚洲国产中文字幕欧美| 欧美日韩国产小视频在线观看| 91亚洲国产成人精品一区二三| 国产综合色视频| 精品一区二区三区在线播放 | 99久久婷婷国产精品综合| 国产福利视频一区二区三区| 麻豆91精品91久久久的内涵| 日韩av一区二区在线影视| 亚洲国产美国国产综合一区二区| 亚洲特黄一级片| 国产精品国产三级国产a| 欧美韩日一区二区三区四区| 国产亚洲成aⅴ人片在线观看| 26uuu国产电影一区二区| 日韩免费一区二区三区在线播放| 欧美一级日韩免费不卡| 666欧美在线视频| 欧美一区二区三区四区五区| 欧美精品v国产精品v日韩精品 | 日本一区二区动态图| 久久精品在线免费观看| 久久久久久久久一| 久久久.com| 国产精品丝袜黑色高跟| 国产精品乱人伦| 亚洲欧洲99久久| 亚洲精选免费视频| 亚洲影院在线观看| 亚洲国产精品影院| 天天综合色天天综合| 日本女人一区二区三区| 久久国产精品一区二区| 国产最新精品免费| 国产成人免费视| 99久久99久久精品免费观看| 91论坛在线播放| 欧美三电影在线| 91精品国产综合久久精品app| 日韩精品专区在线影院观看| 精品国产123| 国产欧美日韩亚州综合| 亚洲色大成网站www久久九九| 一区二区在线免费| 丝袜国产日韩另类美女| 久久国产综合精品| 国产寡妇亲子伦一区二区| av午夜一区麻豆| 欧美性色aⅴ视频一区日韩精品| 欧美日韩高清一区二区不卡| 日韩美女主播在线视频一区二区三区 | 国产一区二区伦理| 国产99久久精品| 91久久精品一区二区| 欧美一区二区三区小说| 久久久高清一区二区三区| 成人欧美一区二区三区| 亚洲第四色夜色| 激情图区综合网| 99精品一区二区三区| 欧美男生操女生| 久久久国产精品麻豆| 一区二区三区四区在线播放| 丝袜脚交一区二区| 懂色av一区二区夜夜嗨| 日本韩国一区二区三区| 欧美大度的电影原声| 国产精品久久久久国产精品日日| 亚洲制服丝袜av| 韩国欧美一区二区| 色婷婷综合五月| 欧美电影免费观看高清完整版 | 成人久久视频在线观看| 欧美视频精品在线| 精品国产一区二区国模嫣然| 亚洲私人影院在线观看| 日本人妖一区二区| 99久久久久久| 欧美一区二区大片| 中文字幕人成不卡一区| 免费美女久久99| 91影视在线播放| 日韩精品一区二区三区中文不卡| 中文字幕视频一区| 另类小说色综合网站| 91首页免费视频| 久久久久久9999| 午夜久久福利影院| 成人免费av网站| 日韩精品一区二区三区在线播放| 亚洲人xxxx| 国产乱人伦偷精品视频免下载| 精品视频999| 国产精品久久精品日日|