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

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

?? subclass.cpp

?? 酒店管理系統(tǒng)
?? CPP
字號(hào):
////////////////////////////////////////////////////////////////
// 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;
}


?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲欧美电影一区二区| 天天综合天天综合色| 欧美色视频在线| 国产主播一区二区三区| 亚洲成人av资源| 国产乱子轮精品视频| 一区av在线播放| 中文乱码免费一区二区| 欧美一级国产精品| 欧美综合视频在线观看| 成人激情校园春色| 国产一区二区三区综合| 日韩国产高清影视| 亚洲午夜视频在线观看| 中文字幕在线免费不卡| 久久免费偷拍视频| 欧美肥胖老妇做爰| 日本久久一区二区三区| 成人免费福利片| 国产98色在线|日韩| 久久不见久久见免费视频7| 午夜精品久久久久久久蜜桃app| 中文字幕制服丝袜一区二区三区| 精品国产乱码久久久久久老虎| 欧美日韩国产美| 欧美最猛性xxxxx直播| av中文一区二区三区| 国产麻豆欧美日韩一区| 久久精品99国产精品日本| 亚洲电影中文字幕在线观看| 亚洲色图欧洲色图婷婷| 亚洲国产成人在线| 久久精品一区八戒影视| 久久久影院官网| 欧美精品一区二区三区四区 | 国产一区在线看| 蜜臀av一区二区三区| 日韩在线观看一区二区| 亚洲成人一区二区在线观看| 亚洲综合一区二区三区| 一区二区三区久久| 亚洲精品成人在线| 亚洲一区二区三区在线播放| 亚洲自拍与偷拍| 亚洲午夜久久久久| 亚洲444eee在线观看| 亚洲国产日产av| 午夜电影一区二区| 日本午夜一区二区| 久久99精品久久只有精品| 激情综合色丁香一区二区| 国产在线一区观看| 国产成都精品91一区二区三| 成人app在线| 99r国产精品| 欧洲色大大久久| 制服丝袜在线91| 日韩免费高清视频| 国产日韩av一区| 中文字幕在线不卡视频| 一区二区三区在线播| 日韩黄色片在线观看| 麻豆国产欧美一区二区三区| 国产一区二区不卡老阿姨| www.亚洲色图| 欧美精品一二三四| 91精品国产全国免费观看| 精品伦理精品一区| 国产欧美日韩在线| 一区二区三区在线观看视频| 五月婷婷久久综合| 国产麻豆精品在线观看| 91同城在线观看| 91精品国产品国语在线不卡| 国产三级三级三级精品8ⅰ区| 亚洲桃色在线一区| 蜜臀久久久99精品久久久久久| 国产成人欧美日韩在线电影| 91尤物视频在线观看| 在线综合亚洲欧美在线视频| 久久精品视频在线免费观看| 亚洲靠逼com| 久热成人在线视频| 国产日韩在线不卡| 亚洲成人动漫av| 高清日韩电视剧大全免费| 在线欧美日韩国产| 久久麻豆一区二区| 亚洲成a人片在线观看中文| 国产一区二区美女| 欧美日韩国产不卡| 中文字幕不卡在线观看| 日韩综合小视频| av在线一区二区三区| 日韩午夜激情电影| 一区二区在线免费观看| 国模冰冰炮一区二区| 在线免费观看日本一区| 精品va天堂亚洲国产| 一区二区三区成人| 国产寡妇亲子伦一区二区| 欧美日韩精品一区二区三区蜜桃| 国产日产欧美一区二区视频| 亚洲一区二区欧美激情| 国产精品 日产精品 欧美精品| 欧美日韩国产一二三| 亚洲欧洲日韩女同| 国产在线精品免费| 欧美日韩高清影院| 亚洲欧美中日韩| 国产二区国产一区在线观看| 欧美一级在线视频| 亚洲高清免费在线| 99精品久久免费看蜜臀剧情介绍| 日韩精品一区二区三区蜜臀 | 国内国产精品久久| 欧美二区在线观看| 一区二区三区四区在线免费观看| 国产高清不卡一区二区| 欧美zozo另类异族| 日产国产欧美视频一区精品 | 日韩精品中文字幕在线不卡尤物| 一级日本不卡的影视| 99久久精品久久久久久清纯| 久久精品亚洲精品国产欧美| 黄色小说综合网站| 欧美r级电影在线观看| 免费欧美高清视频| 91麻豆精品91久久久久久清纯| 亚洲一区二区在线视频| 91毛片在线观看| 亚洲视频免费在线观看| av在线播放不卡| 中文字幕欧美一区| av在线不卡电影| 亚洲天堂免费在线观看视频| 99精品视频一区二区三区| 综合久久综合久久| 91在线观看视频| 亚洲一级二级三级| 欧美精品第一页| 日韩国产欧美三级| 日韩精品一区二| 国产自产2019最新不卡| 国产欧美日韩另类视频免费观看| 国产电影一区在线| 国产精品白丝在线| 91麻豆精品一区二区三区| 一区二区三区在线免费视频| 欧美四级电影网| 日韩中文字幕一区二区三区| 欧美电影免费观看高清完整版| 九九热在线视频观看这里只有精品| 欧美电影免费观看高清完整版在 | 亚洲精品视频在线观看网站| 91福利区一区二区三区| 婷婷成人综合网| 欧美成人官网二区| 国产精品456| 日韩伦理av电影| 欧美色手机在线观看| 蜜臀av一区二区三区| 国产视频亚洲色图| 色综合久久88色综合天天6| 亚洲韩国一区二区三区| 欧美一二三区精品| 国产精品香蕉一区二区三区| 中文字幕在线不卡| 欧美日韩亚州综合| 韩国在线一区二区| 136国产福利精品导航| 欧美日本一区二区在线观看| 国产一区二区三区精品视频| 亚洲三级在线看| 日韩午夜精品视频| 成人精品高清在线| 日韩av中文在线观看| 人人超碰91尤物精品国产| 国产欧美日韩另类一区| 欧美麻豆精品久久久久久| 国产精品91一区二区| 亚洲综合激情小说| 久久一区二区视频| 色婷婷狠狠综合| 久久99国产精品久久| 亚洲三级免费电影| 精品欧美一区二区在线观看| eeuss鲁片一区二区三区在线观看 eeuss鲁片一区二区三区在线看 | 国产精品一区专区| 亚洲一区av在线| 国产亚洲一区二区在线观看| 欧美视频一区二区三区在线观看| 国产乱码精品1区2区3区| 亚洲一二三四在线| 中文字幕不卡在线播放| 日韩一二在线观看| 91在线porny国产在线看| 韩国在线一区二区| 亚洲va韩国va欧美va| 国产精品国产三级国产aⅴ原创 |