win32comdataobject.h
来自「这是VCF框架的代码」· C头文件 代码 · 共 382 行
H
382 行
#ifndef _VCF_COMDATAOBJECT_H__#define _VCF_COMDATAOBJECT_H__//COMDataObject.h/*Copyright 2000-2004 The VCF Project.Please see License.txt in the top level directorywhere you installed the VCF.*/#if _MSC_VER > 1000# pragma once#endif/* Generated by Together */#ifndef _VCF_ENUMOBJECT_H__#include "vcf/ApplicationKit/EnumObject.h"#endif // _VCF_ENUMOBJECT_H__namespace VCFCOM{/** * base implementation of IDataObject */class DataRendering : public VCF::Object{public: DataRendering(); DataRendering( FORMATETC * formatETC, STGMEDIUM * stgMedium, IUnknown* newStorageOwner ); virtual ~DataRendering(); DataRendering( const DataRendering& rhs ) { *this = rhs; } FORMATETC formatETC_; STGMEDIUM storage_; IUnknown* owner_; bool isEmpty() { return formatETC_.cfFormat == 0 && formatETC_.dwAspect == 0 && formatETC_.tymed == 0 && storage_.tymed == 0 && storage_.hGlobal == 0 && owner_ == NULL; } virtual VCF::String toString(); DataRendering& operator= (const DataRendering& rhs ) { memcpy( &formatETC_, &rhs.formatETC_, sizeof(formatETC_) ); memcpy( &storage_, &rhs.storage_, sizeof(storage_) ); owner_ = rhs.owner_; return *this; } bool operator == ( const DataRendering& dataRenderToCompare )const { bool result = false; result = ( (formatETC_.cfFormat == dataRenderToCompare.formatETC_.cfFormat) && (formatETC_.dwAspect == dataRenderToCompare.formatETC_.dwAspect) && (formatETC_.tymed == dataRenderToCompare.formatETC_.tymed) ); return result; }; bool operator == ( const FORMATETC& formatETCToCompare )const { bool result = false; result = ( (formatETC_.cfFormat == formatETCToCompare.cfFormat) && (formatETC_.dwAspect == formatETCToCompare.dwAspect) && (formatETC_.tymed == formatETCToCompare.tymed) ); return result; };};/***This class implements IDataObject directly but also uses a member variable*taht can point to a reference to some already existing IDataObject instance*/class COMDataObject : public IDataObject {public: COMDataObject( IDataObject* outerDataObject=NULL ); virtual ~COMDataObject(); virtual HRESULT STDMETHODCALLTYPE QueryInterface(REFIID iid, void** ppvObj) { if ( iid == IID_IUnknown ) { *ppvObj = (IUnknown*)(this); ((IUnknown*)(*ppvObj))->AddRef(); return S_OK; } else if ( iid == IID_IDataObject ) { *ppvObj = (IDataObject*)(this); ((IUnknown*)(*ppvObj))->AddRef(); return S_OK; } return E_NOINTERFACE; } virtual ULONG STDMETHODCALLTYPE AddRef(void) { ref_ ++; return ref_; } virtual ULONG STDMETHODCALLTYPE Release(void) { if ( ref_ > 0 ) { ref_ --; } if ( 0 == ref_ ) { delete this; return 0; } return ref_; } STDMETHOD(GetData)( FORMATETC * formatETC, STGMEDIUM * stgMedium ); STDMETHOD(GetDataHere)( FORMATETC * formatETC, STGMEDIUM * stgMedium ); STDMETHOD(QueryGetData)( FORMATETC * formatETC ); STDMETHOD(GetCanonicalFormatEtc)( FORMATETC * formatETCIn, FORMATETC * formatETCOut ); STDMETHOD(SetData)( FORMATETC * formatETC, STGMEDIUM * stgMedium, BOOL releaseData ); STDMETHOD(EnumFormatEtc)( DWORD dwDirection, IEnumFORMATETC ** ppenumFormatetc ); STDMETHOD(DAdvise)( FORMATETC * formatETC, DWORD advf, IAdviseSink * pAdvSink, DWORD * pdwConnection ); STDMETHOD(DUnadvise)( DWORD dwConnection ); STDMETHOD(EnumDAdvise)( IEnumSTATDATA ** ppenumAdvise ); /** * Adds a new data type that the dataobject supports. */ void setDataObject( VCF::DataObject* data ); VCF::DataObject* getDataObject() { return dataObj_; } /** * is the data type passed in supported by the data object ? */ virtual bool isTypeSupported(const VCF::String& dataType );private: DataRendering findDataRenderingForType( FORMATETC* formatETC ); UINT translateFrameworkFormat( const VCF::String& dataType ); FORMATETC translateFrameworkFormatToFormatETC( const VCF::String& dataType ); VCF::String translateClipboardFmt( const UINT& fmtType ); std::vector<DataRendering> renderings_; VCF::DataObject* dataObj_; IDataObject* outerDataObject_; ULONG ref_;};class EnumFormatETC : public IEnumFORMATETC, public EnumObject<FORMATETC> {public: EnumFormatETC(): EnumObject<FORMATETC>(){}; EnumFormatETC( const EnumFormatETC& enumObj ): EnumObject<FORMATETC>( enumObj ){}; virtual ~EnumFormatETC(){}; virtual HRESULT STDMETHODCALLTYPE QueryInterface(REFIID iid, void** ppvObj) { if ( iid == IID_IUnknown ) { *ppvObj = (IUnknown*)(this); ((IUnknown*)(*ppvObj))->AddRef(); return S_OK; } else if ( iid == IID_IEnumFORMATETC ) { *ppvObj = (IEnumFORMATETC*)(this); ((IUnknown*)(*ppvObj))->AddRef(); return S_OK; } return E_NOINTERFACE; } virtual ULONG STDMETHODCALLTYPE AddRef(void) { ref_ ++; return ref_; } virtual ULONG STDMETHODCALLTYPE Release(void) { if ( ref_ > 0 ) { ref_ --; } if ( 0 == ref_ ) { delete this; return 0; } return ref_; } STDMETHOD(Next)( ULONG elementsRequested, FORMATETC *elementList, ULONG *elementsFetched ){ return EnumObject<FORMATETC>::_Next( elementsRequested, elementList, elementsFetched ); }; STDMETHOD(Skip)( ULONG elementsToSkip ){ return EnumObject<FORMATETC>::_Skip( elementsToSkip ); }; STDMETHOD(Reset)(void){ return EnumObject<FORMATETC>::_Reset(); }; /** Creates another enumerator that contains the same enumeration state as the current one. Using this function, a client can record a particular point in the enumeration sequence, and then return to that point at a later time. The new enumerator supports the same interface as the original one. */ STDMETHOD(Clone)( IEnumFORMATETC** enumFmtEtc ){ EnumObject<FORMATETC>* enumFmt = NULL; enumFmt = new EnumFormatETC( *this ); *enumFmtEtc = (IEnumFORMATETC*)enumFmt; return NOERROR;//result;//E_NOTIMPL; };protected: ULONG ref_;};};/***CVS Log info*$Log$*Revision 1.2 2006/04/07 02:35:26 ddiego*initial checkin of merge from 0.6.9 dev branch.**Revision 1.1.2.1 2006/02/19 19:38:12 ddiego*adjusted some comet code to make it compile again. renamed some of the COM utility files to have a Win32 prefix.**Revision 1.2 2004/08/07 02:49:05 ddiego*merged in the devmain-0-6-5 branch to stable**Revision 1.1.2.2 2004/04/29 03:43:12 marcelloptr*reformatting of source files: macros and csvlog and copyright sections**Revision 1.1.2.1 2004/04/28 00:28:14 ddiego*migration towards new directory structure**Revision 1.3.4.1 2004/04/26 21:58:42 marcelloptr*changes for dir reorganization: _VCF_MACRO_H__**Revision 1.3 2003/12/18 05:15:58 ddiego*merge from devmain-0-6-2 branch into the stable branch**Revision 1.2.2.2 2003/09/12 00:09:33 ddiego*added better tabbing behaviour - fixed an earlier bug.*Code is easier to understand and it simplified the implementation*a bit as well*Moved around the RTTI definitions for various Appkit classes to a*single inline and stripped them from the various class headers**Revision 1.2.2.1 2003/08/27 20:11:49 ddiego*adjustments to how hte DataObject class work and copy/paste**Revision 1.2 2003/08/09 02:56:44 ddiego*merge over from the devmain-0-6-1 branch*Changes*Features:*-Added additional implementation to better support the MVC architecture in*the VCF**-Added a Document/View architecure that is similar to MFC's or NextSteps's*Doc/View architectures**-Integrated the Anti Grain Graphics library into the GraphicsKit. There is*now basic support for it in terms of drawing vector shapes*(fills and strokes). Image support will come in the next release**-Added several documented graphics tutorials**Bugfixes:**[ 775744 ] wrong buttons on a dialog*[ 585239 ] Painting weirdness in a modal dialog ?*[ 585238 ] Modal dialog which makes a modal Dialog*[ 509004 ] Opening a modal Dialog causes flicker*[ 524878 ] onDropped not called for MLTcontrol**Plus an issue with some focus and getting the right popup window to activate*has also been fixed**Revision 1.1.2.2 2003/06/27 03:10:58 ddiego*got rid of some redundant junk in the Clipboard and DataObject*classes. Instead of a rather dippy use of the DataType calss, we now simply*use pure mime-types to identify the various "flavours" of data.**Revision 1.1.2.1 2003/05/25 19:07:11 ddiego*fixed bug [ 524878 ] onDropped not called for MLTcontrol. This*was due to errors in the drag-drop implementation for WIn32 and is*now fixed.*Also cleaned up the drag-drop implementation and moved/deleted a number of*irrelevant files for COM support. The vcf/include/com and vcf/src/COM*directories are now gotten rid of.**Revision 1.8 2003/05/17 20:36:59 ddiego*this is the checkin for the 0.6.1 release - represents the merge over from*the devmain-0-6-0 branch plus a few minor bug fixes**Revision 1.7.2.2 2003/03/23 03:23:43 marcelloptr*3 empty lines at the end of the files**Revision 1.7.2.1 2003/03/12 03:09:08 ddiego*switched all member variable that used the "m_"<name> prefix to* <name>"_" suffix nameing standard.*Also changed all vcf builder files to accomadate this.*Changes were made to the Stream classes to NOT multiple inheritance and to*be a little more correct. Changes include breaking the FileStream into two*distinct classes, one for input and one for output.**Revision 1.7 2003/02/26 04:30:35 ddiego*merge of code in the devmain-0-5-9 branch into the current tree.*most additions are in the area of the current linux port, but the major*addition to this release is the addition of a Condition class (currently*still under development) and the change over to using the Delegate class*exclusively from the older event handler macros.**Revision 1.6.14.1 2003/01/08 00:19:41 marcelloptr*mispellings and newlines at the end of all source files**Revision 1.6 2002/05/09 03:10:42 ddiego*merged over code from development branch devmain-0-5-1a into the main CVS trunk**Revision 1.5.4.1 2002/04/27 15:52:15 ddiego*Changed a bunch of files include and made it a bit faster and added better include*guards in the common headers**Revision 1.5 2002/01/24 01:46:45 ddiego*added a cvs "log" comment to the top of all files in vcf/src and vcf/include*to facilitate change tracking**/#endif // _VCF_COMDATAOBJECT_H__
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?