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

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

?? tools.cpp

?? 一個比較完整的酒店管理系統
?? CPP
字號:
/*########################################################################
	Filename: 	tools.cpp
	----------------------------------------------------
	Remarks:	...
	----------------------------------------------------
  ########################################################################*/
#include "stdafx.h"
#include "resource.h"
#include "tools.h"

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

typedef struct tagCOLOR
{
	BYTE blue;
	BYTE green;
	BYTE red;
	BYTE alpha;
}COLOR;

COLORREF WINAPI AlphaBlendColor(COLORREF color, BYTE byAlpha)
{
	COLOR *oldcolor = (COLOR*)(&color);
	oldcolor->alpha = 0; 
	oldcolor->red   = oldcolor->red   * byAlpha / 255;
	oldcolor->green = oldcolor->green * byAlpha / 255;
	oldcolor->blue  = oldcolor->blue  * byAlpha / 255;
	return color;
}

/*===============================================================
		名稱:	設置分層窗口透明或半透明屬性.
		hWnd:	分層窗口句柄.
		crKey:	要顯示為透明區域的顏色.當dwFlags為LWA_COLORKEY有效.
		bAlpha: 窗口的半透明度.當dwFlags為LWA_ALPHA有效.
		說明:   當窗口被設置了WS_EX_LAYERED擴展風格才有效.
=================================================================*/
BOOL SetLayeredWindow(HWND hWnd, COLORREF crKey, BYTE bAlpha, DWORD dwFlags)
{
	BOOL bRet = FALSE;

	//load USER32.dll-------------------------------------------------
	HMODULE	hUserDll = NULL;
	hUserDll = ::LoadLibrary(_T("USER32.dll"));
	
	// Check that "USER32.dll" library has been loaded successfully...
	if (hUserDll != NULL)
	{
		typedef BOOL (WINAPI* lpfnSetAttributes)(HWND hWnd, COLORREF crKey, BYTE bAlpha, DWORD dwFlags);
		lpfnSetAttributes pFnlpfnSetAttributes  = NULL;
		pFnlpfnSetAttributes  = (lpfnSetAttributes)GetProcAddress(hUserDll, "SetLayeredWindowAttributes");
		if (pFnlpfnSetAttributes )
		{
			bRet = pFnlpfnSetAttributes(hWnd, crKey, bAlpha, dwFlags);
		}
	} 
	
	if (hUserDll != NULL) ::FreeLibrary(hUserDll);
	return bRet;
} 

/*========================================================================
	說明:	檢測系統是否開啟了菜單陰影(主要針對于Windows XP, Windows 2003
		及他更高的版本).	
==========================================================================*/
BOOL WINAPI IsShadowEnabled()
{
	BOOL bEnabled = FALSE;
	if (SystemParametersInfo(SPI_GETDROPSHADOW, 0, &bEnabled, 0))
	{
		return bEnabled;
	}
	return FALSE;
}

DWORD WINAPI GetWinVersion()
{
    static DWORD WindowsVer = UnKnowWindowsVer;

    if (WindowsVer != UnKnowWindowsVer)
    {
        return WindowsVer;
    }

    OSVERSIONINFO osvi;
    ZeroMemory(&osvi, sizeof(OSVERSIONINFO));
    osvi.dwOSVersionInfoSize = sizeof(OSVERSIONINFO);
	
    if (!GetVersionEx (&osvi))
    {
        return WindowsVer = UnKnowWindowsVer;
    }

    if (osvi.dwPlatformId == VER_PLATFORM_WIN32s)
    {
        return WindowsVer = Windows32s;
    }

    else if(osvi.dwPlatformId == VER_PLATFORM_WIN32_NT)
    {
        if (osvi.dwMajorVersion == 4L)
        {
            return WindowsVer = WindowsNT4;
        }
        else if (osvi.dwMajorVersion == 5L) 
        {
			if (osvi.dwMinorVersion == 0L)
			{
				return WindowsVer = Windows2000;
			}
			else if (osvi.dwMinorVersion == 1L)
			{
				return WindowsVer = WindowsXP;
			}
			else
			{
				return WindowsVer = Windows2003;
			}
        }
        return WindowsVer = WindowsNT3;
    }
    ASSERT(osvi.dwPlatformId == VER_PLATFORM_WIN32_WINDOWS);
	
    if (osvi.dwMajorVersion == 4L && osvi.dwMinorVersion == 10L)
    {
        return WindowsVer = Windows98;
    }
    if (osvi.dwMajorVersion == 4L && osvi.dwMinorVersion == 90L)
    {
        return WindowsVer = WindowsME;
    }
    return WindowsVer = Windows95;
}

