2020-09-30 16:53:55 +02:00

873 lines
30 KiB
C++

/* @doc INTERNAL
*
* @module _HOST.H Text Host for Window's Rich Edit Control |
*
*
* Original Author: <nl>
* Christian Fortini
* Murray Sargent
*
* History: <nl>
* 8/1/95 ricksa Revised interface definition
*/
#ifndef _HOST_H
#define _HOST_H
#ifndef NOWINDOWHOSTS
#include "textserv.h"
#include "textsrv2.h"
#include "dynarray.h"
#ifndef NOACCESSIBILITY
// UNDONE:
// Need to include this file int the project
#include "oleacc.h"
#endif
#include "_notmgr.h"
/*
* TXTEFFECT
*
* @enum Defines different background styles control
*/
enum TXTEFFECT {
TXTEFFECT_NONE = 0, //@emem no special backgoround effect
TXTEFFECT_SUNKEN, //@emem draw a "sunken 3-D" look
};
// @doc EXTERNAL
// ============================ CTxtWinHost ================================================
// Implement the windowed version of the Plain Text control
/*
* CTxtWinHost
*
* @class Text Host for Window's Rich Edit Control implementation class
*
*/
class CTxtWinHost : public ITextHost2
#ifndef NOACCESSIBILITY
, public IAccessible
#endif
{
public:
HWND _hwnd; // control window
HWND _hwndParent; // parent window
ITextServices *_pserv; // pointer to Text Services object
ULONG _crefs; // reference count
// Properties
DWORD _dwStyle; // style bits
DWORD _dwExStyle; // extended style bits
unsigned _fBorder :1; // control has border
unsigned _fInBottomless :1; // inside bottomless callback
unsigned _fInDialogBox :1; // control is in a dialog box
unsigned _fEnableAutoWordSel :1; // enable Word style auto word selection?
unsigned _fIconic :1; // control window is iconic
unsigned _fHidden :1; // control window is hidden
unsigned _fNotSysBkgnd :1; // not using system background color
unsigned _fWindowLocked :1; // window is locked (no update)
unsigned _fRegisteredForDrop :1; // whether host has registered for drop
unsigned _fVisible :1; // Whether window is visible or not.
unsigned _fResized :1; // resized while hidden
unsigned _fDisabled :1; // Window is disabled.
unsigned _fKeyMaskSet :1; // if ENM_KEYEVENTS has been set
unsigned _fMouseMaskSet :1; // if ENM_MOUSEEVENTS has been set
unsigned _fScrollMaskSet :1; // if ENM_SCROLLEVENTS has been set
unsigned _fUseSpecialSetSel :1; // TRUE = use EM_SETSEL hack to not select
// empty controls to make dialog boxes work.
unsigned _fEmSetRectCalled :1; // TRUE - application called EM_SETRECT
unsigned _fAccumulateDBC :1; // TRUE - need to cumulate ytes from 2 WM_CHAR msgs
// we are in this mode when we receive VK_PROCESSKEY
unsigned _fANSIwindow :1; // TRUE - window created as "RichEdit20A"
unsigned _fTextServiceFree :1; // TRUE - Text Services freed at shutdown.
unsigned _fMouseover :1; // TRUE - Mouse Over window
COLORREF _crBackground; // background color
RECT _rcViewInset; // view rect inset /r client rect
HIMC _oldhimc; // previous IME Context
// TODO: the following could be a two-bit field as part of the unsigned field above
DWORD _usIMEMode; // mode of IME operation
// either 0 or ES_SELFIME or ES_NOIME
HPALETTE _hpal; // Logical palette to use.
TCHAR _chPassword; // Password char. If null, no password
TCHAR _chLeadByte; // use when we are in _fAccumulateDBC mode
SHORT _sWidth; // Last client width given by WM_SIZE
char _yInset;
char _xInset;
CTxtWinHost *_pnextdel;
public:
// Initialization
virtual BOOL Init(
HWND hwnd,
const CREATESTRUCT *pcs,
BOOL fIsAnsi,
BOOL fIs10Mode);
void SetScrollBarsForWmEnable(BOOL fEnable);
void OnSetMargins(
DWORD fwMargin,
DWORD xLeft,
DWORD xRight);
virtual void SetScrollInfo(
INT fnBar,
BOOL fRedraw);
// helpers
HRESULT CreateTextServices();
void * CreateNmhdr(UINT uiCode, LONG cb);
void HostRevokeDragDrop(void);
void HostRegisterDragDrop();
void OnSunkenWindowPosChanging(HWND hwnd, WINDOWPOS *pwndpos);
LRESULT OnSize(HWND hwnd, WORD fwSizeType, int nWidth, int nHeight);
virtual TXTEFFECT TxGetEffects() const;
HRESULT OnTxVisibleChange(BOOL fVisible);
void SetDefaultInset();
BOOL IsTransparentMode()
{
return (_dwExStyle & WS_EX_TRANSPARENT);
}
// Keyboard messages
virtual LRESULT OnKeyDown(WORD vKey, DWORD dwFlags);
virtual LRESULT OnChar(WORD vKey, DWORD dwFlags);
// System notifications
virtual void OnSysColorChange();
virtual LRESULT OnGetDlgCode(WPARAM wparam, LPARAM lparam);
// Other messages
LRESULT OnGetOptions() const;
void OnSetOptions(WORD wOp, DWORD eco);
void OnSetReadOnly(BOOL fReadOnly);
void OnGetRect(LPRECT prc);
void OnSetRect(LPRECT prc, BOOL fNewBehavior, BOOL fRedraw);
public:
CTxtWinHost();
virtual ~CTxtWinHost();
void Shutdown();
// Window creation/destruction
static CTxtWinHost *OnNCCreate(
HWND hwnd,
const CREATESTRUCT *pcs,
BOOL fIsAnsi,
BOOL fIs10Mode);
static void OnNCDestroy(CTxtWinHost *ped);
virtual LRESULT OnCreate(const CREATESTRUCT *pcs);
// -----------------------------
// IUnknown interface
// -----------------------------
virtual HRESULT WINAPI QueryInterface(REFIID riid, void **ppvObject);
virtual ULONG WINAPI AddRef(void);
virtual ULONG WINAPI Release(void);
// -----------------------------
// ITextHost interface
// -----------------------------
//@cmember Get the DC for the host
virtual HDC TxGetDC();
//@cmember Release the DC gotten from the host
virtual INT TxReleaseDC(HDC hdc);
//@cmember Show the scroll bar
virtual BOOL TxShowScrollBar(INT fnBar, BOOL fShow);
//@cmember Enable the scroll bar
virtual BOOL TxEnableScrollBar (INT fuSBFlags, INT fuArrowflags);
//@cmember Set the scroll range
virtual BOOL TxSetScrollRange(
INT fnBar,
LONG nMinPos,
INT nMaxPos,
BOOL fRedraw);
//@cmember Set the scroll position
virtual BOOL TxSetScrollPos (INT fnBar, INT nPos, BOOL fRedraw);
//@cmember InvalidateRect
virtual void TxInvalidateRect(LPCRECT prc, BOOL fMode);
//@cmember Send a WM_PAINT to the window
virtual void TxViewChange(BOOL fUpdate);
//@cmember Create the caret
virtual BOOL TxCreateCaret(HBITMAP hbmp, INT xWidth, INT yHeight);
//@cmember Show the caret
virtual BOOL TxShowCaret(BOOL fShow);
//@cmember Set the caret position
virtual BOOL TxSetCaretPos(INT x, INT y);
//@cmember Create a timer with the specified timeout
virtual BOOL TxSetTimer(UINT idTimer, UINT uTimeout);
//@cmember Destroy a timer
virtual void TxKillTimer(UINT idTimer);
//@cmember Scroll the content of the specified window's client area
virtual void TxScrollWindowEx (
INT dx,
INT dy,
LPCRECT lprcScroll,
LPCRECT lprcClip,
HRGN hrgnUpdate,
LPRECT lprcUpdate,
UINT fuScroll);
//@cmember Get mouse capture
virtual void TxSetCapture(BOOL fCapture);
//@cmember Set the focus to the text window
virtual void TxSetFocus();
//@cmember Establish a new cursor shape
virtual void TxSetCursor(HCURSOR hcur, BOOL fText);
//@cmember Changes the mouse cursor
virtual HCURSOR TxSetCursor2(HCURSOR hcur, BOOL bText) { return ::SetCursor(hcur);}
//@cmember Notification that text services is freed
virtual void TxFreeTextServicesNotification();
//@cmember Converts screen coordinates of a specified point to the client coordinates
virtual BOOL TxScreenToClient (LPPOINT lppt);
//@cmember Converts the client coordinates of a specified point to screen coordinates
virtual BOOL TxClientToScreen (LPPOINT lppt);
//@cmember Request host to activate text services
virtual HRESULT TxActivate( LONG * plOldState );
//@cmember Request host to deactivate text services
virtual HRESULT TxDeactivate( LONG lNewState );
//@cmember Retrieves the coordinates of a window's client area
virtual HRESULT TxGetClientRect(LPRECT prc);
//@cmember Get the view rectangle relative to the inset
virtual HRESULT TxGetViewInset(LPRECT prc);
//@cmember Get the default character format for the text
virtual HRESULT TxGetCharFormat(const CHARFORMAT **ppCF );
//@cmember Get the default paragraph format for the text
virtual HRESULT TxGetParaFormat(const PARAFORMAT **ppPF);
//@cmember Get the background color for the window
virtual COLORREF TxGetSysColor(int nIndex);
//@cmember Get the background (either opaque or transparent)
virtual HRESULT TxGetBackStyle(TXTBACKSTYLE *pstyle);
//@cmember Get the maximum length for the text
virtual HRESULT TxGetMaxLength(DWORD *plength);
//@cmember Get the bits representing requested scroll bars for the window
virtual HRESULT TxGetScrollBars(DWORD *pdwScrollBar);
//@cmember Get the character to display for password input
virtual HRESULT TxGetPasswordChar(TCHAR *pch);
//@cmember Get the accelerator character
virtual HRESULT TxGetAcceleratorPos(LONG *pcp);
//@cmember Get the native size
virtual HRESULT TxGetExtent(LPSIZEL lpExtent);
//@cmember Notify host that default character format has changed
virtual HRESULT OnTxCharFormatChange (const CHARFORMAT * pCF);
//@cmember Notify host that default paragraph format has changed
virtual HRESULT OnTxParaFormatChange (const PARAFORMAT * pPF);
//@cmember Bulk access to bit properties
virtual HRESULT TxGetPropertyBits(DWORD dwMask, DWORD *pdwBits);
//@cmember Notify host of events
virtual HRESULT TxNotify(DWORD iNotify, void *pv);
// FE Support Routines for handling the Input Method Context
virtual HIMC TxImmGetContext(void);
virtual void TxImmReleaseContext(HIMC himc);
//@cmember Returns HIMETRIC size of the control bar.
virtual HRESULT TxGetSelectionBarWidth (LONG *lSelBarWidth);
// ITextHost2 methods
virtual BOOL TxIsDoubleClickPending();
virtual HRESULT TxGetWindow(HWND *phwnd);
virtual HRESULT TxSetForegroundWindow();
virtual HPALETTE TxGetPalette();
virtual HRESULT TxGetFEFlags(LONG *pFlags);
virtual HRESULT TxGetEditStyle(DWORD dwItem, DWORD *pdwData);
virtual HRESULT TxGetWindowStyles(DWORD *pdwStyle, DWORD *pdwExStyle);
virtual HRESULT TxEBookLoadImage( LPWSTR lpszName, // name of image
LPARAM * pID, // E-Book supplied image ID
SIZE * psize, // returned size of image (pixels)
DWORD *pdwFlags); // returned flags for Float
virtual HRESULT TxEBookImageDraw(LPARAM ID, // id of image to draw
HDC hdc, // drawing HDC
POINT *topLeft, // top left corner of where to draw
RECT *prcRenderint, // parm pointer to render rectangle
BOOL fSelected); // TRUE if image is in selected state
virtual HRESULT TxGetHorzExtent(LONG *plHorzExtent);
#ifndef NOACCESSIBILITY
ITypeInfo *_pTypeInfo;
virtual HRESULT InitTypeInfo() {return E_NOTIMPL;}
////////////////////////// IDispatch Methods /////////////////////////////////
STDMETHOD(GetTypeInfoCount)(UINT __RPC_FAR *pctinfo);
STDMETHOD(GetTypeInfo)(UINT iTInfo, LCID lcid, ITypeInfo __RPC_FAR *__RPC_FAR *ppTInfo);
STDMETHOD(GetIDsOfNames)(REFIID riid, LPOLESTR __RPC_FAR *rgszNames, UINT cNames,
LCID lcid, DISPID __RPC_FAR *rgDispId);
STDMETHOD(Invoke)(DISPID dispIdMember, REFIID riid, LCID lcid, WORD wFlags, DISPPARAMS __RPC_FAR *pDispParams,
VARIANT __RPC_FAR *pVarResult, EXCEPINFO __RPC_FAR *pExcepInfo, UINT __RPC_FAR *puArgErr);
////////////////////////// IAccessible Methods /////////////////////////////////
STDMETHOD(get_accParent)(IDispatch **ppdispParent) {return S_FALSE;}
STDMETHOD(get_accChildCount)(long *pcountChildren) {return S_FALSE;}
STDMETHOD(get_accChild)(VARIANT varChild, IDispatch **ppdispChild) {return S_FALSE;}
STDMETHOD(get_accName)(VARIANT varChild, BSTR *pszName) {return S_FALSE;}
STDMETHOD(get_accValue)(VARIANT varChild, BSTR *pszValue) {return S_FALSE;}
STDMETHOD(get_accDescription)(VARIANT varChild, BSTR *pszDescription) {return S_FALSE;}
STDMETHOD(get_accRole)(VARIANT varChild, VARIANT *pvarRole) {return S_FALSE;}
STDMETHOD(get_accState)(VARIANT varChild, VARIANT *pvarState) {return S_FALSE;}
STDMETHOD(get_accHelp)(VARIANT varChild, BSTR *pszHelp) {return S_FALSE;}
STDMETHOD(get_accHelpTopic)(BSTR *pszHelpFile, VARIANT varChild, long *pidTopic) {return S_FALSE;}
STDMETHOD(get_accKeyboardShortcut)(VARIANT varChild, BSTR *pszKeyboardShortcut) {return S_FALSE;}
STDMETHOD(get_accFocus)(VARIANT *pvarChild) {return S_FALSE;}
STDMETHOD(get_accSelection)(VARIANT *pvarChildren) {return S_FALSE;}
STDMETHOD(get_accDefaultAction)(VARIANT varChild, BSTR *pszDefaultAction) {return S_FALSE;}
STDMETHOD(accSelect)(long flagsSelect, VARIANT varChild) {return S_FALSE;}
STDMETHOD(accLocation)(long *pxLeft, long *pyTop, long *pcxWidth, long *pcyHeight, VARIANT varChild)
{return S_FALSE;}
STDMETHOD(accNavigate)(long navDir, VARIANT varStart, VARIANT *pvarEndUpAt) {return S_FALSE;}
STDMETHOD(accHitTest)(long xLeft, long yTop, VARIANT *pvarChild) {return S_FALSE;}
STDMETHOD(accDoDefaultAction)(VARIANT varChild) {return S_FALSE;}
STDMETHOD(put_accName)(VARIANT varChild, BSTR szName) {return S_FALSE;}
STDMETHOD(put_accValue)(VARIANT varChild, BSTR szValue) {return S_FALSE;}
#endif // NOACCESSIBILITY
};
#ifndef NOWINDOWHOSTS
// Work around some client's (MSN chat) problems with host deletions.
void DeleteDanglingHosts();
#endif
#define LBS_COMBOBOX 0x8000L
#define LBCB_TRACKING WM_USER+2
#define LBCBM_PREPARE 1
#define LBCBM_START 2
#define LBCBM_END 3
// mask for LBCBM messages
#define LBCBM_PREPARE_SETFOCUS 1
#define LBCBM_PREPARE_SAVECURSOR 2
class CLbData
{
public:
unsigned _fSelected :1; // indicates if the item has been selected
UINT _uHeight; // Item height for owner-drawn with varibale height
LPARAM _lparamData; // Item data
};
struct CHARSORTINFO
{
WCHAR* str;
int sz;
};
#define CHECKNOERROR(x) if (NOERROR != x) goto CleanExit
class CCmbBxWinHost;
class CLstBxWinHost : public CTxtWinHost, public ITxNotify
{
public:
typedef enum {
//kNoSel = 0, //LBS_NOSEL
kSingle = 1, //LBS_SIMPLE
kMultiple = 2, //LBS_MULTIPLESEL
kExtended = 3, //LBS_EXTENDEDSEL
kCombo = 8 //Combo box
} Listtype;
#ifndef NOACCESSIBILITY
public:
// -----------------------------
// IUnknown interface
// -----------------------------
virtual HRESULT WINAPI QueryInterface(REFIID riid, void **ppvObject);
#endif
private:
short _cWheelDelta; //contains the delta values for mouse wheels
int _nTopIdx; //the item index at the top of list
//Do not touch this unless you know what you are doing!!
LONG _cpLastGetRange; //Cached cp value for last GetRange call
int _nIdxLastGetRange; //Cached index for last GetRange call.
public:
DWORD _fOwnerDraw :1; //indicates if list box is owner draw
DWORD _fOwnerDrawVar :1; //indicates if list box is owner draw with variable height
DWORD _fSort :1; //determines if the list should be sorted
DWORD _fNoIntegralHeight :1; //indicates if the size of the listbox should be readjusted according
//how many items can be fully displayed
DWORD _fDisableScroll :1; //indicates if scroll bar should be displayed at all times
DWORD _fNotify :1; //notifies parent dialog of activities done in list box.
DWORD _fSingleSel :1; // Indicates the list box is a single selection item
DWORD _fMouseDown :1; // Indicates if the mouse is down
DWORD _fFocus :1; // determines if the control has focus
DWORD _fCapture :1; // determines if mouse capture is set
DWORD _fSearching :1; // indicates if we are in type searching mode
DWORD _fDblClick :1; // flag indicating double click was received
DWORD _fNoResize :1; // internal flag to tell us if we should ignore resize messages
DWORD _fNotifyWinEvt :1; // Indicates only Notify Win Event (ACCESSIBILITY use)
DWORD _fHorzScroll :1; // enable Horz scrolling
DWORD _fWantKBInput :1; // indicates owner wants keyboard input
DWORD _fHasStrings :1; // indicates LB has string
DWORD _fSetRedraw :1; // indicates if we should handle WM_PAINT
DWORD _fSetScroll :1; // indicates if we should set scroll info after unfreeze
DWORD _fShutDown :1; // indicates listbox is shutting down
DWORD _fIntegralHeightOld :1; // previous value for _fNoIntegralHeight
Listtype _fLstType; //indicates current type of list box or combo box
#ifndef NOACCESSIBILITY
DWORD _dwWinEvent; // Win Event code (ACCESSIBILITY use)
int _nAccessibleIdx; // Index (ACCESSIBILITY use)
#endif
LONG GetHorzExtent() { return _lHorzExtent;}
void SetHorzExtent(LONG lHorzExtent) { _lHorzExtent = lHorzExtent;}
CDynamicArray<CLbData> _rgData; // Array/link list of the item data
protected:
UINT _idCtrl; // control's unique id
COLORREF _crSelFore; //Selected Forground color
COLORREF _crSelBack; //Selected Background color
COLORREF _crDefFore; //Default Forground color
COLORREF _crDefBack; //Default Background color
RECT _rcViewport; //drawable area for the items
long _nyFont; // Font pixel size in y direction
long _nyItem; //Height of the items in the list box
int _nViewSize; //number of items which is viewable at the same time
int _nCount; //Number of items in the list box
int _nAnchor; //Indicates the top selected item
//NOTE:
// In a single sel list box only _nCursor is used
int _nCursor; //Indicates the current item which has the focus
int _nOldCursor; //The old cursor position for combo boxes
int _stvidx; // This is for a hack to workaround a bug when the display
// is frozen ITextRange doesn't cache to scroll change
int _nidxSearch; // Number of characters in search string
WCHAR* _pwszSearch; // pointer to allocated string
LPARAM _nPrevMousePos; // Last position from Mousemove message
CCmbBxWinHost* _pcbHost; // pointer to combo box win host
long _lHorzExtent; // Horizontal extent in pixel for Horz scrolling
protected:
// Changes the background color
BOOL SetColors(DWORD, DWORD, long, long);
// Makes sure the top item is displayed at the top of the view
BOOL ScrollToView(long nTop);
// Sets the requested item to be at the top of the viewable space
BOOL SetTopViewableItem(long);
// Searches if a given index qualifies as a match
BOOL FindString(long idx, LPCTSTR szSearch, BOOL bExact);
// helper function for the OnMouseMove function
void MouseMoveHelper(int, BOOL);
// Set the height of each item in the list box in the given range
int SetItemsHeight(int,BOOL);
// Sum the height from iStart to iEnd for variable item height listbox
int SumVarHeight(int iStart, int iEnd, BOOL *pfGreaterThanView = NULL);
// Page up/down helper for Variable height LB
int PageVarHeight(int startItem, BOOL fPageForwardDirection);
// Setup height for Variable height LB
BOOL SetVarItemHeight(int idx, int iHeight);
// Find the idx for the given iHeight from idx 0
int GetIdxFromHeight(int iHeight);
public:
CLstBxWinHost();
virtual ~CLstBxWinHost();
void ResizeInset();
// initialization function
virtual BOOL Init(HWND, const CREATESTRUCT *);
// Window creation/destruction
static LRESULT OnNCCreate(HWND hwnd, const CREATESTRUCT *pcs);
static void OnNCDestroy(CLstBxWinHost *ped);
virtual LRESULT OnCreate(const CREATESTRUCT *pcs);
////////////////////////// helper functions ////////////////////////////////////
static wchar_t * wcscat(wchar_t * dst, const wchar_t * src)
{
wchar_t * cp = dst;
while(*cp) cp++; // find null character in first string
while( *cp++ = *src++ ); // Copy src over dst
return( dst );
}
// given a source string the destination string contains a sorted version
// separated by <CR>
int SortInsertList(WCHAR* pszDst, WCHAR* pszSrc);
// Sets the indents for the listbox
BOOL SetListIndent(int fLeftIndent);
// Equivalent to CompareString except int is a reference to an item index
int CompareIndex(LPCTSTR szInsert, int nIndex);
// Returns the position a string should be in a sorted list
int GetSortedPosition(LPCTSTR, int, int);
// Updates the system color settings
void UpdateSysColors();
// Inits search string
void InitSearch();
// Prevents the window from updating itself
long Freeze();
// Frees the window to update itself
long Unfreeze();
// Retrieves the range give the top and bottom index
BOOL GetRange(long, long, ITextRange**);
// Inserts the string at the requested index
BOOL InsertString(long, LPCTSTR);
// Removes the string from the listbox
BOOL RemoveString(long, long);
// Retrieves the string at the requested index
long GetString(long, PWCHAR);
// Deselects all the items in the list box
BOOL ResetContent();
// Retrieves the nearest valid item from a given point
int GetItemFromPoint(const POINT *);
// Tells if a given points is within the listbox's rect
BOOL PointInRect(const POINT *);
// Sets the cursor position and draws the rect
void SetCursor(HDC, int, BOOL);
// Recalulates the height so no partial text will be displayed
BOOL RecalcHeight(int, int);
// Reset Listbox items color
void ResetItemColor();
// returns of listbox is single selection
inline BOOL IsSingleSelection() const {return _fSingleSel;}
// Returns the current top index
inline long GetTopIndex() const { return _nTopIdx;}
// Checks if the mouse has been captured
inline BOOL GetCapture() const { return _fCapture;}
// return the item count
inline int GetCount() const {return _nCount;}
// returns the anchor position
inline int GetAnchor() const {return _nAnchor;}
// returns the cursor position
inline int GetCursor() const {return _nCursor;}
// returns the viewsize
inline int GetViewSize() const {return _nViewSize;}
// returns the font height
inline int GetFontHeight() const {return _nyFont;}
// returns the item height
inline int GetItemHeight() const {return _nyItem;}
// returns the displays freeze count
inline short FreezeCount() const;
// initialize mouse wheel variable to zero
inline void InitWheelDelta() { _cWheelDelta = 0;}
BOOL IsItemViewable(long idx);
// Determines if index is selected
inline BOOL IsSelected(long nIdx)
{
#ifdef _DEBUG
Assert(nIdx < -1 || _nCount <= nIdx);
if (nIdx < -1 || _nCount <= nIdx) return FALSE;
#endif
if (nIdx < 0)
return FALSE;
else
return _rgData[nIdx]._fSelected;
}
// Returns the ItemData of a given index
inline LPARAM GetData(long nIdx)
{
return _rgData.Get(nIdx)._lparamData;
}
// Check if we need to do custom look for ListBox
LRESULT OnSetEditStyle(WPARAM, LPARAM);
//Custom look
BOOL IsCustomLook();
/////////////////////ListBox Message Handling functions /////////////////////////
// Set the height of the items in the list box
BOOL LbSetItemHeight(WPARAM, LPARAM);
// Set the selection state for the items in the range
BOOL LbSetSelection(long, long, int, long, long);
// Sets the requested item to be at the top of the list box
long LbSetTopIndex(long);
// Makes sure the requested index is visible
BOOL LbShowIndex(long, BOOL);
// Retrieves the index give a string and starting position
long LbFindString(long, LPCTSTR, BOOL);
// Inserts the string at the requested location
long LbInsertString(long, LPCTSTR);
// Range to delete
long LbDeleteString(long, long);
// Sets the Item data
void LbSetItemData(long, long, LPARAM);
// returns the item rect of a given index
BOOL LbGetItemRect(int, RECT*);
// Notifies parent when an item is deleted
void LbDeleteItemNotify(int, int);
// Owner draw function
void LbDrawItemNotify(HDC, int, UINT, UINT);
// used to insert a list of strings rather than individually
int LbBatchInsert(WCHAR* psz);
BOOL LbEnableDraw()
{
return _fSetRedraw;
};
// Handles LB_GETCURSEL
LRESULT LbGetCurSel();
///////////////////////// Message Map functions //////////////////////////////
// if subclassed then make these functions virtual
// Handles the WM_MOUSEMOVE message
LRESULT OnMouseWheel(WPARAM, LPARAM);
// Handles the WM_LBUTTONDOWN message
LRESULT OnLButtonDown(WPARAM wparam, LPARAM lparam);
// Handles the WM_MOUSEMOVE message
LRESULT OnMouseMove(WPARAM, LPARAM);
// Handles the WM_LBUTTONUP message
LRESULT OnLButtonUp(WPARAM, LPARAM, int ff = 0);
// Handles the WM_VSCROLL message
LRESULT OnVScroll(WPARAM, LPARAM);
// Handles the WM_TIMER message
LRESULT OnTimer(WPARAM, LPARAM);
// Handles the WM_KEYDOWN message
LRESULT OnKeyDown(WPARAM, LPARAM, int);
// Hanldes the WM_CAPTURECHANGED message
LRESULT OnCaptureChanged(WPARAM, LPARAM);
// Handles the WM_CHAR message
virtual LRESULT OnChar(WORD, DWORD);
// Handles the WM_SYSCOLORCHANGE message
virtual void OnSysColorChange();
// Handles the WM_SETTINGCHANGE message
void OnSettingChange(WPARAM, LPARAM);
// Handles the WM_SETCURSOR message
LRESULT OnSetCursor();
// Handles the WM_SETREDRAW message
LRESULT OnSetRedraw(WPARAM);
// Handles the WM_HSCROLL message
LRESULT OnHScroll(WPARAM, LPARAM);
//////////////////////////// overridden Tx fn's ////////////////////////////////
//@cmember Get the bits representing requested scroll bars for the window
virtual HRESULT TxGetScrollBars(DWORD *pdwScrollBar);
//@cmember Bulk access to bit properties
virtual HRESULT TxGetPropertyBits(DWORD, DWORD *);
virtual TXTEFFECT TxGetEffects() const;
//@cmember Notify host of events
virtual HRESULT TxNotify(DWORD iNotify, void *pv);
//@cmember Show the scroll bar
virtual BOOL TxShowScrollBar(INT fnBar, BOOL fShow);
//@cmember Enable the scroll bar
virtual BOOL TxEnableScrollBar (INT fuSBFlags, INT fuArrowflags);
//@cmember Show the caret
virtual BOOL TxShowCaret(BOOL fShow) {return TRUE;}
//@cmember Create the caret
virtual BOOL TxCreateCaret(HBITMAP hbmp, INT xWidth, INT yHeight) {return FALSE;}
//@cmember Set the scroll range
virtual void SetScrollInfo(INT, BOOL);
//@cmember Get the horizontal extent
virtual HRESULT TxGetHorzExtent(LONG *plHorzExtent);
/////////////////////////// Combobox helper fn's ///////////////////////////////
void OnCBTracking(WPARAM, LPARAM);
static int QSort(CHARSORTINFO rg[], int nStart, int nEnd);
#ifndef NOACCESSIBILITY
HRESULT InitTypeInfo();
////////////////////////// IAccessible Methods /////////////////////////////////
STDMETHOD(get_accParent)(IDispatch **ppdispParent);
STDMETHOD(get_accName)(VARIANT varChild, BSTR *pszName);
STDMETHOD(get_accChildCount)(long *pcountChildren);
STDMETHOD(get_accRole)(VARIANT varChild, VARIANT *pvarRole);
STDMETHOD(get_accState)(VARIANT varChild, VARIANT *pvarState);
STDMETHOD(get_accKeyboardShortcut)(VARIANT varChild, BSTR *pszKeyboardShortcut);
STDMETHOD(get_accFocus)(VARIANT *pvarChild);
STDMETHOD(get_accSelection)(VARIANT *pvarChildren);
STDMETHOD(get_accDefaultAction)(VARIANT varChild, BSTR *pszDefaultAction);
STDMETHOD(accSelect)(long flagsSelect, VARIANT varChild);
STDMETHOD(accLocation)(long *pxLeft, long *pyTop, long *pcxWidth, long *pcyHeight, VARIANT varChild);
STDMETHOD(accNavigate)(long navDir, VARIANT varStart, VARIANT *pvarEndUpAt);
STDMETHOD(accHitTest)(long xLeft, long yTop, VARIANT *pvarChild);
STDMETHOD(accDoDefaultAction)(VARIANT varChild);
#endif // NOACCESSIBILITY
// ITxNotify methods
virtual void OnPreReplaceRange( LONG cp, LONG cchDel, LONG cchNew,
LONG cpFormatMin, LONG cpFormatMax, NOTIFY_DATA *pNotifyData ) { ; }
virtual void OnPostReplaceRange( LONG cp, LONG cchDel, LONG cchNew,
LONG cpFormatMin, LONG cpFormatMax, NOTIFY_DATA *pNotifyData );
virtual void Zombie() { ; };
};
#ifndef NOACCESSIBILITY
// --------------------------------------------------------------------------
//
// Although CListBoxSelection() is based off of IEnumVARIANT.
// It will hand back the proper IDs so you can pass them to the real
// listbox parent object.
//
// --------------------------------------------------------------------------
class CListBoxSelection : public IEnumVARIANT
{
public:
// IUnknown
virtual STDMETHODIMP QueryInterface(REFIID, void**);
virtual STDMETHODIMP_(ULONG) AddRef(void);
virtual STDMETHODIMP_(ULONG) Release(void);
// IEnumVARIANT
virtual STDMETHODIMP Next(ULONG celt, VARIANT* rgvar, ULONG * pceltFetched);
virtual STDMETHODIMP Skip(ULONG celt);
virtual STDMETHODIMP Reset(void);
virtual STDMETHODIMP Clone(IEnumVARIANT ** ppenum);
CListBoxSelection(int, int, LPINT, BOOL);
~CListBoxSelection();
protected:
int _cRef;
int _idChildCur;
int _cSel;
LPINT _piSel;
};
#endif
#ifndef DEBUG
#define AttCheckRunTotals(_fCF)
#define AttCheckPFRuns(_fCF)
#endif
#define ECO_STYLES (ECO_AUTOVSCROLL | ECO_AUTOHSCROLL | ECO_NOHIDESEL | \
ECO_READONLY | ECO_WANTRETURN | ECO_SAVESEL | \
ECO_SELECTIONBAR | ES_NOIME | ES_SELFIME | ES_VERTICAL)
#endif // NOWINDOWHOSTS
#endif // _HOST_H