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

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

?? myfile.cpp

?? 很好的邊緣檢測(cè)源代碼
?? CPP
字號(hào):
//  myfile.cpp
//
//  Source file for Device-Independent Bitmap (DIB) API.  Provides
//  the following functions:
//
//  SaveDIB()           - Saves the specified dib in a file
//  ReadDIBFile()       - Loads a DIB from a file
//
//
// This is a part of the Microsoft Foundation Classes C++ library.
// Copyright (C) 1992-1997 Microsoft Corporation
// All rights reserved.
//
// This source code is only intended as a supplement to the
// Microsoft Foundation Classes Reference and related
// electronic documentation provided with the library.
// See these sources for detailed information regarding the
// Microsoft Foundation Classes product.

#include "stdafx.h"
#include <math.h>
#include <io.h>
#include <direct.h>
#include "dibapi.h"

/*
 * Dib Header Marker - used in writing DIBs to files
 */
#define DIB_HEADER_MARKER   ((WORD) ('M' << 8) | 'B')

#ifdef _MAC
#define SWAPWORD(x) MAKEWORD(HIBYTE(x), LOBYTE(x))
#define SWAPLONG(x) MAKELONG(SWAPWORD(HIWORD(x)), SWAPWORD(LOWORD(x)))
void ByteSwapHeader(BITMAPFILEHEADER* bmiHeader);
void ByteSwapInfo(LPSTR lpHeader, BOOL fWin30Header);
#endif

/*************************************************************************
 *
 * SaveDIB()
 *
 * Saves the specified DIB into the specified CFile.  The CFile
 * is opened and closed by the caller.
 *
 * Parameters:
 *
 * HDIB hDib - Handle to the dib to save
 *
 * CFile& file - open CFile used to save DIB
 *
 * Return value: TRUE if successful, else FALSE or CFileException
 *
 *************************************************************************/


BOOL WINAPI SaveDIB(HDIB hDib, CFile& file)
{
	BITMAPFILEHEADER bmfHdr; // Header for Bitmap file
	LPBITMAPINFOHEADER lpBI;   // Pointer to DIB info structure
	DWORD dwDIBSize;

	if (hDib == NULL)
		return FALSE;

	/*
	 * Get a pointer to the DIB memory, the first of which contains
	 * a BITMAPINFO structure
	 */
	lpBI = (LPBITMAPINFOHEADER) ::GlobalLock((HGLOBAL) hDib);
	if (lpBI == NULL)
		return FALSE;

	if (!IS_WIN30_DIB(lpBI))
	{
		::GlobalUnlock((HGLOBAL) hDib);
		return FALSE;       // It's an other-style DIB (save not supported)
	}

	/*
	 * Fill in the fields of the file header
	 */

	/* Fill in file type (first 2 bytes must be "BM" for a bitmap) */
	bmfHdr.bfType = DIB_HEADER_MARKER;  // "BM"

	// Calculating the size of the DIB is a bit tricky (if we want to
	// do it right).  The easiest way to do this is to call GlobalSize()
	// on our global handle, but since the size of our global memory may have
	// been padded a few bytes, we may end up writing out a few too
	// many bytes to the file (which may cause problems with some apps).
	//
	// So, instead let's calculate the size manually (if we can)
	//
	// First, find size of header plus size of color table.  Since the
	// first DWORD in both BITMAPINFOHEADER and BITMAPCOREHEADER conains
	// the size of the structure, let's use this.

	dwDIBSize = *(LPDWORD)lpBI + ::PaletteSize((LPSTR)lpBI);  // Partial Calculation

	// Now calculate the size of the image

	if ((lpBI->biCompression == BI_RLE8) || (lpBI->biCompression == BI_RLE4))
	{
		// It's an RLE bitmap, we can't calculate size, so trust the
		// biSizeImage field

		dwDIBSize += lpBI->biSizeImage;
	}
	else
	{
		DWORD dwBmBitsSize;  // Size of Bitmap Bits only

		// It's not RLE, so size is Width (DWORD aligned) * Height

		dwBmBitsSize = WIDTHBYTES((lpBI->biWidth)*((DWORD)lpBI->biBitCount)) * lpBI->biHeight;

		dwDIBSize += dwBmBitsSize;

		// Now, since we have calculated the correct size, why don't we
		// fill in the biSizeImage field (this will fix any .BMP files which
		// have this field incorrect).

		lpBI->biSizeImage = dwBmBitsSize;
	}


	// Calculate the file size by adding the DIB size to sizeof(BITMAPFILEHEADER)

	bmfHdr.bfSize = dwDIBSize + sizeof(BITMAPFILEHEADER);
	bmfHdr.bfReserved1 = 0;
	bmfHdr.bfReserved2 = 0;

	/*
	 * Now, calculate the offset the actual bitmap bits will be in
	 * the file -- It's the Bitmap file header plus the DIB header,
	 * plus the size of the color table.
	 */
	bmfHdr.bfOffBits = (DWORD)sizeof(BITMAPFILEHEADER) + lpBI->biSize
											  + PaletteSize((LPSTR)lpBI);
#ifdef _MAC
	ByteSwapHeader(&bmfHdr);

	// First swap the size field
	*((LPDWORD)lpBI) = SWAPLONG(*((LPDWORD)lpBI));

	// Now swap the rest of the structure (we don't save < Win30 files)
	ByteSwapInfo((LPSTR)lpBI, TRUE);
#endif

	TRY
	{
		// Write the file header
		file.Write((LPSTR)&bmfHdr, sizeof(BITMAPFILEHEADER));
		//
		// Write the DIB header and the bits
		//
		file.WriteHuge(lpBI, dwDIBSize);
	}
	CATCH (CFileException, e)
	{
#ifdef _MAC
		// Swap everything back
		*((LPDWORD)lpBI) = SWAPLONG(*((LPDWORD)lpBI));
		ByteSwapInfo((LPSTR)lpBI, TRUE);
#endif
		::GlobalUnlock((HGLOBAL) hDib);
		THROW_LAST();
	}
	END_CATCH

#ifdef _MAC
	// Swap everything back
	*((LPDWORD)lpBI) = SWAPLONG(*((LPDWORD)lpBI));
	ByteSwapInfo((LPSTR)lpBI, TRUE);
#endif

	::GlobalUnlock((HGLOBAL) hDib);
	return TRUE;
}