/*========================================================================
	說明:		截取屏幕上指定區域內的圖像.
==========================================================================*/
HBITMAP WINAPI GetScreenBitmap(LPCRECT pRect)
{
    HDC     hDC;
    HDC     hMemDC;
    HBITMAP hNewBitmap = NULL;
	
    if ((hDC = ::GetDC(NULL)) != NULL )
    {
        if ((hMemDC = ::CreateCompatibleDC(hDC)) != NULL)
        {
            if ((hNewBitmap = ::CreateCompatibleBitmap(hDC, pRect->right - pRect->left, pRect->bottom - pRect->top)) != NULL)
            {
                HBITMAP hOldBitmap = (HBITMAP)::SelectObject(hMemDC, hNewBitmap);
                ::BitBlt(hMemDC, 0, 0, pRect->right - pRect->left, pRect->bottom - pRect->top,
					hDC, pRect->left, pRect->top, SRCCOPY);
                ::SelectObject(hMemDC, (HGDIOBJ)hOldBitmap);
            }
            ::DeleteDC(hMemDC);
        }
        ::ReleaseDC(NULL, hDC);
    }
    return hNewBitmap;
}

/*========================================================================
	說明:	指定Windows菜單句柄是否為自畫風格菜單.
==========================================================================*/
BOOL WINAPI IsOwnerDrawMenu(HMENU hMenu)
{
    MENUITEMINFO mii = {sizeof MENUITEMINFO, MIIM_TYPE };
    ::GetMenuItemInfo(hMenu, 0, TRUE, &mii);
    return (mii.fType & MFT_OWNERDRAW) != 0;
}

