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

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

?? subclass.cpp

?? 利用c++制作的酒店管理系統
?? CPP
字號:
////////////////////////////////////////////////////////////////
// VCKBASE -- August 2000
// Compiles with Visual C++ 6.0, runs on Windows 98 and probably NT too.
//
// CSubclassWnd is a generic class for hooking another window's messages.

#include "StdAfx.h"
#include "Subclass.h"

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

//////////////////
// The message hook map is derived from CMapPtrToPtr, which associates
// a pointer with another pointer. It maps an HWND to a CSubclassWnd, like
// the way MFC's internal maps map HWND's to CWnd's. The first CSubclassWnd
// attached to a window is stored in the map; all other CSubclassWnd's for that
// window are then chained via CSubclassWnd::m_pNext.
//
class CSubclassWndMap : private CMapPtrToPtr {
public:
	CSubclassWndMap();
	~CSubclassWndMap();
	static CSubclassWndMap& GetHookMap();
	void Add(HWND hwnd, CSubclassWnd* pSubclassWnd);
	void Remove(CSubclassWnd* pSubclassWnd);
	void RemoveAll(HWND hwnd);
	CSubclassWnd* Lookup(HWND hwnd);
};

// This trick is used so the hook map isn't
// instantiated until someone actually requests it.
//
#define	theHookMap	(CSubclassWndMap::GetHookMap())

IMPLEMENT_DYNAMIC(CSubclassWnd, CWnd);

CSubclassWnd::CSubclassWnd()
{
	m_pNext = NULL;
	m_pOldWndProc = NULL;	
	m_hWnd  = NULL;
}

CSubclassWnd::~CSubclassWnd()
{
	if (m_hWnd) 
		HookWindow((HWND)NULL);		// unhook window
}

//////////////////
// Hook a window.
// This installs a new window proc that directs messages to the CSubclassWnd.
// pWnd=NULL to remove.
//
BOOL CSubclassWnd::HookWindow(HWND hwnd)
{
	ASSERT_VALID(this);
	if (hwnd) {
		// Hook the window
		ASSERT(m_hWnd==NULL);
		ASSERT(::IsWindow(hwnd));
		theHookMap.Add(hwnd, this);			// Add to map of hooks

	} else if (m_hWnd) {
		// Unhook the window
		theHookMap.Remove(this);				// Remove from map
		m_pOldWndProc = NULL;
	}
	m_hWnd = hwnd;
	return TRUE;
}

//////////////////
// Window proc-like virtual function which specific CSubclassWnds will
// override to do stuff. Default passes the message to the next hook; 
// the last hook passes the message to the original window.
// You MUST call this at the end of your WindowProc if you want the real
// window to get the message. This is just like CWnd::WindowProc, except that
// a CSubclassWnd is not a window.
//
LRESULT CSubclassWnd::WindowProc(UINT msg, WPARAM wp, LPARAM lp)
{
//	ASSERT_VALID(this);  // removed for speed
	ASSERT(m_pOldWndProc);
	return m_pNext ? m_pNext->WindowProc(msg, wp, lp) :	
		::CallWindowProc(m_pOldWndProc, m_hWnd, msg, wp, lp);//AfxMessageBox("hello");
}

//////////////////
// Like calling base class WindowProc, but with no args, so individual
// message handlers can do the default thing. Like CWnd::Default
//
LRESULT CSubclassWnd::Default()
{
	// MFC stores current MSG in thread state
	MSG& curMsg = AfxGetThreadState()->m_lastSentMsg;
	// Note: must explicitly call CSubclassWnd::WindowProc to avoid infinte
	// recursion on virtual function
	return CSubclassWnd::WindowProc(curMsg.message, curMsg.wParam, curMsg.lParam);
}

#ifdef _DEBUG
void CSubclassWnd::AssertValid() const
{
	CObject::AssertValid();
	ASSERT(m_hWnd==NULL || ::IsWindow(m_hWnd));
	if (m_hWnd) {
		for (CSubclassWnd* p = theHookMap.Lookup(m_hWnd); p; p=p->m_pNext) {
			if (p==this)
				break;
		}
		ASSERT(p); // should have found it!
	}
}