/*************************************************************************

  Function:  ReadDIBFile (CFile&)

   Purpose:  Reads in the specified DIB file into a global chunk of
			 memory.

   Returns:  A handle to a dib (hDIB) if successful.
			 NULL if an error occurs.

  Comments:  BITMAPFILEHEADER is stripped off of the DIB.  Everything
			 from the end of the BITMAPFILEHEADER structure on is
			 returned in the global memory handle.

*************************************************************************/


HDIB WINAPI ReadDIBFile(CFile& file)
{
	BITMAPFILEHEADER bmfHeader;
	DWORD dwBitsSize;
	HDIB hDIB;
	LPSTR pDIB;

	/*
	 * get length of DIB in bytes for use when reading
	 */

	dwBitsSize = file.GetLength();

	/*
	 * Go read the DIB file header and check if it's valid.
	 */
	if (file.Read((LPSTR)&bmfHeader, sizeof(bmfHeader)) != sizeof(bmfHeader))
		return NULL;

#ifdef _MAC
	ByteSwapHeader(&bmfHeader);
#endif
	if (bmfHeader.bfType != DIB_HEADER_MARKER)
		return NULL;

	/*
	 * Allocate memory for DIB
	 */
	hDIB = (HDIB) ::GlobalAlloc(GMEM_MOVEABLE | GMEM_ZEROINIT, dwBitsSize);
	if (hDIB == 0)
	{
		return NULL;
	}
	pDIB = (LPSTR) ::GlobalLock((HGLOBAL) hDIB);

	/*
	 * Go read the bits.
	 */
	if (file.ReadHuge(pDIB, dwBitsSize - sizeof(BITMAPFILEHEADER)) !=
		dwBitsSize - sizeof(BITMAPFILEHEADER) )
	{
		::GlobalUnlock((HGLOBAL) hDIB);
		::GlobalFree((HGLOBAL) hDIB);
		return NULL;
	}
#ifdef _MAC
	// First swap the size field
	*((LPDWORD)pDIB) = SWAPLONG(*((LPDWORD)pDIB));

	// Now swap the rest of the structure
	ByteSwapInfo(pDIB, IS_WIN30_DIB(pDIB));
#endif
	::GlobalUnlock((HGLOBAL) hDIB);
	return hDIB;
}


#ifdef _MAC
void ByteSwapHeader(BITMAPFILEHEADER* bmfHeader)
{
	bmfHeader->bfType = SWAPWORD(bmfHeader->bfType);
	bmfHeader->bfSize = SWAPLONG(bmfHeader->bfSize);
	bmfHeader->bfOffBits = SWAPLONG(bmfHeader->bfOffBits);
}


