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

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

?? dib.cpp

?? 這是linux的接口的大量原碼,大家可以學習中進步,linux是開發嵌入式不能不學的系統工程
?? CPP
字號:
// Dib.cpp : implementation file
//

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

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

#define pi 3.14159265

CDib::CDib()
{
	m_lWidth = 0;
	m_lHeight = 0;
	m_wBitCount = 0;
	m_nClrUsed = 0;
	m_dwSizeImage = 0;
	m_bIsLoadFile = false;

	m_lpBMPInfo = NULL;
	m_lpLogPal = NULL;
	m_lpImage = NULL;
	m_hdd = 0;
	m_hPal = 0;

}

CDib::~CDib()
{
	Empty();
}

CDib::CDib(LPCTSTR lpszPathName)
{
   	m_lWidth = 0;
	m_lHeight = 0;
	m_wBitCount = 0;
	m_nClrUsed = 0;
	m_dwSizeImage = 0;
	m_bIsLoadFile = false;

	m_lpBMPInfo = NULL;
	m_lpLogPal = NULL;
	m_lpImage = NULL;
	m_hdd = 0;
	m_hPal = 0;

	LoadBMP(lpszPathName);
}

BOOL CDib::LoadBMP(LPCTSTR lpszPathName)
{
   Empty();

   //open a file
   CFile file;
   if(!file.Open(lpszPathName,CFile::modeRead | 
	                                  CFile::shareDenyNone))
   {
	   AfxMessageBox("cann't open the file");
	   return false;
   }

   //read the header of the file
   LPBITMAPFILEHEADER lpBMPFileHeader = (LPBITMAPFILEHEADER)
	           new BYTE[sizeof(BITMAPFILEHEADER)];
   if(!lpBMPFileHeader)
   {
	   AfxMessageBox("not enough memory");
	   file.Close();
	   return false;
   }
   file.Read(lpBMPFileHeader,sizeof(BITMAPFILEHEADER));
   if(lpBMPFileHeader->bfType != 0x4d42)
   {
	   AfxMessageBox("It is not a BMP's file");
	   delete[] lpBMPFileHeader;
	   lpBMPFileHeader = NULL;
	   file.Close();
	   return false;
   }

   //read the structure of the BITMAPINFO 
   m_lpBMPInfo = (LPBITMAPINFO) new BYTE[lpBMPFileHeader->bfOffBits
	                          - sizeof(BITMAPFILEHEADER)];
   if(!m_lpBMPInfo)
   {
	   AfxMessageBox("not enough memory");
	   delete[] lpBMPFileHeader;
	   lpBMPFileHeader = NULL;
	   file.Close();
	   return false;
   }
   file.ReadHuge(m_lpBMPInfo,lpBMPFileHeader->bfOffBits
	                          - sizeof(BITMAPFILEHEADER) );
   m_lWidth = m_lpBMPInfo->bmiHeader.biWidth;
   m_lHeight = m_lpBMPInfo->bmiHeader.biHeight;
   m_wBitCount = m_lpBMPInfo->bmiHeader.biBitCount;
   m_nClrUsed = GetClrUsed();
   BytesPerLine=(m_lWidth * (m_wBitCount / 8) + 3)&~3;//m_lpBMPInfo->bmiHeader.biWidth*m_lpBMPInfo->bmiHeader.biPlanes
							//*m_lpBMPInfo->bmiHeader.biBitCount;
   
   if(m_nClrUsed<=16 && m_nClrUsed !=0)
   {
	   AfxMessageBox("The picture need more biBitCount");
	   delete[] lpBMPFileHeader;
	   lpBMPFileHeader = NULL;
	   delete[] m_lpBMPInfo;
	   m_lpBMPInfo = NULL;
	   file.Close();
	   return false;
   }
   //calculate the bytes of the picture
   m_dwSizeImage = ((m_lWidth * (m_wBitCount / 8) + 3)&~3)*m_lHeight;
   m_lpImage = new BYTE[m_dwSizeImage];
   if(!m_lpImage)
   {
	   AfxMessageBox("not enough memory");
	   delete[] lpBMPFileHeader;
	   lpBMPFileHeader = NULL;
	   delete[] m_lpBMPInfo;
	   m_lpBMPInfo = NULL;
	   file.Close();
	   return false;
   }
   file.ReadHuge(m_lpImage,m_dwSizeImage);

   //set the imformation of the palette;
   m_lpLogPal = (LPLOGPALETTE) new BYTE[sizeof(LPLOGPALETTE)
	                            +m_nClrUsed*sizeof(PALETTEENTRY)];
   m_lpLogPal->palVersion = 0x300;
   m_lpLogPal->palNumEntries = m_nClrUsed;
   for(int i = 0;i<m_nClrUsed;i++)
   {
	   m_lpLogPal->palPalEntry[i].peRed = m_lpBMPInfo->
		                                      bmiColors[i].rgbRed;
	   m_lpLogPal->palPalEntry[i].peBlue = m_lpBMPInfo->
		                                      bmiColors[i].rgbBlue;
	   m_lpLogPal->palPalEntry[i].peGreen = m_lpBMPInfo->
		                                      bmiColors[i].rgbGreen;
	   m_lpLogPal->palPalEntry[i].peFlags = 0;
   }
   m_hPal = ::CreatePalette(m_lpLogPal);
   delete[] lpBMPFileHeader;
   lpBMPFileHeader = NULL;
   file.Close();
   m_bIsLoadFile = true;
	
   return true;

}

