You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
234 lines
5.1 KiB
234 lines
5.1 KiB
/*
|
|
* _DRAGDRP.H
|
|
*
|
|
* Purpose:
|
|
* class declarations for Richedit's OLE drop target and drop source
|
|
* objects.
|
|
*
|
|
* Author:
|
|
* alexgo (4/28/95)
|
|
*
|
|
*/
|
|
|
|
#ifndef __DRAGDRP_H__
|
|
#define __DRAGDRP_H__
|
|
|
|
#include "_osdc.h"
|
|
|
|
// DWORD packed flag values. These are assigned values such that they can
|
|
// be or'd with DataObjectInfo flags and not conflict. We are, in effect,
|
|
// overriding the DataObjectInfo flags.
|
|
#define DF_CLIENTCONTROL 0x80000000 // QueryAcceptData says the client
|
|
// will handle this drop.
|
|
#define DF_CANDROP 0x40000000 // We can handle the drop
|
|
#define DF_OVERSOURCE 0x20000000 // Drop target is within source range.
|
|
#define DF_RIGHTMOUSEDRAG 0x10000000 // doing a right mouse drag drop
|
|
|
|
|
|
// forward declaration.
|
|
class CCallMgr;
|
|
|
|
|
|
#define WIDTH_DROPCARET 1
|
|
#define DEFAULT_DROPCARET_MAXHEIGHT 32
|
|
|
|
/*
|
|
* CDropCaret
|
|
*
|
|
* Purpose:
|
|
* provides a caret for the location that drop will occur
|
|
*/
|
|
class CDropCaret
|
|
{
|
|
public:
|
|
|
|
CDropCaret(CTxtEdit *ped);
|
|
|
|
~CDropCaret();
|
|
|
|
BOOL Init();
|
|
|
|
void DrawCaret(LONG cpCur);
|
|
|
|
void HideCaret();
|
|
|
|
void ShowCaret();
|
|
|
|
void CancelRestoreCaretArea();
|
|
|
|
BOOL NoCaret();
|
|
|
|
private:
|
|
|
|
CTxtEdit * _ped;
|
|
|
|
HDC _hdcWindow;
|
|
|
|
LONG _yPixelsPerInch;
|
|
|
|
LONG _yHeight;
|
|
|
|
LONG _yHeightMax;
|
|
|
|
POINT _ptCaret;
|
|
|
|
COffScreenDC _osdc;
|
|
};
|
|
|
|
/*
|
|
* CDropCaret::CancelRestoreCaretArea
|
|
*
|
|
* Purpose:
|
|
* Tell object not to restore area where caret was.
|
|
*
|
|
* @devnote:
|
|
* When we drop we don't want to restore the old caret area
|
|
* since that is no longer correct.
|
|
*
|
|
*/
|
|
inline void CDropCaret::CancelRestoreCaretArea()
|
|
{
|
|
_yHeight = -1;
|
|
}
|
|
|
|
|
|
/*
|
|
* CDropCaret::NoCaret
|
|
*
|
|
* Purpose:
|
|
* Tell whether caret has been turned off
|
|
*
|
|
*/
|
|
inline BOOL CDropCaret::NoCaret()
|
|
{
|
|
return -1 == _yHeight;
|
|
}
|
|
|
|
|
|
/*
|
|
* CDropSource
|
|
*
|
|
* Purpose:
|
|
* provides drag drop feedback
|
|
*/
|
|
|
|
class CDropSource : public IDropSource
|
|
{
|
|
public:
|
|
// IUnknown methods
|
|
STDMETHOD(QueryInterface)(REFIID riid, void ** ppv);
|
|
STDMETHOD_(ULONG, AddRef)();
|
|
STDMETHOD_(ULONG, Release)();
|
|
|
|
// IDropSource methods
|
|
STDMETHOD(QueryContinueDrag)(BOOL fEscapePressed, DWORD grfKeyState);
|
|
STDMETHOD(GiveFeedback)(DWORD dwEffect);
|
|
|
|
CDropSource();
|
|
|
|
private:
|
|
// NOTE: private destructor, may not be allocated on the stack as
|
|
// this would break OLE's current object liveness rules
|
|
~CDropSource();
|
|
|
|
ULONG _crefs;
|
|
};
|
|
|
|
/*
|
|
* CDropTarget
|
|
*
|
|
* Purpose:
|
|
* an OLE drop-target object; provides a place for text to be "dropped"
|
|
*
|
|
*/
|
|
|
|
class CDropTarget : public IDropTarget
|
|
{
|
|
public:
|
|
// IUnknown methods
|
|
STDMETHOD(QueryInterface)(REFIID riid, void ** ppv);
|
|
STDMETHOD_(ULONG, AddRef)();
|
|
STDMETHOD_(ULONG, Release)();
|
|
|
|
// IDropTarget methods
|
|
STDMETHOD(DragEnter)(IDataObject *pdo, DWORD grfKeyState,
|
|
POINTL pt, DWORD *pdwEffect);
|
|
STDMETHOD(DragOver)(DWORD grfKeyState, POINTL pt, DWORD *pdwEffect);
|
|
STDMETHOD(DragLeave)();
|
|
STDMETHOD(Drop)(IDataObject *pdo, DWORD grfKeyState, POINTL pt,
|
|
DWORD *pdwEffect);
|
|
|
|
|
|
CDropTarget(CTxtEdit *ped);
|
|
|
|
// this method is used during drag drop to cache important information
|
|
void SetDragInfo( IUndoBuilder *publdr, LONG cpMin, LONG cpMax );
|
|
void Zombie(); //@cmember Nulls out the state of this object
|
|
|
|
BOOL fInDrag(); //@cmember Tells whether another app is dragging
|
|
// over us.
|
|
|
|
private:
|
|
// this class is used in CDropTarget::Drop to clean up at the end
|
|
// of the call.
|
|
class CDropCleanup
|
|
{
|
|
public:
|
|
CDropCleanup( CDropTarget *pdt )
|
|
{
|
|
_pdt = pdt;
|
|
}
|
|
|
|
~CDropCleanup()
|
|
{
|
|
delete _pdt->_pcallmgr;
|
|
_pdt->_pcallmgr = NULL;
|
|
delete _pdt->_pdrgcrt;
|
|
_pdt->_pdrgcrt = NULL;
|
|
}
|
|
private:
|
|
CDropTarget * _pdt;
|
|
};
|
|
|
|
friend class CDropCleanup;
|
|
|
|
// NOTE: private destructor, may not be allocated on the stack as
|
|
// this would break OLE's current object liveness rules
|
|
|
|
~CDropTarget();
|
|
|
|
void UpdateEffect(DWORD grfKeyState, POINTL pt, DWORD *pdwEffect);
|
|
void DrawFeedback(void);
|
|
void ConvertScreenPtToClientPt( POINTL *pptScreen, POINT *pptClient );
|
|
HRESULT HandleRightMouseDrop(IDataObject *pdo, POINTL ptl);
|
|
|
|
ULONG _crefs;
|
|
DWORD _dwFlags; // DataObjectInfo cache (e.g. DOI_CANPASTEPLAIN)
|
|
// and other flags.
|
|
CTxtEdit * _ped;
|
|
CCallMgr * _pcallmgr; // The call manager used during a drag drop operation.
|
|
|
|
// cached information for drag drop operations
|
|
IUndoBuilder *_publdr; // the undo builder for the drag operation
|
|
LONG _cpMin; // the min and max cp's for the range that is
|
|
LONG _cpMost; // being dragged so we can disable drag-onto-yourself!
|
|
LONG _cpSel; // active end and length for selection *before*
|
|
LONG _cchSel; // drag drop op occured (so we can restore it)
|
|
LONG _cpCur; // the cp that the mouse is currently over
|
|
CDropCaret *_pdrgcrt; // Object that implements the drop caret
|
|
};
|
|
|
|
|
|
/*
|
|
* CDropTarget::fInDrag ()
|
|
*
|
|
* Purpose:
|
|
* Tells interested parties whether a drag operation is occurring
|
|
*
|
|
*/
|
|
inline BOOL CDropTarget::fInDrag()
|
|
{
|
|
return _pcallmgr != NULL;
|
|
}
|
|
|
|
#endif // !__DRAGDRP_H__
|