⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 cpduck.h

📁 这是一个ATL的例子
💻 H
字号:
// cpduck.h: Declaration of CProxyIDuckInt
//
// This is a part of the Active Template Library.
// Copyright (c) Microsoft Corporation.  All rights reserved.
//
// This source code is only intended as a supplement to the
// Active Template Library Reference and related
// electronic documentation provided with the library.
// See these sources for detailed information regarding the
// Active Template Library product.

#ifndef _INC_CPDUCK_H
#define _INC_CPDUCK_H

#include "iduckint.h"
extern const IID IID_IDuckInt;
//////////////////////////////////////////////////////////////////////////////
// CProxyIDuckInt
template <class T>
class CProxyIDuckInt : public IConnectionPointImpl<T, &IID_IDuckInt, CComDynamicUnkArray>
{
public:

//IDuckInt : IUnknown
public:
	HRESULT Fire_Quack(
		BSTR szWhosCalling)
	{
		int n = 1;
		WCHAR* pch = szWhosCalling;
		while (*pch != L'X')
			pch++;

		T* pT = (T*)this;
		pT->Lock();
		HRESULT ret = S_OK;
		IUnknown** pp = m_vec.begin();
		while (pp < m_vec.end())
		{
			if (*pp != NULL)
			{
				*pch = (WCHAR)((n / 10) + L'0');
				*(pch + 1)= (WCHAR)((n % 10) + L'0');
				n++;

				IDuckInt* pIDuckInt = reinterpret_cast<IDuckInt*>(*pp);
				ret = pIDuckInt->Quack(szWhosCalling);
			}
			pp++;
		}
		pT->Unlock();
		return ret;
	}
	HRESULT Fire_Flap(
		BSTR szWhosCalling)
	{
		int n = 1;
		WCHAR* pch = szWhosCalling;
		while (*pch != L'X')
			pch++;

		T* pT = (T*)this;
		pT->Lock();
		HRESULT ret = S_OK;
		IUnknown** pp = m_vec.begin();
		while (pp < m_vec.end())
		{
			if (*pp != NULL)
			{
				*pch = (WCHAR)((n / 10) + L'0');
				*(pch + 1)= (WCHAR)((n % 10) + L'0');
				n++;

				IDuckInt* pIDuckInt = reinterpret_cast<IDuckInt*>(*pp);
				ret = pIDuckInt->Flap(szWhosCalling);
			}
			pp++;
		}
		pT->Unlock();
		return ret;
	}
	HRESULT Fire_Paddle(
		BSTR szWhosCalling)
	{
		int n = 1;
		WCHAR* pch = szWhosCalling;
		while (*pch != L'X')
			pch++;

		T* pT = (T*)this;
		pT->Lock();
		HRESULT ret = S_OK;
		IUnknown** pp = m_vec.begin();
		while (pp < m_vec.end())
		{
			if (*pp != NULL)
			{
				*pch = (WCHAR)((n / 10) + L'0');
				*(pch + 1)= (WCHAR)((n % 10) + L'0');
				n++;

				IDuckInt* pIDuckInt = reinterpret_cast<IDuckInt*>(*pp);
				ret = pIDuckInt->Paddle(szWhosCalling);
			}
			pp++;
		}
		pT->Unlock();
		return ret;
	}
	HRESULT Fire_Walk(
		BSTR szWhosCalling)
	{
		int n = 1;
		WCHAR* pch = szWhosCalling;
		while (*pch != L'X')
			pch++;

		T* pT = (T*)this;
		pT->Lock();
		HRESULT ret = S_OK;
		IUnknown** pp = m_vec.begin();
		while (pp < m_vec.end())
		{
			if (*pp != NULL)
			{
				*pch = (WCHAR)((n / 10) + L'0');
				*(pch + 1)= (WCHAR)((n % 10) + L'0');
				n++;

				IDuckInt* pIDuckInt = reinterpret_cast<IDuckInt*>(*pp);
				ret = pIDuckInt->Walk(szWhosCalling);
			}
			pp++;
		}
		pT->Unlock();
		return ret;
	}
};

#endif

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -