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

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

?? subclass.cpp

?? 注冊熱鍵
?? CPP
字號:
////////////////////////////////////////////////////////////////
// PixieLib(TM) Copyright 1997-1999 Paul DiLascia
// If this code works, it was written by Paul DiLascia.
// If not, I don't know who wrote it.
//
// 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);
}

//////////////////
// 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
	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);
	
	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一区二区三区免费野_久草精品视频
国产精品一区二区三区乱码| 欧美日韩在线直播| 91久久一区二区| 日韩午夜在线观看视频| 亚洲精品成人在线| 国产成人在线视频播放| 欧美一级一区二区| 亚洲第一av色| 99久久er热在这里只有精品15 | 日韩精品中文字幕在线一区| 中文字幕不卡的av| 精品在线一区二区| 日韩西西人体444www| 婷婷久久综合九色综合绿巨人| 91丨九色丨国产丨porny| 国产婷婷色一区二区三区| 另类小说色综合网站| 欧美精品 日韩| 亚洲成av人综合在线观看| 在线亚洲一区二区| 亚洲天堂a在线| 91蝌蚪国产九色| 日韩毛片在线免费观看| 成人app网站| ...av二区三区久久精品| av影院午夜一区| 成人欧美一区二区三区黑人麻豆| 成人精品一区二区三区四区| 国产区在线观看成人精品| 国产一区二区精品在线观看| 精品国产乱码91久久久久久网站| 蜜桃精品在线观看| 2023国产一二三区日本精品2022| 精品在线你懂的| 亚洲精品一区二区三区福利| 久久99精品久久久久久| 久久久另类综合| 成人福利在线看| 伊人婷婷欧美激情| 欧美日韩一区二区不卡| 美腿丝袜在线亚洲一区| 久久欧美中文字幕| 99久久免费视频.com| 亚洲男人天堂av| 欧美理论在线播放| 国内精品视频一区二区三区八戒| 国产亚洲欧美日韩在线一区| 风间由美一区二区三区在线观看| 亚洲素人一区二区| 欧美老年两性高潮| 国产成人在线影院| 一区二区三区在线看| 91精品国产高清一区二区三区蜜臀| 麻豆久久久久久久| 亚洲天堂av老司机| 91精品国产aⅴ一区二区| 国产精选一区二区三区| 亚洲精品欧美激情| 日韩精品在线看片z| 9l国产精品久久久久麻豆| 婷婷中文字幕一区三区| 久久综合中文字幕| 色吊一区二区三区| 久久er99精品| 亚洲精品视频免费观看| 日韩视频国产视频| 色综合一区二区| 国产自产v一区二区三区c| 亚洲色图在线看| 精品国精品国产| 欧美视频一区二区三区| 国产一区二区精品久久99| 亚洲午夜成aⅴ人片| 久久久久9999亚洲精品| 欧美日韩精品一区二区| 成人性生交大片免费看中文| 日韩精彩视频在线观看| 成人免费在线视频| 精品国产髙清在线看国产毛片| 91浏览器在线视频| 国产成人av网站| 麻豆精品一二三| 一区二区三区在线高清| 国产精品女同互慰在线看| 日韩欧美高清一区| 欧美日韩成人综合在线一区二区| 成人美女视频在线观看| 麻豆成人av在线| 午夜电影久久久| 亚洲精品成人少妇| 国产精品久久久久一区二区三区共| 91精品国产综合久久久久久漫画| 99精品视频在线观看免费| 懂色av中文字幕一区二区三区 | www.欧美日韩国产在线| 国产自产2019最新不卡| 美腿丝袜亚洲综合| 天堂午夜影视日韩欧美一区二区| 一区二区三区在线免费视频| 中文字幕一区二区三区视频| 中文字幕二三区不卡| 久久亚洲影视婷婷| 精品91自产拍在线观看一区| 7777女厕盗摄久久久| 欧美精品成人一区二区三区四区| 在线观看欧美黄色| 色综合久久99| 在线观看免费成人| 在线观看国产日韩| 欧美三级资源在线| 欧美肥妇bbw| 91.xcao| 欧美一区二区不卡视频| 日韩欧美高清一区| 久久先锋资源网| 久久久久久久久蜜桃| 国产亚洲一区二区三区四区| 久久精品视频一区二区三区| 久久精品亚洲精品国产欧美kt∨ | 一片黄亚洲嫩模| 夜夜夜精品看看| 视频在线在亚洲| 青青草97国产精品免费观看| 麻豆精品精品国产自在97香蕉| 美女视频一区二区三区| 国产尤物一区二区| 成人小视频在线观看| 91天堂素人约啪| 91麻豆精品国产综合久久久久久| 欧美一区二区三区免费大片 | 亚洲一区二区三区视频在线 | 久久综合九色综合久久久精品综合| 精品福利视频一区二区三区| 国产清纯白嫩初高生在线观看91 | 亚洲色图自拍偷拍美腿丝袜制服诱惑麻豆 | 91精品国产综合久久福利| 日韩欧美一级二级| 欧美激情在线观看视频免费| 亚洲欧美一区二区三区极速播放| 亚洲成av人在线观看| 国产在线视视频有精品| 波多野结衣在线一区| 欧美这里有精品| 精品欧美一区二区久久| 国产精品麻豆网站| 亚洲第一电影网| 国产一区二区三区不卡在线观看| www.视频一区| 在线播放日韩导航| 国产午夜精品在线观看| 亚洲国产视频一区二区| 国产一区二区精品在线观看| 91国产免费观看| 国产亚洲美州欧州综合国| 亚洲成人高清在线| 成人黄色大片在线观看| 8x8x8国产精品| 亚洲欧美日韩国产一区二区三区| 日韩国产精品久久久| 成人午夜又粗又硬又大| 日韩一级片网址| 亚洲综合成人在线| 粉嫩久久99精品久久久久久夜| 91国偷自产一区二区使用方法| 国产午夜精品久久| 蜜臀av一区二区三区| 日本道在线观看一区二区| 国产女人18毛片水真多成人如厕| 天天av天天翘天天综合网 | 日本精品裸体写真集在线观看 | 亚洲欧美另类久久久精品2019| 日韩av在线免费观看不卡| 色综合久久久久综合| 国产视频在线观看一区二区三区| 日本午夜一区二区| 欧美自拍丝袜亚洲| 1024精品合集| k8久久久一区二区三区| 久久久久九九视频| 久久疯狂做爰流白浆xx| 91精品国产91久久久久久最新毛片| 亚洲人成伊人成综合网小说| 国产91精品久久久久久久网曝门| 欧美刺激脚交jootjob| 日韩精品国产精品| 555www色欧美视频| 日韩激情在线观看| 91精品国产综合久久久久久久久久| 亚洲一区影音先锋| 色狠狠一区二区| 亚洲精品高清在线| 91老师国产黑色丝袜在线| 中文字幕五月欧美| 色呦呦网站一区| 一区二区三区精品视频在线| 色视频成人在线观看免| 亚洲精品国产无天堂网2021 | 亚洲在线免费播放| 欧美日韩在线精品一区二区三区激情| 亚洲色欲色欲www在线观看|