void CSubclassWnd::Dump(CDumpContext& dc) const
{
	CObject::Dump(dc);
}

#endif

//////////////////
// Subclassed window proc for message hooks. Replaces AfxWndProc (or whatever
// else was there before.)
//
LRESULT CALLBACK
HookWndProc(HWND hwnd, UINT msg, WPARAM wp, LPARAM lp)
{
#ifdef _USRDLL
	// If this is a DLL, need to set up MFC state
	AFX_MANAGE_STATE(AfxGetStaticModuleState());
#endif

	// Set up MFC message state just in case anyone wants it
	// This is just like AfxCallWindowProc, but we can't use that because
	// a CSubclassWnd is not a CWnd.
	//
	MSG& curMsg = AfxGetThreadState()->m_lastSentMsg;
	MSG  oldMsg = curMsg;   // save for nesting
	curMsg.hwnd		= hwnd;
	curMsg.message = msg;
	curMsg.wParam  = wp;
	curMsg.lParam  = lp;

	// Get hook object for this window. Get from hook map
	CSubclassWnd* pSubclassWnd = theHookMap.Lookup(hwnd);
	ASSERT(pSubclassWnd);

	LRESULT lr;
	if (msg==WM_NCDESTROY) {
		// Window is being destroyed: unhook all hooks (for this window)
		// and pass msg to orginal window proc
		//
		WNDPROC wndproc = pSubclassWnd->m_pOldWndProc;
		theHookMap.RemoveAll(hwnd);
		lr = ::CallWindowProc(wndproc, hwnd, msg, wp, lp);

	} else {
		// pass to msg hook
		lr = pSubclassWnd->WindowProc(msg, wp, lp);
	}
	curMsg = oldMsg;			// pop state
//	AfxMessageBox("正在初始化!");
	return lr;
}

////////////////////////////////////////////////////////////////
// CSubclassWndMap implementation
//
CSubclassWndMap::CSubclassWndMap()
{
}

CSubclassWndMap::~CSubclassWndMap()
{
// This assert bombs when posting WM_QUIT, so I've deleted it.
//	ASSERT(IsEmpty());	// all hooks should be removed!	
}

//////////////////
// Get the one and only global hook map
// 
CSubclassWndMap& CSubclassWndMap::GetHookMap()
{
	// By creating theMap here, C++ doesn't instantiate it until/unless
	// it's ever used! This is a good trick to use in C++, to
	// instantiate/initialize a static object the first time it's used.
	//
	static CSubclassWndMap theMap;
	return theMap;
}

/////////////////
// Add hook to map; i.e., associate hook with window
//
void CSubclassWndMap::Add(HWND hwnd, CSubclassWnd* pSubclassWnd)
{
	ASSERT(hwnd && ::IsWindow(hwnd));

	// Add to front of list
		
	pSubclassWnd->m_pNext = Lookup(hwnd);
SetAt(hwnd, pSubclassWnd);
//	AfxMessageBox("Hello");
	if (pSubclassWnd->m_pNext==NULL) {
		// If this is the first hook added, subclass the window
		pSubclassWnd->m_pOldWndProc = 
			(WNDPROC)SetWindowLong(hwnd, GWL_WNDPROC, (DWORD)HookWndProc);

	} else {
		// just copy wndproc from next hook
		pSubclassWnd->m_pOldWndProc=pSubclassWnd->m_pNext->m_pOldWndProc;
	}
	ASSERT(pSubclassWnd->m_pOldWndProc);
}