/*========================================================================
	功能:			創建相應的圖像列表所需的圖像
	-------------------------------------------------------------
	hbitmap:		原始位圖句柄
	crBackColor:	背景色
	nstyle:			要創建的圖像的風格,它們為下列值之一:
	----------------------------------------------------
		-	0:		創建禁止圖像列表圖像
		-	1:		創建正常圖像列表圖像
		-	2:		創建熱圖像列表圖像
==========================================================================*/
HBITMAP WINAPI CreateImage(HBITMAP hbitmap, int nstyle, BOOL bAlpha, COLORREF crBackColor, COLORREF crMarkColor, BOOL bFillMarkColor)
{
	HBITMAP RetBmp = NULL;
    if (hbitmap == NULL)
    {  
		return NULL;
	}

	//源位圖DC------------------------------------
    HDC BufferDC = CreateCompatibleDC(NULL);      
    if (BufferDC == NULL)
    {
		return NULL;
	}
    SelectObject(BufferDC, hbitmap);

	//目標DC--------------------------------------
    HDC DirectDC = CreateCompatibleDC(NULL);      
    if (DirectDC == NULL)
    {
		  DeleteDC(BufferDC);
		  return NULL;
	}

    // 獲取源位圖大小----------------------------
    BITMAP bm;
    GetObject(hbitmap, sizeof(bm), &bm);

	// 初始化BITMAPINFO信息----------------------
    BITMAPINFO bitmapinfo; 
    ZeroMemory(&bitmapinfo, sizeof(BITMAPINFO));
    bitmapinfo.bmiHeader.biSize     = sizeof(BITMAPINFOHEADER);
    bitmapinfo.bmiHeader.biWidth    = bm.bmWidth;
    bitmapinfo.bmiHeader.biHeight   = bm.bmHeight;
    bitmapinfo.bmiHeader.biPlanes   = 1;
    bitmapinfo.bmiHeader.biBitCount = 32;
	
	//指向像素區指針--------
	BYTE *ptPixels;    
    HBITMAP DirectBitmap = CreateDIBSection(DirectDC, (BITMAPINFO*)&bitmapinfo, 
                                  DIB_RGB_COLORS, (void**)&ptPixels, NULL, 0);
	
	//背景顏色--------------
	BYTE	oldRed   = GetRValue(crBackColor);
	BYTE	oldGreen = GetGValue(crBackColor);
	BYTE	oldBlue  = GetBValue(crBackColor);

	//透明色----------------
	BYTE	markRed   = GetRValue(crMarkColor);
	BYTE	markGreen = GetGValue(crMarkColor);
	BYTE	markBlue  = GetBValue(crMarkColor);

	BYTE	temp = 0;
	COLOR* ptPixel = (COLOR*)ptPixels;
	
    if (DirectBitmap != NULL)
    {
        HGDIOBJ oldObject = SelectObject(DirectDC, DirectBitmap);
        BitBlt(DirectDC, 0, 0, bm.bmWidth, bm.bmHeight, BufferDC, 0, 0, SRCCOPY);
		
		register int nbitcount = (bm.bmWidth * bm.bmHeight * 4);
        for (register int i = 0; i < nbitcount;  i += 4)
        {
			//透明區(alpha == 0)----------------------------------
			if (( bAlpha && ptPixel->alpha == 0) 
			||  (!bAlpha && ptPixel->red   == markRed	//red
						 && ptPixel->green == markGreen	//green
						 && ptPixel->blue  == markBlue	//blue
					)
			   ) 
			{
				if (bFillMarkColor)
				{
					ptPixel->blue  = 255;
					ptPixel->green = 0;
					ptPixel->red   = 255;
				}
				else
				{
					ptPixel->blue  = oldRed;
					ptPixel->green = oldGreen;
					ptPixel->red   = oldBlue;
				}
			}
			else 
			{
				//灰度化位圖--------------------------------------
				if (nstyle == 0 )
				{
					temp = (BYTE)(ptPixel->red * 0.299 + ptPixel->green * 0.587 + ptPixels[i] * 0.114);
					temp = (BYTE)(255 - (255 - temp) * 0.8); 
					ptPixel->red = ptPixel->green = ptPixels[i] = temp;
				}

				//淡化位圖----------------------------------------
				else if (nstyle == 2)
				{
					ptPixel->red   = (BYTE)(255 - (255 - ptPixel->red)   * 0.9); 
					ptPixel->green = (BYTE)(255 - (255 - ptPixel->green) * 0.9); 
					ptPixel->blue  = (BYTE)(255 - (255 - ptPixel->blue)  * 0.9); 
				}

				//Alpha混合(Alpha blend)---------------------------
				if (bAlpha)
				{
					ptPixel->red   = (oldRed   * (255 - ptPixel->alpha) + ptPixel->red   * ptPixel->alpha) / 255; 
					ptPixel->green = (oldGreen * (255 - ptPixel->alpha) + ptPixel->green * ptPixel->alpha) / 255; 
					ptPixel->blue  = (oldBlue  * (255 - ptPixel->alpha) + ptPixel->blue  * ptPixel->alpha) / 255; 
				}
			}
			ptPixel++;
        }

        SelectObject(DirectDC, oldObject);
        RetBmp = DirectBitmap;
    }
    // 釋放DC--------------------
    DeleteDC(DirectDC);
    DeleteDC(BufferDC);
 
	return RetBmp;
}