void CDib::Empty()
{
	m_lWidth = 0;
	m_lHeight = 0;
	m_wBitCount = 0;
	m_nClrUsed = 0;
	m_dwSizeImage = 0;
	m_bIsLoadFile = false;

	if(m_lpBMPInfo)
		delete[] m_lpBMPInfo;
	m_lpBMPInfo = NULL;

	if(m_lpLogPal)
		delete[] m_lpLogPal;
    m_lpLogPal = NULL;

	if(m_lpImage)
		delete[] m_lpImage;
	m_lpImage = NULL;
//	if(m_lpImage1)
//		delete[] m_lpImage1;
//	m_lpImage1=NULL;

	if(m_hdd)
		::DrawDibClose(m_hdd);
	m_hdd = 0;

	if(m_hPal)
		::DeleteObject(m_hPal);
	m_hPal = 0;
}

DWORD CDib::GetClrUsed()
{
    if(m_lpBMPInfo->bmiHeader.biClrUsed == 0)
	{
		switch(m_wBitCount)
		{
		case 1:
			return 2;
		case 4:
			return 16;
		case 8:
			return 256;
		default:
			return 0;
		}
	}
	return m_lpBMPInfo->bmiHeader.biClrUsed;
}



BOOL CDib::Init(CDC *pDC)
{
	if(!m_bIsLoadFile)
		return false;
	m_hdd = ::DrawDibOpen();
	::DrawDibBegin(m_hdd,pDC->m_hDC,-1,-1,&m_lpBMPInfo->bmiHeader
		,m_lWidth,m_lHeight,DDF_ANIMATE);
	return true;

}

BOOL CDib::draw(CDC *pDC, CPoint originDes)
{
	CRect src;
	src.left = src.top = 0;
	src.right = m_lWidth;
	src.bottom = m_lHeight;
	::DrawDibDraw(m_hdd,pDC->m_hDC,originDes.x ,
				 originDes.y ,m_lWidth,-m_lHeight,&m_lpBMPInfo->bmiHeader,
				 (LPVOID)m_lpImage,src.left,src.top,m_lWidth,src.Height(),
				 DDF_SAME_HDC);
	return true;
}