//////////////////
// Remove hook from map
//
void CSubclassWndMap::Remove(CSubclassWnd* pUnHook)
{
	HWND hwnd = pUnHook->m_hWnd;
	ASSERT(hwnd && ::IsWindow(hwnd));

	CSubclassWnd* pHook = Lookup(hwnd);
	ASSERT(pHook);
	if (pHook==pUnHook) {
		// hook to remove is the one in the hash table: replace w/next
		if (pHook->m_pNext)
			SetAt(hwnd, pHook->m_pNext);
		else {
			// This is the last hook for this window: restore wnd proc
			RemoveKey(hwnd);
			SetWindowLong(hwnd, GWL_WNDPROC, (DWORD)pHook->m_pOldWndProc);
		}
	} else {
		// Hook to remove is in the middle: just remove from linked list
		while (pHook->m_pNext!=pUnHook)
			pHook = pHook->m_pNext;
		ASSERT(pHook && pHook->m_pNext==pUnHook);
		pHook->m_pNext = pUnHook->m_pNext;
	}
}

//////////////////
// Remove all the hooks for a window
//
void CSubclassWndMap::RemoveAll(HWND hwnd)
{
	CSubclassWnd* pSubclassWnd;
	while ((pSubclassWnd = Lookup(hwnd))!=NULL)
		pSubclassWnd->HookWindow((HWND)NULL);	// (unhook)
}

/////////////////
// Find first hook associate with window
//
CSubclassWnd* CSubclassWndMap::Lookup(HWND hwnd)
{
	CSubclassWnd* pFound = NULL;
	if (!CMapPtrToPtr::Lookup(hwnd, (void*&)pFound))
		return NULL;
	ASSERT_KINDOF(CSubclassWnd, pFound);
	return pFound;
}