void ByteSwapInfo(LPSTR lpHeader, BOOL fWin30Header)
{
	// Note this doesn't swap the bcSize/biSize field.  It assumes that the
	// size field was swapped during read or while setting the fWin30Header
	// flag.

	if (fWin30Header)
	{
		LPBITMAPINFOHEADER lpBMIH = &(LPBITMAPINFO(lpHeader)->bmiHeader);

		//lpBMIH->biSize = SWAPLONG(lpBMIH->biSize);
		lpBMIH->biWidth = SWAPLONG(lpBMIH->biWidth);
		lpBMIH->biHeight = SWAPLONG(lpBMIH->biHeight);
		lpBMIH->biPlanes = SWAPWORD(lpBMIH->biPlanes);
		lpBMIH->biBitCount = SWAPWORD(lpBMIH->biBitCount);
		lpBMIH->biCompression = SWAPLONG(lpBMIH->biCompression);
		lpBMIH->biSizeImage = SWAPLONG(lpBMIH->biSizeImage);
		lpBMIH->biXPelsPerMeter = SWAPLONG(lpBMIH->biXPelsPerMeter);
		lpBMIH->biYPelsPerMeter = SWAPLONG(lpBMIH->biYPelsPerMeter);
		lpBMIH->biClrUsed = SWAPLONG(lpBMIH->biClrUsed);
		lpBMIH->biClrImportant = SWAPLONG(lpBMIH->biClrImportant);
	}
	else
	{
		LPBITMAPCOREHEADER lpBMCH = &(LPBITMAPCOREINFO(lpHeader)->bmciHeader);

		lpBMCH->bcWidth = SWAPWORD(lpBMCH->bcWidth);
		lpBMCH->bcHeight = SWAPWORD(lpBMCH->bcHeight);
		lpBMCH->bcPlanes = SWAPWORD(lpBMCH->bcPlanes);
		lpBMCH->bcBitCount = SWAPWORD(lpBMCH->bcBitCount);
	}
}