/*
LONG CDib::GetPixOffset(LONG x, LONG y)
{
	return (m_lHeight-y-1)*BytesPerLine+x*m_wBitCount/8;
}



int CDib::ComputePixel(float x, float y, float &x1, float &y1)
{
	float r, nn;

  if (x==0 && y==0) 
  {
	 x1 = x;
	 y1 = y;
	 return 1;
  }

  nn = (float)sqrt(x*x + y*y);
  r = (float) (fabs(x) > fabs(y)) ? fabs(nn/x): fabs(nn/y);

  x1 = (r*x);
  y1 = (r*y);

  return 1;

}

void CDib::ComputerEllipseEffect(LPBYTE src,LPBYTE des)
{
   // CWaitCursor wait;
  int x, y, x1, y1,tmp1,tmp2;
  float fx, fy, xmid, ymid, ar;


  xmid = (float) (m_lWidth/2.0);
  ymid = (float) (m_lHeight/2.0);
  ar = (float)(m_lHeight)/(float)(m_lWidth);
  for (y=0; y<m_lHeight; y++)
  {
	 for (x=0; x<m_lWidth; x++)
	 {
		ComputePixel(ar*(x-xmid), y-ymid, fx, fy);
		x1 = (int)(xmid+fx/ar);
		y1 = (int)(ymid+fy);
	   if(x1>=0&&y1>=0&&x1<m_lWidth&&y1<m_lHeight)
		{
		tmp2=GetPixOffset(x1,y1);
		tmp1=GetPixOffset(x,y);
		des[tmp1] = src[tmp2];
		des[tmp1+1] = src[tmp2+1];
		des[tmp1+2] = src[tmp2+2];
		}
	 }
  }
  

}
*/

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
有码一区二区三区| 日韩欧美国产综合一区| 欧美日韩黄视频| 久久精品一区四区| 午夜天堂影视香蕉久久| 国产999精品久久久久久| 欧美日精品一区视频| 久久久久久久国产精品影院| 婷婷中文字幕一区三区| 成人一区在线观看| 久久女同性恋中文字幕| 日韩有码一区二区三区| 欧美午夜宅男影院| 亚洲欧洲成人av每日更新| 激情深爱一区二区| 欧美电视剧免费观看| 亚洲电影激情视频网站| 色婷婷综合五月| 国产精品乱子久久久久| 国产激情一区二区三区桃花岛亚洲| 欧美欧美欧美欧美| 亚洲国产一区视频| 欧美亚洲动漫精品| 亚洲裸体在线观看| 91亚洲永久精品| 中文字幕不卡在线观看| 国产成人免费视频一区| 精品国产sm最大网站免费看| 免费在线视频一区| 日韩免费性生活视频播放| 久久精品国产免费| 色哟哟一区二区三区| 五月天久久比比资源色| 午夜精品在线看| 国产一区二区日韩精品| 人人爽香蕉精品| 精品中文字幕一区二区小辣椒| 国产日韩欧美一区二区三区乱码| 欧美一级片在线| 欧美日韩成人综合天天影院| 欧美美女一区二区| 久久综合九色综合97_久久久| 久久老女人爱爱| 亚洲资源中文字幕| 色噜噜久久综合| 午夜不卡av免费| 日韩亚洲欧美在线| 国产精品69久久久久水密桃| 国产日韩综合av| 91成人在线免费观看| 午夜欧美视频在线观看| 欧美成人综合网站| 成人午夜免费电影| 亚洲免费在线视频一区 二区| 欧美性三三影院| 美腿丝袜亚洲色图| 国产精品美女一区二区在线观看| 色成人在线视频| 免费人成网站在线观看欧美高清| 国产日产欧美一区二区视频| 91啪九色porn原创视频在线观看| 午夜欧美视频在线观看| 久久婷婷成人综合色| 91免费版在线看| 久久99精品久久久久久| 国产精品久久二区二区| 欧美日韩高清一区| 国产伦精品一区二区三区免费迷| 亚洲精品乱码久久久久久黑人 | 国产性色一区二区| 91美女精品福利| 久久精品av麻豆的观看方式| 亚洲免费观看高清完整版在线观看熊 | 色天使久久综合网天天| 日本成人中文字幕| 亚洲色欲色欲www在线观看| 欧美一级夜夜爽| 日本韩国一区二区三区视频| 美美哒免费高清在线观看视频一区二区| 国产精品女人毛片| 欧美一级专区免费大片| 91美女福利视频| 国产自产高清不卡| 国产自产2019最新不卡| 精品黑人一区二区三区久久| 成人精品鲁一区一区二区| 日韩欧美不卡在线观看视频| 视频一区中文字幕| 欧美tk—视频vk| 麻豆精品国产传媒mv男同| 欧美精品一区二区久久久| 国产主播一区二区| 国产日韩欧美在线一区| 在线精品视频一区二区三四| 国产精品美女久久久久久2018 | 日韩一区欧美一区| 91精品午夜视频| 欧美日韩一区二区在线观看视频| 欧美高清hd18日本| 91免费看`日韩一区二区| 国内国产精品久久| 蜜臀av亚洲一区中文字幕| 亚洲欧美偷拍三级| 国产精品水嫩水嫩| 久久精品夜色噜噜亚洲aⅴ| 欧美一区国产二区| 欧美一级理论片| 欧美一区二区三区系列电影| 欧美日韩电影一区| 色噜噜偷拍精品综合在线| 一本久久a久久精品亚洲| 成人精品一区二区三区四区 | 91网站视频在线观看| 成人黄色软件下载| www.亚洲精品| 99综合电影在线视频| 不卡一二三区首页| av一二三不卡影片| 色悠悠亚洲一区二区| 欧美综合亚洲图片综合区| 欧美婷婷六月丁香综合色| 欧美久久一二区| 欧美tickling挠脚心丨vk| 2欧美一区二区三区在线观看视频 337p粉嫩大胆噜噜噜噜噜91av | 成人高清在线视频| eeuss鲁片一区二区三区在线看| 成人午夜视频在线观看| 成人自拍视频在线| 色噜噜狠狠成人网p站| 欧美视频三区在线播放| 884aa四虎影成人精品一区| 日韩精品一区二区三区中文不卡| 精品日韩一区二区三区免费视频| 精品人在线二区三区| 国产调教视频一区| 亚洲精品乱码久久久久久日本蜜臀| 亚洲成av人影院在线观看网| 蜜臀av性久久久久蜜臀aⅴ四虎 | 26uuu亚洲| 国产精品乱码人人做人人爱| 亚洲欧美aⅴ...| 视频一区二区三区在线| 国产精品一卡二卡在线观看| 一本色道久久综合精品竹菊| 欧美精品久久99久久在免费线 | www.99精品| 欧美人狂配大交3d怪物一区| 久久精品亚洲乱码伦伦中文| 亚洲精品日日夜夜| 日韩国产精品91| aaa国产一区| 日韩精品在线网站| 中文字幕在线免费不卡| 日韩成人精品视频| av成人免费在线| 精品电影一区二区| 亚洲观看高清完整版在线观看 | 亚洲欧洲一区二区三区| 日韩黄色免费电影| 成人avav在线| 日韩一区二区在线播放| 成人欧美一区二区三区黑人麻豆| 免费成人在线观看| 欧美性生活久久| 国产精品天干天干在线综合| 美女精品一区二区| 91成人免费在线视频| 国产欧美一区二区精品忘忧草| 亚洲福利国产精品| 成人国产精品免费网站| 久久综合色8888| 美女网站在线免费欧美精品| 一本久道中文字幕精品亚洲嫩| 久久久久久毛片| 蜜桃一区二区三区四区| 91麻豆产精品久久久久久| 久久久精品黄色| 激情图片小说一区| 日韩午夜三级在线| 日韩av在线播放中文字幕| 在线精品视频一区二区三四| 国产精品国产三级国产aⅴ无密码| 久久国产尿小便嘘嘘尿| 91精品国产91热久久久做人人| 玉米视频成人免费看| 99re在线精品| 亚洲欧美一区二区在线观看| 成人免费的视频| 一本一道久久a久久精品| 欧美在线观看一二区| 日韩欧美二区三区| 男男gaygay亚洲| 制服丝袜亚洲精品中文字幕| 亚洲成人手机在线| 91黄色小视频| 亚洲精品国产第一综合99久久| 成人高清免费在线播放| 国产精品美女www爽爽爽| 成人精品视频一区二区三区尤物| 久久精品日产第一区二区三区高清版|