?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产欧美精品一区| 久久精品国产亚洲a| 香蕉影视欧美成人| 丰满少妇久久久久久久| 欧美无乱码久久久免费午夜一区| 久久精品网站免费观看| 婷婷久久综合九色综合绿巨人 | 色偷偷成人一区二区三区91| 日韩写真欧美这视频| 亚洲美女在线一区| 成人国产电影网| 精品国产麻豆免费人成网站| 亚洲福利国产精品| av不卡一区二区三区| 国产亚洲欧美激情| 蜜臀av性久久久久av蜜臀妖精| 97久久超碰国产精品电影| 久久九九久久九九| 久久www免费人成看片高清| 欧美系列一区二区| 亚洲视频一二三区| 不卡电影免费在线播放一区| 国产人成一区二区三区影院| 国产精品99久久久久久宅男| 69堂精品视频| 视频一区视频二区在线观看| 在线观看日韩电影| 亚洲永久精品国产| 欧美中文字幕亚洲一区二区va在线 | 九色|91porny| 日韩欧美国产成人一区二区| 日韩和的一区二区| 91精品国产91久久综合桃花 | 精品国产一二三| 国产在线不卡一区| 久久久精品2019中文字幕之3| 国内精品久久久久影院一蜜桃| 精品国产亚洲在线| 国产精品系列在线播放| 国产精品麻豆欧美日韩ww| 成人高清免费在线播放| 亚洲视频图片小说| 欧美在线播放高清精品| 亚洲成人www| 精品对白一区国产伦| 国产精品亚洲а∨天堂免在线| 国产欧美日韩视频在线观看| 99久久精品国产一区| 一区二区三区在线免费视频| 欧美久久久影院| 精品写真视频在线观看| 国产精品欧美一区二区三区| 91丨九色丨蝌蚪丨老版| 天堂资源在线中文精品| 欧美大片一区二区| 成人av资源下载| 亚洲大尺度视频在线观看| 日韩免费观看高清完整版 | 中文字幕乱码久久午夜不卡| 91蝌蚪porny| 蜜桃久久久久久| 中文字幕精品在线不卡| 欧美综合一区二区| 国产在线观看免费一区| 亚洲一区二区三区在线| 久久综合成人精品亚洲另类欧美| 91年精品国产| 激情欧美一区二区| 亚洲精品欧美综合四区| 日韩欧美亚洲一区二区| 不卡影院免费观看| 免费日本视频一区| 亚洲欧美区自拍先锋| 日韩欧美视频在线| 色婷婷精品久久二区二区蜜臀av| 免费不卡在线观看| 亚洲自拍偷拍麻豆| 久久精品一区二区三区不卡| 国产喷白浆一区二区三区| 色综合色狠狠综合色| 经典三级一区二区| 亚洲国产精品久久人人爱| 国产免费成人在线视频| 91精品国产综合久久婷婷香蕉| 波多野洁衣一区| 久久99精品国产麻豆婷婷洗澡| 亚洲已满18点击进入久久| 国产欧美精品一区aⅴ影院| 91精品国产综合久久久久久久| 成人精品免费网站| 国产真实乱对白精彩久久| 调教+趴+乳夹+国产+精品| 亚洲少妇最新在线视频| 亚洲国产成人自拍| 欧美电影免费观看完整版| 欧美日韩国产高清一区| 色噜噜夜夜夜综合网| 成人一级黄色片| 国产又粗又猛又爽又黄91精品| 日韩精品三区四区| 亚洲最新在线观看| 亚洲午夜久久久| 一区二区三区四区高清精品免费观看 | 中文字幕一区免费在线观看| 久久综合成人精品亚洲另类欧美| 欧美一二三四在线| 5858s免费视频成人| 欧美日韩国产首页| 欧美美女一区二区在线观看| 欧美色精品天天在线观看视频| 色菇凉天天综合网| 91搞黄在线观看| 欧美在线观看禁18| 欧美日韩一区二区三区四区| 在线91免费看| 7777精品伊人久久久大香线蕉的 | 国产精品久久久久久久第一福利 | 色哟哟精品一区| 欧美做爰猛烈大尺度电影无法无天| 99久久精品一区二区| 91老师国产黑色丝袜在线| 色婷婷综合激情| 91麻豆精品国产91久久久久| 欧美v日韩v国产v| 久久影视一区二区| 亚洲国产成人私人影院tom| 国产精品乱码久久久久久| 亚洲人xxxx| 丝袜国产日韩另类美女| 精品无人码麻豆乱码1区2区| 国产成人精品免费在线| 99精品国产视频| 3atv在线一区二区三区| 欧美成人r级一区二区三区| 久久亚洲一级片| 国产精品成人免费精品自在线观看 | 国产午夜精品久久久久久免费视 | 国产精品午夜在线观看| 亚洲蜜臀av乱码久久精品蜜桃| 国产乱码精品一区二区三| jvid福利写真一区二区三区| 欧洲色大大久久| 精品少妇一区二区三区 | 亚洲精品一区二区三区福利| 日本一区二区三区视频视频| 一区二区三区欧美日| 免费成人在线观看| 成人99免费视频| 日韩视频一区二区三区在线播放| 国产精品色哟哟网站| 丝袜美腿亚洲一区| 国产999精品久久| 欧美丰满嫩嫩电影| 中文字幕第一页久久| 午夜影院久久久| 丁香另类激情小说| 欧美精品18+| 国产精品每日更新| 日本网站在线观看一区二区三区| 国产suv精品一区二区三区| 欧美在线看片a免费观看| 国产亚洲一区二区三区| 午夜精品aaa| 成年人午夜久久久| 精品99999| 亚洲丰满少妇videoshd| 成人高清在线视频| 久久久久久久性| 日韩精品视频网站| 欧美亚洲动漫精品| 国产精品久久久久久久久久久免费看 | 国产成人精品一区二| 欧美日韩高清不卡| 国产精品福利一区二区三区| 久久99热99| 91精品国产综合久久久久久久久久| 亚洲欧美日韩一区二区| 国产91在线观看丝袜| 精品国产一二三| 精品在线播放午夜| 91精品国产综合久久福利| 亚洲一区二区不卡免费| 99热这里都是精品| 国产精品网友自拍| 黄色小说综合网站| 精品少妇一区二区三区| 免费观看久久久4p| 6080亚洲精品一区二区| 丝瓜av网站精品一区二区| 在线亚洲+欧美+日本专区| 亚洲欧美日韩中文播放| 成人激情小说乱人伦| 久久精品人人爽人人爽| 久久99精品一区二区三区| 欧美videofree性高清杂交| 轻轻草成人在线| 日韩欧美亚洲国产精品字幕久久久 | 亚洲1区2区3区4区| 欧美日韩亚洲综合一区二区三区| 亚洲一区在线电影|