/*========================================================================
	說明:	用漸變色填充指定的矩形區域.
==========================================================================*/
void FillGradient(CDC *pDC, CRect rect, const COLORREF& StartColor, const COLORREF& EndColor, BOOL bHor)
{
	//繪制漸變色--------------------------------
	int r1 = GetRValue(StartColor);
	int g1 = GetGValue(StartColor);
	int b1 = GetBValue(StartColor);
	
	int r2 = GetRValue(EndColor);
	int g2 = GetGValue(EndColor);
	int b2 = GetBValue(EndColor);
	
	if (bHor)
	{
		float dr = ((float)(r2 - r1)) / (float)(rect.Width());
		float dg = ((float)(g2 - g1)) / (float)(rect.Width());
		float db = ((float)(b2 - b1)) / (float)(rect.Width());
		for (int i = rect.left; i < rect.right; i ++)
		{
			int r = r1 + (int)(dr*((float)(i - rect.left)));
			int g = g1 + (int)(dg*((float)(i - rect.left)));
			int b = b1 + (int)(db*((float)(i - rect.left)));
			CPen pen(PS_SOLID, 1, RGB(r, g, b));
			CPen *old = pDC->SelectObject(&pen);
			pDC->MoveTo(i, rect.top);
			pDC->LineTo(i, rect.bottom);
			pDC->SelectObject(old);
		}
	}
	else
	{
		float dr = ((float)(r2 - r1)) / (float)(rect.Height());
		float dg = ((float)(g2 - g1)) / (float)(rect.Height());
		float db = ((float)(b2 - b1)) / (float)(rect.Height());
		for (int i = rect.top; i < rect.bottom; i ++)
		{
			int r = r1 + (int)(dr*((float)(i - rect.top)));
			int g = g1 + (int)(dg*((float)(i - rect.top)));
			int b = b1 + (int)(db*((float)(i - rect.top)));
			CPen pen(PS_SOLID, 1, RGB(r, g, b));
			CPen *old = pDC->SelectObject(&pen);
			pDC->MoveTo(rect.left, i);
			pDC->LineTo(rect.right, i);
			pDC->SelectObject(old);
		}
	}
}

/*========================================================================
	說明:	在指定的矩形區域內繪制陰影.	
==========================================================================*/
void DrawShadow(CDC *pDC, CRect rect)
{
	COLORREF oldcolor = RGB(255, 255, 255);
	BYTE newValR, newValG, newValB;
	BYTE AlphaArray[] = {140, 170, 212, 240};
	BYTE AlphaArray2[] = {170, 205, 220, 240, 240, 250, 255};
	
	// 底部的陰影 -----------------------------------------
	int i, j;
	for (j = 0; j < 4; j++)
	{
		for (i = 6; i <= rect.right - 5; i++)
		{
			oldcolor = pDC->GetPixel(i, rect.bottom - (4 - j));
			newValR = GetRValue(oldcolor) * AlphaArray[j] / 255;  
			newValG = GetGValue(oldcolor) * AlphaArray[j] / 255;  
			newValB = GetBValue(oldcolor) * AlphaArray[j] / 255;  
			pDC->SetPixel(i, rect.bottom - (4 - j), RGB(newValR, newValG, newValB));
		}
	}
	
	// 右邊的陰影 -----------------------------------------
	for (i = 0; i < 4; i++)
	{
		for (j = 6; j <= rect.bottom - 5; j++)
		{
			oldcolor = pDC->GetPixel(rect.right - (4 - i), j);
			newValR = GetRValue(oldcolor) * AlphaArray[i] / 255;  
			newValG = GetGValue(oldcolor) * AlphaArray[i] / 255;  
			newValB = GetBValue(oldcolor) * AlphaArray[i] / 255;  
			pDC->SetPixel(rect.right - (4 - i), j, RGB(newValR, newValG, newValB));
		}
	}
	
	// 其他部位的陰影 --------------------------------------
	for (i = 0; i < 4; i++)
	{
		for (j = 0; j < 4; j++)
		{
			if ((i + j) > 6) break;
			BYTE alpha = AlphaArray2[i + j];
			oldcolor = pDC->GetPixel(rect.right - 4 + i, rect.bottom - 4 + j);
			newValR = GetRValue(oldcolor) * alpha / 255;  
			newValG = GetGValue(oldcolor) * alpha / 255;  
			newValB = GetBValue(oldcolor) * alpha / 255;  
			pDC->SetPixel(rect.right - 4 + i, rect.bottom - 4 + j, RGB(newValR, newValG, newValB));
			
			oldcolor = pDC->GetPixel(rect.right - 4 + i, rect.top + 5 - j);
			newValR = GetRValue(oldcolor) * alpha / 255;  
			newValG = GetGValue(oldcolor) * alpha / 255;  
			newValB = GetBValue(oldcolor) * alpha / 255;  
			pDC->SetPixel(rect.right - 4 + i, rect.top + 5 - j, RGB(newValR, newValG, newValB));
			
			oldcolor = pDC->GetPixel(rect.left - i + 5, rect.bottom - 4 + j);
			newValR = GetRValue(oldcolor) * alpha / 255;  
			newValG = GetGValue(oldcolor) * alpha / 255;  
			newValB = GetBValue(oldcolor) * alpha / 255;  
			pDC->SetPixel(rect.left - i + 5, rect.bottom - 4 + j, RGB(newValR, newValG, newValB));
		}
	}
}