#endif

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
99久久婷婷国产综合精品| 国产精品美女久久久久久久| 韩国毛片一区二区三区| 亚洲欧洲日韩女同| 日韩欧美国产wwwww| 在线观看网站黄不卡| 国产91清纯白嫩初高中在线观看| 一区二区不卡在线视频 午夜欧美不卡在| 欧美电影精品一区二区| 日本精品一区二区三区四区的功能| 九九视频精品免费| 五月婷婷另类国产| 亚洲精品日产精品乱码不卡| 国产日韩欧美高清在线| 欧美va亚洲va香蕉在线| 欧美日韩一区二区三区四区五区| aaa国产一区| 成人丝袜视频网| 国内精品嫩模私拍在线| 久久精品国产亚洲高清剧情介绍| 亚洲成人精品在线观看| 亚洲美女视频在线| 国产精品久久久久9999吃药| 久久这里只有精品首页| 精品久久久三级丝袜| 欧美一级高清片在线观看| 欧美理论片在线| 欧美色电影在线| 欧美在线观看视频一区二区| 91免费视频网| 色婷婷综合久久久久中文一区二区 | 欧美精选一区二区| 一本到不卡免费一区二区| 91免费视频网址| 一本一本久久a久久精品综合麻豆| 国产成人av电影免费在线观看| 美女视频黄久久| 韩国欧美国产1区| 国产精品亚洲成人| 精品无人码麻豆乱码1区2区| 久久精品国产亚洲高清剧情介绍 | 九一九一国产精品| 免费成人你懂的| 久国产精品韩国三级视频| 狠狠色丁香久久婷婷综合丁香| 蜜臀99久久精品久久久久久软件| 男女性色大片免费观看一区二区| 蜜臀av性久久久久蜜臀av麻豆 | 麻豆精品一区二区综合av| 免费观看久久久4p| 精品一区二区三区欧美| 国产黄色精品视频| 不卡区在线中文字幕| 91久久国产最好的精华液| 欧美亚洲综合网| 欧美一区二区在线不卡| 欧美成人午夜电影| 国产欧美在线观看一区| 亚洲色图在线视频| 亚洲成a人v欧美综合天堂下载| 日本不卡视频在线| 国产精品一级二级三级| 色综合久久天天| 欧美日韩卡一卡二| 久久无码av三级| 国产精品初高中害羞小美女文| 亚洲激情第一区| 日本人妖一区二区| 粗大黑人巨茎大战欧美成人| 91久久精品国产91性色tv| 欧美一区二区三区在| 国产午夜亚洲精品午夜鲁丝片| 最新国产成人在线观看| 天天操天天干天天综合网| 国产精品一区久久久久| 欧美性受xxxx| 久久久国产精品不卡| 亚洲一区精品在线| 国精产品一区一区三区mba桃花 | 中文字幕一区二区视频| 性感美女极品91精品| 国产精品18久久久久久久久| 91浏览器在线视频| 精品国产乱码久久久久久闺蜜| 亚洲美女在线一区| 国产一区二区导航在线播放| 色老汉一区二区三区| 精品国产亚洲一区二区三区在线观看| 中文字幕一区视频| 毛片av一区二区三区| 色综合天天视频在线观看 | 一区在线观看免费| 琪琪久久久久日韩精品| 91香蕉视频在线| 精品久久五月天| 午夜欧美电影在线观看| 成人午夜av在线| 日韩免费电影网站| 亚洲国产aⅴ成人精品无吗| 成人一区二区三区视频| 日韩午夜在线观看| 一区二区三区在线观看动漫| 国产精品一二三四五| 91精品国模一区二区三区| 亚洲乱码国产乱码精品精可以看| 国产精品一级在线| 日韩精品中文字幕在线一区| 亚洲午夜电影网| 色综合久久久久久久| 欧美国产精品中文字幕| 久久精品国产精品亚洲综合| 欧美日韩亚洲综合在线 欧美亚洲特黄一级| 久久精品视频一区二区三区| 日韩av中文字幕一区二区| 欧美在线观看一区二区| 国产精品护士白丝一区av| 久久99国产精品久久| 91精品国产综合久久国产大片| 亚洲综合免费观看高清在线观看| av激情亚洲男人天堂| 中文字幕二三区不卡| 国产精品一区二区黑丝| 久久夜色精品国产噜噜av| 另类小说一区二区三区| 欧美精品一二三四| 天堂蜜桃91精品| 在线视频你懂得一区二区三区| 中文字幕中文字幕中文字幕亚洲无线 | 国产精品视频线看| 国产精品资源在线看| 久久综合九色综合久久久精品综合| 麻豆国产一区二区| 日韩精品中文字幕在线一区| 免费观看在线综合色| 777亚洲妇女| 美女视频黄频大全不卡视频在线播放| 欧美精品xxxxbbbb| 奇米一区二区三区| 欧美mv和日韩mv的网站| 精品亚洲porn| 久久久久国产精品麻豆ai换脸| 国产美女一区二区三区| 久久久激情视频| 波波电影院一区二区三区| 亚洲视频一二三区| 欧美吻胸吃奶大尺度电影| 亚洲bt欧美bt精品| 日韩欧美国产麻豆| 国产一区二区三区综合| 中文在线一区二区| 色哦色哦哦色天天综合| 亚洲妇女屁股眼交7| 日韩视频在线永久播放| 国产精品资源在线看| 亚洲视频你懂的| 欧美日韩国产美| 美国三级日本三级久久99 | 久久无码av三级| av高清久久久| 无码av免费一区二区三区试看| 欧美成人精品1314www| 国产99久久久国产精品潘金网站| 1000精品久久久久久久久| 欧美色视频在线| 狠狠久久亚洲欧美| 最新国产の精品合集bt伙计| 在线91免费看| 处破女av一区二区| 亚洲国产综合人成综合网站| 欧美成人一区二区三区在线观看 | 91蜜桃婷婷狠狠久久综合9色| 亚洲v中文字幕| 久久久久久毛片| 在线精品视频小说1| 狠狠狠色丁香婷婷综合久久五月| 亚洲人成网站精品片在线观看| 911精品产国品一二三产区| 国产精品18久久久久久久久| 亚洲综合自拍偷拍| 久久精品欧美一区二区三区不卡| 91久久线看在观草草青青| 久久精品72免费观看| 亚洲精品自拍动漫在线| 久久伊人中文字幕| 欧美人xxxx| 99麻豆久久久国产精品免费 | 一区二区三区 在线观看视频| 精品久久久久久久久久久院品网 | 亚洲欧洲日韩在线| 日韩亚洲欧美综合| 一本到不卡免费一区二区| 狠狠色综合色综合网络| 亚洲高清视频在线| 国产精品久99| 久久综合九色综合欧美98| 欧美肥大bbwbbw高潮| 色婷婷久久久亚洲一区二区三区| 国产一区二区三区最好精华液| 日日夜夜精品视频免费| 一区二区三区中文字幕精品精品|