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

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

?? subclass.cpp

?? 一個(gè)VC寫(xiě)的酒店管理系統(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一区二区三区免费野_久草精品视频
精品国产一区a| 日韩精品中文字幕一区 | 国产偷国产偷亚洲高清人白洁| 成人看片黄a免费看在线| 天天做天天摸天天爽国产一区| 久久丝袜美腿综合| 欧美日韩在线直播| 波多野结衣中文字幕一区二区三区 | 精品va天堂亚洲国产| 一道本成人在线| 国产一区二区三区四| 亚洲福利一区二区三区| 国产精品久久夜| 精品国产凹凸成av人导航| 欧美日韩一区二区在线视频| 99久久伊人精品| 国产成人综合视频| 久久疯狂做爰流白浆xx| 亚洲国产一区在线观看| 亚洲少妇30p| 中文字幕一区二区三区视频| 亚洲精品一区在线观看| 欧美一区二区网站| 欧美三级电影网站| 欧美性一二三区| 一本大道久久a久久精二百| 国产a视频精品免费观看| 精彩视频一区二区| 麻豆中文一区二区| 一本久久综合亚洲鲁鲁五月天| 国产高清不卡二三区| 国内精品久久久久影院色| 麻豆免费精品视频| 麻豆精品一二三| 免费观看日韩av| 免费一级欧美片在线观看| 日韩不卡免费视频| 日韩影院在线观看| 舔着乳尖日韩一区| 日韩中文字幕区一区有砖一区| 亚洲一区二区中文在线| 一区二区三区产品免费精品久久75| 国产精品久久久久久久久免费丝袜| 久久久久亚洲蜜桃| 久久久99免费| 国产精品婷婷午夜在线观看| 欧美国产日韩亚洲一区| 欧美激情一区不卡| 国产精品美女一区二区三区| 日本一区免费视频| 亚洲欧洲美洲综合色网| 亚洲黄色av一区| 亚洲午夜精品网| 日韩av电影免费观看高清完整版在线观看| 亚洲线精品一区二区三区| 亚洲国产成人tv| 蜜桃精品视频在线| 高清在线成人网| 91亚洲午夜精品久久久久久| 在线一区二区视频| 欧美老人xxxx18| 精品少妇一区二区三区| 久久草av在线| 国产风韵犹存在线视精品| www.在线欧美| 欧美视频日韩视频| 日韩免费观看2025年上映的电影| 精品国产成人在线影院 | 日韩三级免费观看| 久久精品男人天堂av| 国产精品久久久久久久久久久免费看| 亚洲视频香蕉人妖| 日本三级韩国三级欧美三级| 激情五月播播久久久精品| 波多野结衣的一区二区三区| 欧美三级午夜理伦三级中视频| 日韩欧美一区在线| 国产精品毛片久久久久久久| 亚洲午夜av在线| 韩国成人在线视频| 一本在线高清不卡dvd| 91精品国产综合久久精品app| 国产亚洲一区二区三区四区| 亚洲一区在线观看免费 | 97se亚洲国产综合自在线| 精品视频一区三区九区| 久久影视一区二区| 亚洲视频在线一区观看| 青椒成人免费视频| 99精品国产视频| 欧美成人性战久久| 亚洲精品中文字幕在线观看| 奇米影视一区二区三区小说| 成人av在线电影| 91精品啪在线观看国产60岁| 国产精品网友自拍| 蜜臀91精品一区二区三区| www.亚洲国产| 精品奇米国产一区二区三区| 亚洲一区二区在线视频| 国产一区二区按摩在线观看| 欧美三级中文字幕在线观看| 国产欧美日韩一区二区三区在线观看| 亚洲图片欧美一区| gogo大胆日本视频一区| 欧美成人国产一区二区| 一区二区三区资源| 成人久久久精品乱码一区二区三区| 56国语精品自产拍在线观看| 一区二区三区在线播| 国产精品亚洲专一区二区三区| 欧美日本精品一区二区三区| 亚洲天堂免费看| 国产精品99久久久久久似苏梦涵| 欧美日本在线看| 亚洲综合免费观看高清完整版在线 | av成人老司机| 久久久久国产精品人| 日本大胆欧美人术艺术动态| 欧美日韩中文另类| 亚洲综合999| 91香蕉视频在线| 国产精品久久久久久久第一福利| 国产乱码精品一品二品| 精品女同一区二区| 蜜臀av一区二区三区| 欧美老女人第四色| 天天操天天色综合| 欧美人妖巨大在线| 亚洲444eee在线观看| 色88888久久久久久影院按摩 | 中文字幕一区二区三区不卡| 精品一区二区免费视频| 日韩视频国产视频| 美女性感视频久久| 日韩午夜在线观看视频| 青青草国产成人av片免费| 欧美一区二区女人| 青草av.久久免费一区| 欧美一级生活片| 九九视频精品免费| 久久久.com| 成人自拍视频在线观看| 国产精品久久三| 色噜噜狠狠成人网p站| 怡红院av一区二区三区| 欧美性色黄大片| 日韩国产成人精品| 欧美va亚洲va香蕉在线| 国内久久婷婷综合| 国产人伦精品一区二区| 9人人澡人人爽人人精品| 日韩美女精品在线| 精品视频1区2区| 蜜臀av一区二区| 国产偷国产偷精品高清尤物 | 日韩一区二区三免费高清| 美女脱光内衣内裤视频久久网站 | 欧美色图片你懂的| 日本不卡视频在线观看| 久久嫩草精品久久久精品一| 欧美精品一区二区三区在线播放| 蜜臀av性久久久久蜜臀av麻豆| www国产精品av| www.综合网.com| 丝袜美腿亚洲色图| 欧美精品一区二区三区蜜桃 | 亚洲成人av在线电影| 日韩欧美资源站| 成人国产视频在线观看 | 开心九九激情九九欧美日韩精美视频电影 | 亚洲主播在线播放| 91精品国产综合久久小美女| 国产乱人伦精品一区二区在线观看 | 精品视频在线免费看| 国内不卡的二区三区中文字幕| 国产精品国产自产拍高清av| 欧美三级资源在线| 国产伦精品一区二区三区免费| 国产精品久久久久久久久免费丝袜| 欧美日韩一二三区| 国产精品一区二区三区乱码| 夜夜精品视频一区二区| 精品国产sm最大网站| 91极品视觉盛宴| 韩国精品免费视频| 亚洲高清视频的网址| 国产亚洲一本大道中文在线| 欧美日韩在线不卡| 成人自拍视频在线| 日韩不卡一区二区| 亚洲你懂的在线视频| 精品国产伦一区二区三区观看方式| 99v久久综合狠狠综合久久| 蜜臀av性久久久久蜜臀aⅴ| 亚洲免费av网站| 日本一区二区三区在线观看| 欧美精品久久久久久久多人混战 | 91麻豆国产福利在线观看| 韩国午夜理伦三级不卡影院|