CString GetPathText(CString strPathName)
{
	int count = strPathName.GetLength();
	for (int i = count - 1; i >= 0; i--)
	{
		if (strPathName[i] == '\\')
		{
			break;
		}
	}
	return strPathName.Left(i + 1);
}

CString GetFileName(CString strPathName)
{
	int count = strPathName.GetLength();
	for (int i = count - 1; i >= 0; i--)
	{
		if (strPathName[i] == '\\')
		{
			break;
		}
	}
	return strPathName.Right(count - i - 1);
}

CString GetExFileName(CString strPathName)
{
	int count = strPathName.GetLength();
	for (int i = count - 1; i >= 0; i--)
	{
		if (strPathName[i] == '\\')
		{
			return CString("");
		}
		else if (strPathName[i] == '.')
		{
			break;
		}
	}
	return strPathName.Right(count - i - 1);
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
狂野欧美性猛交blacked| 亚洲第一在线综合网站| 日韩欧美一级二级三级久久久| 成人av在线资源| av高清久久久| 91视频免费观看| 日本乱码高清不卡字幕| 色国产综合视频| 欧美性猛交xxxx乱大交退制版 | 亚洲一级片在线观看| 一区二区三区在线视频观看58| 成人免费在线视频观看| 亚洲永久免费视频| 天堂成人国产精品一区| 热久久国产精品| 国产一区二区精品久久| 成人晚上爱看视频| 色噜噜狠狠成人网p站| 欧美日韩一区二区三区免费看| 欧美人动与zoxxxx乱| 日韩天堂在线观看| 久久久久久久av麻豆果冻| 国产亚洲精品bt天堂精选| 国产精品成人免费在线| 亚洲资源中文字幕| 精品在线播放午夜| 丁香婷婷综合五月| 欧美色男人天堂| 欧美精品一区二区三区一线天视频 | 国产在线一区二区| eeuss影院一区二区三区| 欧美日韩大陆在线| 久久一区二区视频| 亚洲成人精品在线观看| 国产中文一区二区三区| 色老汉av一区二区三区| 久久老女人爱爱| 日韩精品欧美精品| 99视频国产精品| 精品裸体舞一区二区三区| 亚洲精品精品亚洲| 精东粉嫩av免费一区二区三区| 91久久香蕉国产日韩欧美9色| 欧美精品一区男女天堂| 午夜精品久久久久久久久久| 国产sm精品调教视频网站| 51精品久久久久久久蜜臀| 中文字幕制服丝袜一区二区三区| 免费看黄色91| 欧美日韩国产美| 亚洲美女区一区| 国产成人高清在线| 日韩一区二区免费在线观看| 一区二区三区在线视频免费 | 欧美日韩亚洲综合在线 | 久久精品亚洲精品国产欧美kt∨| 亚洲一区二区四区蜜桃| 成人v精品蜜桃久久一区| 日韩欧美国产麻豆| 天天综合色天天综合色h| 91国偷自产一区二区三区观看| 国产日韩视频一区二区三区| 蜜桃视频一区二区三区在线观看| 在线亚洲一区二区| 亚洲六月丁香色婷婷综合久久 | 亚洲成av人片一区二区| 91麻豆视频网站| 中文字幕佐山爱一区二区免费| 狠狠色丁香久久婷婷综合_中 | 欧美系列日韩一区| 一区二区高清免费观看影视大全| 91一区二区在线观看| 亚洲视频1区2区| 日本精品免费观看高清观看| 亚洲欧洲成人精品av97| 99re成人在线| 亚洲免费色视频| 欧美日韩在线精品一区二区三区激情| 亚洲精品一二三区| 欧美午夜寂寞影院| 日韩精品福利网| 精品久久久久久久久久久院品网| 蜜桃久久久久久| 欧美电视剧免费观看| 久久99深爱久久99精品| 国产欧美在线观看一区| 成人av小说网| 亚洲电影视频在线| 日韩一区二区三区精品视频| 激情深爱一区二区| 国产三级精品三级在线专区| 一本到不卡免费一区二区| 亚洲大片精品永久免费| 日韩欧美精品三级| 成人性生交大片免费看在线播放 | 91 com成人网| 国产精品一区二区不卡| 亚洲精品国产精华液| 69p69国产精品| 国产盗摄精品一区二区三区在线 | 亚洲3atv精品一区二区三区| 日韩女优av电影| av在线综合网| 日本午夜精品一区二区三区电影| 久久久蜜臀国产一区二区| 色综合久久久久综合99| 日本不卡不码高清免费观看| 国产清纯在线一区二区www| 97se亚洲国产综合在线| 美女视频黄 久久| 亚洲色图一区二区| 日韩视频永久免费| 91首页免费视频| 久久国产福利国产秒拍| 一区二区三区小说| 久久综合色综合88| 欧美日韩午夜在线| k8久久久一区二区三区| 精品影视av免费| 亚洲一区二区三区爽爽爽爽爽| 久久久精品一品道一区| 欧美日韩国产高清一区二区三区| 丰满白嫩尤物一区二区| 婷婷成人综合网| 一区二区三区四区视频精品免费| 精品国产一区二区精华| 在线播放视频一区| 色狠狠一区二区三区香蕉| 国产福利一区二区三区视频| 日韩电影在线观看网站| 一区二区成人在线| 中文字幕视频一区二区三区久| 日韩精品中文字幕一区二区三区| 欧美少妇一区二区| 91啪在线观看| 99国产精品国产精品久久| 国产精品888| 国产一区二区精品在线观看| 免费观看在线综合色| 天堂久久一区二区三区| 天天综合色天天综合| 午夜精品一区在线观看| 亚洲一区二区精品3399| 亚洲另类春色国产| 亚洲女同女同女同女同女同69| 国产精品乱码妇女bbbb| 中文字幕免费观看一区| 欧美国产97人人爽人人喊| 欧美激情在线看| 国产精品伦一区| 亚洲欧美日韩一区二区| 亚洲欧美日韩国产综合| 亚洲麻豆国产自偷在线| 亚洲一线二线三线视频| 亚洲一区二区三区在线看| 五月天精品一区二区三区| 调教+趴+乳夹+国产+精品| 免费人成在线不卡| 激情成人午夜视频| 国产suv精品一区二区三区| 成人av资源在线| 欧美系列在线观看| 91精品综合久久久久久| 26uuu精品一区二区| 国产日韩欧美麻豆| 亚洲女同ⅹxx女同tv| 午夜成人免费视频| 久久精品国产成人一区二区三区| 久久精品国产久精国产| 高清av一区二区| 一本一道综合狠狠老| 欧美精品xxxxbbbb| 久久久综合视频| 亚洲精品免费电影| 免费欧美在线视频| av亚洲精华国产精华| 精品污污网站免费看| 亚洲精品一区在线观看| 国产精品久久久久久久久果冻传媒| 亚洲婷婷综合色高清在线| 性做久久久久久免费观看| 狠狠色狠狠色综合日日91app| av中文字幕亚洲| 欧美一区二区三区思思人| 国产日韩在线不卡| 午夜欧美一区二区三区在线播放| 精品一区二区三区免费毛片爱| 99久久精品国产观看| 91精品国产综合久久精品| 国产网站一区二区三区| 亚洲高清免费观看| 不卡一区中文字幕| 日韩欧美美女一区二区三区| 亚洲日本乱码在线观看| 国内精品国产成人| 欧美男女性生活在线直播观看| 久久久不卡影院| 三级欧美在线一区| 色88888久久久久久影院按摩| 久久久久久久久久久久久女国产乱|