PageRenderTime 105ms CodeModel.GetById 18ms RepoModel.GetById 0ms app.codeStats 2ms

/thirdparty/wtl/atlctrls.h

http://crashrpt.googlecode.com/
C Header | 10033 lines | 8164 code | 1548 blank | 321 comment | 431 complexity | 568a835c698d37e8daf2a4b28c1f5c17 MD5 | raw file
Possible License(s): LGPL-3.0, BSD-3-Clause
  1. // Windows Template Library - WTL version 8.1
  2. // Copyright (C) Microsoft Corporation. All rights reserved.
  3. //
  4. // This file is a part of the Windows Template Library.
  5. // The use and distribution terms for this software are covered by the
  6. // Common Public License 1.0 (http://opensource.org/licenses/cpl1.0.php)
  7. // which can be found in the file CPL.TXT at the root of this distribution.
  8. // By using this software in any fashion, you are agreeing to be bound by
  9. // the terms of this license. You must not remove this notice, or
  10. // any other, from this software.
  11. #ifndef __ATLCTRLS_H__
  12. #define __ATLCTRLS_H__
  13. #pragma once
  14. #ifndef __ATLAPP_H__
  15. #error atlctrls.h requires atlapp.h to be included first
  16. #endif
  17. #ifndef __ATLWIN_H__
  18. #error atlctrls.h requires atlwin.h to be included first
  19. #endif
  20. #ifndef _WIN32_WCE
  21. #include <richedit.h>
  22. #include <richole.h>
  23. #elif defined(WIN32_PLATFORM_WFSP) && !defined(_WINUSERM_H_)
  24. #include <winuserm.h>
  25. #endif // !_WIN32_WCE
  26. // protect template members from windowsx.h macros
  27. #ifdef _INC_WINDOWSX
  28. #undef GetNextSibling
  29. #undef GetPrevSibling
  30. #endif // _INC_WINDOWSX
  31. ///////////////////////////////////////////////////////////////////////////////
  32. // Classes in this file:
  33. //
  34. // CStaticT<TBase> - CStatic
  35. // CButtonT<TBase> - CButton
  36. // CListBoxT<TBase> - CListBox
  37. // CComboBoxT<TBase> - CComboBox
  38. // CEditT<TBase> - CEdit
  39. // CEditCommands<T>
  40. // CScrollBarT<TBase> - CScrollBar
  41. //
  42. // CImageList
  43. // CListViewCtrlT<TBase> - CListViewCtrl
  44. // CTreeViewCtrlT<TBase> - CTreeViewCtrl
  45. // CTreeItemT<TBase> - CTreeItem
  46. // CTreeViewCtrlExT<TBase> - CTreeViewCtrlEx
  47. // CHeaderCtrlT<TBase> - CHeaderCtrl
  48. // CToolBarCtrlT<TBase> - CToolBarCtrl
  49. // CStatusBarCtrlT<TBase> - CStatusBarCtrl
  50. // CTabCtrlT<TBase> - CTabCtrl
  51. // CToolInfo
  52. // CToolTipCtrlT<TBase> - CToolTipCtrl
  53. // CTrackBarCtrlT<TBase> - CTrackBarCtrl
  54. // CUpDownCtrlT<TBase> - CUpDownCtrl
  55. // CProgressBarCtrlT<TBase> - CProgressBarCtrl
  56. // CHotKeyCtrlT<TBase> - CHotKeyCtrl
  57. // CAnimateCtrlT<TBase> - CAnimateCtrl
  58. // CRichEditCtrlT<TBase> - CRichEditCtrl
  59. // CRichEditCommands<T>
  60. // CDragListBoxT<TBase> - CDragListBox
  61. // CDragListNotifyImpl<T>
  62. // CReBarCtrlT<TBase> - CReBarCtrl
  63. // CComboBoxExT<TBase> - CComboBoxEx
  64. // CDateTimePickerCtrlT<TBase> - CDateTimePickerCtrl
  65. // CMonthCalendarCtrlT<TBase> - CMonthCalendarCtrl
  66. // CFlatScrollBarImpl<T>
  67. // CFlatScrollBarT<TBase> - CFlatScrollBar
  68. // CIPAddressCtrlT<TBase> - CIPAddressCtrl
  69. // CPagerCtrlT<TBase> - CPagerCtrl
  70. // CLinkCtrlT<TBase> - CLinkCtrl
  71. //
  72. // CCustomDraw<T>
  73. //
  74. // CCECommandBarCtrlT<TBase> - CCECommandBarCtrl
  75. // CCECommandBandsCtrlT<TBase> - CCECommandBandsCtrl
  76. namespace WTL
  77. {
  78. // These are wrapper classes for Windows standard and common controls.
  79. // To implement a window based on a control, use following:
  80. // Example: Implementing a window based on a list box
  81. //
  82. // class CMyListBox : CWindowImpl<CMyListBox, CListBox>
  83. // {
  84. // public:
  85. // BEGIN_MSG_MAP(CMyListBox)
  86. // // put your message handler entries here
  87. // END_MSG_MAP()
  88. // };
  89. // --- Standard Windows controls ---
  90. ///////////////////////////////////////////////////////////////////////////////
  91. // CStatic - client side for a Windows STATIC control
  92. template <class TBase>
  93. class CStaticT : public TBase
  94. {
  95. public:
  96. // Constructors
  97. CStaticT(HWND hWnd = NULL) : TBase(hWnd)
  98. { }
  99. CStaticT< TBase >& operator =(HWND hWnd)
  100. {
  101. m_hWnd = hWnd;
  102. return *this;
  103. }
  104. HWND Create(HWND hWndParent, ATL::_U_RECT rect = NULL, LPCTSTR szWindowName = NULL,
  105. DWORD dwStyle = 0, DWORD dwExStyle = 0,
  106. ATL::_U_MENUorID MenuOrID = 0U, LPVOID lpCreateParam = NULL)
  107. {
  108. return TBase::Create(GetWndClassName(), hWndParent, rect.m_lpRect, szWindowName, dwStyle, dwExStyle, MenuOrID.m_hMenu, lpCreateParam);
  109. }
  110. // Attributes
  111. static LPCTSTR GetWndClassName()
  112. {
  113. return _T("STATIC");
  114. }
  115. #ifndef _WIN32_WCE
  116. HICON GetIcon() const
  117. {
  118. ATLASSERT(::IsWindow(m_hWnd));
  119. return (HICON)::SendMessage(m_hWnd, STM_GETICON, 0, 0L);
  120. }
  121. HICON SetIcon(HICON hIcon)
  122. {
  123. ATLASSERT(::IsWindow(m_hWnd));
  124. return (HICON)::SendMessage(m_hWnd, STM_SETICON, (WPARAM)hIcon, 0L);
  125. }
  126. HENHMETAFILE GetEnhMetaFile() const
  127. {
  128. ATLASSERT(::IsWindow(m_hWnd));
  129. return (HENHMETAFILE)::SendMessage(m_hWnd, STM_GETIMAGE, IMAGE_ENHMETAFILE, 0L);
  130. }
  131. HENHMETAFILE SetEnhMetaFile(HENHMETAFILE hMetaFile)
  132. {
  133. ATLASSERT(::IsWindow(m_hWnd));
  134. return (HENHMETAFILE)::SendMessage(m_hWnd, STM_SETIMAGE, IMAGE_ENHMETAFILE, (LPARAM)hMetaFile);
  135. }
  136. #else // CE specific
  137. HICON GetIcon() const
  138. {
  139. ATLASSERT(::IsWindow(m_hWnd));
  140. return (HICON)::SendMessage(m_hWnd, STM_GETIMAGE, IMAGE_ICON, 0L);
  141. }
  142. HICON SetIcon(HICON hIcon)
  143. {
  144. ATLASSERT(::IsWindow(m_hWnd));
  145. return (HICON)::SendMessage(m_hWnd, STM_SETIMAGE, IMAGE_ICON, (LPARAM)hIcon);
  146. }
  147. #endif // _WIN32_WCE
  148. CBitmapHandle GetBitmap() const
  149. {
  150. ATLASSERT(::IsWindow(m_hWnd));
  151. return CBitmapHandle((HBITMAP)::SendMessage(m_hWnd, STM_GETIMAGE, IMAGE_BITMAP, 0L));
  152. }
  153. CBitmapHandle SetBitmap(HBITMAP hBitmap)
  154. {
  155. ATLASSERT(::IsWindow(m_hWnd));
  156. return CBitmapHandle((HBITMAP)::SendMessage(m_hWnd, STM_SETIMAGE, IMAGE_BITMAP, (LPARAM)hBitmap));
  157. }
  158. HCURSOR GetCursor() const
  159. {
  160. ATLASSERT(::IsWindow(m_hWnd));
  161. return (HCURSOR)::SendMessage(m_hWnd, STM_GETIMAGE, IMAGE_CURSOR, 0L);
  162. }
  163. HCURSOR SetCursor(HCURSOR hCursor)
  164. {
  165. ATLASSERT(::IsWindow(m_hWnd));
  166. return (HCURSOR)::SendMessage(m_hWnd, STM_SETIMAGE, IMAGE_CURSOR, (LPARAM)hCursor);
  167. }
  168. };
  169. typedef CStaticT<ATL::CWindow> CStatic;
  170. ///////////////////////////////////////////////////////////////////////////////
  171. // CButton - client side for a Windows BUTTON control
  172. template <class TBase>
  173. class CButtonT : public TBase
  174. {
  175. public:
  176. // Constructors
  177. CButtonT(HWND hWnd = NULL) : TBase(hWnd)
  178. { }
  179. CButtonT< TBase >& operator =(HWND hWnd)
  180. {
  181. m_hWnd = hWnd;
  182. return *this;
  183. }
  184. HWND Create(HWND hWndParent, ATL::_U_RECT rect = NULL, LPCTSTR szWindowName = NULL,
  185. DWORD dwStyle = 0, DWORD dwExStyle = 0,
  186. ATL::_U_MENUorID MenuOrID = 0U, LPVOID lpCreateParam = NULL)
  187. {
  188. return TBase::Create(GetWndClassName(), hWndParent, rect.m_lpRect, szWindowName, dwStyle, dwExStyle, MenuOrID.m_hMenu, lpCreateParam);
  189. }
  190. // Attributes
  191. static LPCTSTR GetWndClassName()
  192. {
  193. return _T("BUTTON");
  194. }
  195. UINT GetState() const
  196. {
  197. ATLASSERT(::IsWindow(m_hWnd));
  198. return (UINT)::SendMessage(m_hWnd, BM_GETSTATE, 0, 0L);
  199. }
  200. void SetState(BOOL bHighlight)
  201. {
  202. ATLASSERT(::IsWindow(m_hWnd));
  203. ::SendMessage(m_hWnd, BM_SETSTATE, bHighlight, 0L);
  204. }
  205. int GetCheck() const
  206. {
  207. ATLASSERT(::IsWindow(m_hWnd));
  208. return (int)::SendMessage(m_hWnd, BM_GETCHECK, 0, 0L);
  209. }
  210. void SetCheck(int nCheck)
  211. {
  212. ATLASSERT(::IsWindow(m_hWnd));
  213. ::SendMessage(m_hWnd, BM_SETCHECK, nCheck, 0L);
  214. }
  215. UINT GetButtonStyle() const
  216. {
  217. ATLASSERT(::IsWindow(m_hWnd));
  218. return (UINT)::GetWindowLong(m_hWnd, GWL_STYLE) & 0xFFFF;
  219. }
  220. void SetButtonStyle(UINT nStyle, BOOL bRedraw = TRUE)
  221. {
  222. ATLASSERT(::IsWindow(m_hWnd));
  223. ::SendMessage(m_hWnd, BM_SETSTYLE, nStyle, (LPARAM)bRedraw);
  224. }
  225. #ifndef _WIN32_WCE
  226. HICON GetIcon() const
  227. {
  228. ATLASSERT(::IsWindow(m_hWnd));
  229. return (HICON)::SendMessage(m_hWnd, BM_GETIMAGE, IMAGE_ICON, 0L);
  230. }
  231. HICON SetIcon(HICON hIcon)
  232. {
  233. ATLASSERT(::IsWindow(m_hWnd));
  234. return (HICON)::SendMessage(m_hWnd, BM_SETIMAGE, IMAGE_ICON, (LPARAM)hIcon);
  235. }
  236. CBitmapHandle GetBitmap() const
  237. {
  238. ATLASSERT(::IsWindow(m_hWnd));
  239. return CBitmapHandle((HBITMAP)::SendMessage(m_hWnd, BM_GETIMAGE, IMAGE_BITMAP, 0L));
  240. }
  241. CBitmapHandle SetBitmap(HBITMAP hBitmap)
  242. {
  243. ATLASSERT(::IsWindow(m_hWnd));
  244. return CBitmapHandle((HBITMAP)::SendMessage(m_hWnd, BM_SETIMAGE, IMAGE_BITMAP, (LPARAM)hBitmap));
  245. }
  246. #endif // !_WIN32_WCE
  247. #if (_WIN32_WINNT >= 0x0501)
  248. BOOL GetIdealSize(LPSIZE lpSize) const
  249. {
  250. ATLASSERT(::IsWindow(m_hWnd));
  251. return (BOOL)::SendMessage(m_hWnd, BCM_GETIDEALSIZE, 0, (LPARAM)lpSize);
  252. }
  253. BOOL GetImageList(PBUTTON_IMAGELIST pButtonImagelist) const
  254. {
  255. ATLASSERT(::IsWindow(m_hWnd));
  256. return (BOOL)::SendMessage(m_hWnd, BCM_GETIMAGELIST, 0, (LPARAM)pButtonImagelist);
  257. }
  258. BOOL SetImageList(PBUTTON_IMAGELIST pButtonImagelist)
  259. {
  260. ATLASSERT(::IsWindow(m_hWnd));
  261. return (BOOL)::SendMessage(m_hWnd, BCM_SETIMAGELIST, 0, (LPARAM)pButtonImagelist);
  262. }
  263. BOOL GetTextMargin(LPRECT lpRect) const
  264. {
  265. ATLASSERT(::IsWindow(m_hWnd));
  266. return (BOOL)::SendMessage(m_hWnd, BCM_GETTEXTMARGIN, 0, (LPARAM)lpRect);
  267. }
  268. BOOL SetTextMargin(LPRECT lpRect)
  269. {
  270. ATLASSERT(::IsWindow(m_hWnd));
  271. return (BOOL)::SendMessage(m_hWnd, BCM_SETTEXTMARGIN, 0, (LPARAM)lpRect);
  272. }
  273. #endif // (_WIN32_WINNT >= 0x0501)
  274. #if (WINVER >= 0x0600)
  275. void SetDontClick(BOOL bDontClick)
  276. {
  277. ATLASSERT(::IsWindow(m_hWnd));
  278. ::SendMessage(m_hWnd, BM_SETDONTCLICK, (WPARAM)bDontClick, 0L);
  279. }
  280. #endif // (WINVER >= 0x0600)
  281. #if (_WIN32_WINNT >= 0x0600)
  282. BOOL SetDropDownState(BOOL bDropDown)
  283. {
  284. ATLASSERT(::IsWindow(m_hWnd));
  285. ATLASSERT((GetStyle() & (BS_SPLITBUTTON | BS_DEFSPLITBUTTON)) != 0);
  286. return (BOOL)::SendMessage(m_hWnd, BCM_SETDROPDOWNSTATE, (WPARAM)bDropDown, 0L);
  287. }
  288. BOOL GetSplitInfo(PBUTTON_SPLITINFO pSplitInfo) const
  289. {
  290. ATLASSERT(::IsWindow(m_hWnd));
  291. ATLASSERT((GetStyle() & (BS_SPLITBUTTON | BS_DEFSPLITBUTTON)) != 0);
  292. return (BOOL)::SendMessage(m_hWnd, BCM_GETSPLITINFO, 0, (LPARAM)pSplitInfo);
  293. }
  294. BOOL SetSplitInfo(PBUTTON_SPLITINFO pSplitInfo)
  295. {
  296. ATLASSERT(::IsWindow(m_hWnd));
  297. ATLASSERT((GetStyle() & (BS_SPLITBUTTON | BS_DEFSPLITBUTTON)) != 0);
  298. return (BOOL)::SendMessage(m_hWnd, BCM_SETSPLITINFO, 0, (LPARAM)pSplitInfo);
  299. }
  300. int GetNoteLength() const
  301. {
  302. ATLASSERT(::IsWindow(m_hWnd));
  303. ATLASSERT((GetStyle() & (BS_COMMANDLINK | BS_DEFCOMMANDLINK)) != 0);
  304. return (int)::SendMessage(m_hWnd, BCM_GETNOTELENGTH, 0, 0L);
  305. }
  306. BOOL GetNote(LPWSTR lpstrNoteText, int cchNoteText) const
  307. {
  308. ATLASSERT(::IsWindow(m_hWnd));
  309. ATLASSERT((GetStyle() & (BS_COMMANDLINK | BS_DEFCOMMANDLINK)) != 0);
  310. return (BOOL)::SendMessage(m_hWnd, BCM_GETNOTE, cchNoteText, (LPARAM)lpstrNoteText);
  311. }
  312. BOOL SetNote(LPCWSTR lpstrNoteText)
  313. {
  314. ATLASSERT(::IsWindow(m_hWnd));
  315. ATLASSERT((GetStyle() & (BS_COMMANDLINK | BS_DEFCOMMANDLINK)) != 0);
  316. return (BOOL)::SendMessage(m_hWnd, BCM_SETNOTE, 0, (LPARAM)lpstrNoteText);
  317. }
  318. LRESULT SetElevationRequiredState(BOOL bSet)
  319. {
  320. ATLASSERT(::IsWindow(m_hWnd));
  321. return ::SendMessage(m_hWnd, BCM_SETSHIELD, 0, (LPARAM)bSet);
  322. }
  323. #endif // (_WIN32_WINNT >= 0x0600)
  324. // Operations
  325. void Click()
  326. {
  327. ATLASSERT(::IsWindow(m_hWnd));
  328. ::SendMessage(m_hWnd, BM_CLICK, 0, 0L);
  329. }
  330. };
  331. typedef CButtonT<ATL::CWindow> CButton;
  332. ///////////////////////////////////////////////////////////////////////////////
  333. // CListBox - client side for a Windows LISTBOX control
  334. template <class TBase>
  335. class CListBoxT : public TBase
  336. {
  337. public:
  338. // Constructors
  339. CListBoxT(HWND hWnd = NULL) : TBase(hWnd)
  340. { }
  341. CListBoxT< TBase >& operator =(HWND hWnd)
  342. {
  343. m_hWnd = hWnd;
  344. return *this;
  345. }
  346. HWND Create(HWND hWndParent, ATL::_U_RECT rect = NULL, LPCTSTR szWindowName = NULL,
  347. DWORD dwStyle = 0, DWORD dwExStyle = 0,
  348. ATL::_U_MENUorID MenuOrID = 0U, LPVOID lpCreateParam = NULL)
  349. {
  350. return TBase::Create(GetWndClassName(), hWndParent, rect.m_lpRect, szWindowName, dwStyle, dwExStyle, MenuOrID.m_hMenu, lpCreateParam);
  351. }
  352. // Attributes
  353. static LPCTSTR GetWndClassName()
  354. {
  355. return _T("LISTBOX");
  356. }
  357. // for entire listbox
  358. int GetCount() const
  359. {
  360. ATLASSERT(::IsWindow(m_hWnd));
  361. return (int)::SendMessage(m_hWnd, LB_GETCOUNT, 0, 0L);
  362. }
  363. #ifndef _WIN32_WCE
  364. int SetCount(int cItems)
  365. {
  366. ATLASSERT(::IsWindow(m_hWnd));
  367. ATLASSERT(((GetStyle() & LBS_NODATA) != 0) && ((GetStyle() & LBS_HASSTRINGS) == 0));
  368. return (int)::SendMessage(m_hWnd, LB_SETCOUNT, cItems, 0L);
  369. }
  370. #endif // !_WIN32_WCE
  371. int GetHorizontalExtent() const
  372. {
  373. ATLASSERT(::IsWindow(m_hWnd));
  374. return (int)::SendMessage(m_hWnd, LB_GETHORIZONTALEXTENT, 0, 0L);
  375. }
  376. void SetHorizontalExtent(int cxExtent)
  377. {
  378. ATLASSERT(::IsWindow(m_hWnd));
  379. ::SendMessage(m_hWnd, LB_SETHORIZONTALEXTENT, cxExtent, 0L);
  380. }
  381. int GetTopIndex() const
  382. {
  383. ATLASSERT(::IsWindow(m_hWnd));
  384. return (int)::SendMessage(m_hWnd, LB_GETTOPINDEX, 0, 0L);
  385. }
  386. int SetTopIndex(int nIndex)
  387. {
  388. ATLASSERT(::IsWindow(m_hWnd));
  389. return (int)::SendMessage(m_hWnd, LB_SETTOPINDEX, nIndex, 0L);
  390. }
  391. LCID GetLocale() const
  392. {
  393. ATLASSERT(::IsWindow(m_hWnd));
  394. return (LCID)::SendMessage(m_hWnd, LB_GETLOCALE, 0, 0L);
  395. }
  396. LCID SetLocale(LCID nNewLocale)
  397. {
  398. ATLASSERT(::IsWindow(m_hWnd));
  399. return (LCID)::SendMessage(m_hWnd, LB_SETLOCALE, (WPARAM)nNewLocale, 0L);
  400. }
  401. #if (WINVER >= 0x0500) && !defined(_WIN32_WCE)
  402. DWORD GetListBoxInfo() const
  403. {
  404. ATLASSERT(::IsWindow(m_hWnd));
  405. #if (_WIN32_WINNT >= 0x0501)
  406. return (DWORD)::SendMessage(m_hWnd, LB_GETLISTBOXINFO, 0, 0L);
  407. #else // !(_WIN32_WINNT >= 0x0501)
  408. return ::GetListBoxInfo(m_hWnd);
  409. #endif // !(_WIN32_WINNT >= 0x0501)
  410. }
  411. #endif // (WINVER >= 0x0500) && !defined(_WIN32_WCE)
  412. // for single-selection listboxes
  413. int GetCurSel() const
  414. {
  415. ATLASSERT(::IsWindow(m_hWnd));
  416. ATLASSERT((GetStyle() & (LBS_MULTIPLESEL | LBS_EXTENDEDSEL)) == 0);
  417. return (int)::SendMessage(m_hWnd, LB_GETCURSEL, 0, 0L);
  418. }
  419. int SetCurSel(int nSelect)
  420. {
  421. ATLASSERT(::IsWindow(m_hWnd));
  422. ATLASSERT((GetStyle() & (LBS_MULTIPLESEL | LBS_EXTENDEDSEL)) == 0);
  423. return (int)::SendMessage(m_hWnd, LB_SETCURSEL, nSelect, 0L);
  424. }
  425. // for multiple-selection listboxes
  426. int GetSel(int nIndex) const // also works for single-selection
  427. {
  428. ATLASSERT(::IsWindow(m_hWnd));
  429. return (int)::SendMessage(m_hWnd, LB_GETSEL, nIndex, 0L);
  430. }
  431. int SetSel(int nIndex, BOOL bSelect = TRUE)
  432. {
  433. ATLASSERT(::IsWindow(m_hWnd));
  434. ATLASSERT((GetStyle() & (LBS_MULTIPLESEL | LBS_EXTENDEDSEL)) != 0);
  435. return (int)::SendMessage(m_hWnd, LB_SETSEL, bSelect, nIndex);
  436. }
  437. int GetSelCount() const
  438. {
  439. ATLASSERT(::IsWindow(m_hWnd));
  440. ATLASSERT((GetStyle() & (LBS_MULTIPLESEL | LBS_EXTENDEDSEL)) != 0);
  441. return (int)::SendMessage(m_hWnd, LB_GETSELCOUNT, 0, 0L);
  442. }
  443. int GetSelItems(int nMaxItems, LPINT rgIndex) const
  444. {
  445. ATLASSERT(::IsWindow(m_hWnd));
  446. ATLASSERT((GetStyle() & (LBS_MULTIPLESEL | LBS_EXTENDEDSEL)) != 0);
  447. return (int)::SendMessage(m_hWnd, LB_GETSELITEMS, nMaxItems, (LPARAM)rgIndex);
  448. }
  449. int GetAnchorIndex() const
  450. {
  451. ATLASSERT(::IsWindow(m_hWnd));
  452. ATLASSERT((GetStyle() & (LBS_MULTIPLESEL | LBS_EXTENDEDSEL)) != 0);
  453. return (int)::SendMessage(m_hWnd, LB_GETANCHORINDEX, 0, 0L);
  454. }
  455. void SetAnchorIndex(int nIndex)
  456. {
  457. ATLASSERT(::IsWindow(m_hWnd));
  458. ATLASSERT((GetStyle() & (LBS_MULTIPLESEL | LBS_EXTENDEDSEL)) != 0);
  459. ::SendMessage(m_hWnd, LB_SETANCHORINDEX, nIndex, 0L);
  460. }
  461. int GetCaretIndex() const
  462. {
  463. ATLASSERT(::IsWindow(m_hWnd));
  464. return (int)::SendMessage(m_hWnd, LB_GETCARETINDEX, 0, 0);
  465. }
  466. int SetCaretIndex(int nIndex, BOOL bScroll = TRUE)
  467. {
  468. ATLASSERT(::IsWindow(m_hWnd));
  469. return (int)::SendMessage(m_hWnd, LB_SETCARETINDEX, nIndex, MAKELONG(bScroll, 0));
  470. }
  471. // for listbox items
  472. DWORD_PTR GetItemData(int nIndex) const
  473. {
  474. ATLASSERT(::IsWindow(m_hWnd));
  475. return (DWORD_PTR)::SendMessage(m_hWnd, LB_GETITEMDATA, nIndex, 0L);
  476. }
  477. int SetItemData(int nIndex, DWORD_PTR dwItemData)
  478. {
  479. ATLASSERT(::IsWindow(m_hWnd));
  480. return (int)::SendMessage(m_hWnd, LB_SETITEMDATA, nIndex, (LPARAM)dwItemData);
  481. }
  482. void* GetItemDataPtr(int nIndex) const
  483. {
  484. ATLASSERT(::IsWindow(m_hWnd));
  485. return (void*)::SendMessage(m_hWnd, LB_GETITEMDATA, nIndex, 0L);
  486. }
  487. int SetItemDataPtr(int nIndex, void* pData)
  488. {
  489. ATLASSERT(::IsWindow(m_hWnd));
  490. return SetItemData(nIndex, (DWORD_PTR)pData);
  491. }
  492. int GetItemRect(int nIndex, LPRECT lpRect) const
  493. {
  494. ATLASSERT(::IsWindow(m_hWnd));
  495. return (int)::SendMessage(m_hWnd, LB_GETITEMRECT, nIndex, (LPARAM)lpRect);
  496. }
  497. int GetText(int nIndex, LPTSTR lpszBuffer) const
  498. {
  499. ATLASSERT(::IsWindow(m_hWnd));
  500. return (int)::SendMessage(m_hWnd, LB_GETTEXT, nIndex, (LPARAM)lpszBuffer);
  501. }
  502. #ifndef _ATL_NO_COM
  503. #ifdef _OLEAUTO_H_
  504. BOOL GetTextBSTR(int nIndex, BSTR& bstrText) const
  505. {
  506. USES_CONVERSION;
  507. ATLASSERT(::IsWindow(m_hWnd));
  508. ATLASSERT(bstrText == NULL);
  509. int nLen = GetTextLen(nIndex);
  510. if(nLen == LB_ERR)
  511. return FALSE;
  512. CTempBuffer<TCHAR, _WTL_STACK_ALLOC_THRESHOLD> buff;
  513. LPTSTR lpstrText = buff.Allocate(nLen + 1);
  514. if(lpstrText == NULL)
  515. return FALSE;
  516. if(GetText(nIndex, lpstrText) == LB_ERR)
  517. return FALSE;
  518. bstrText = ::SysAllocString(T2OLE(lpstrText));
  519. return (bstrText != NULL) ? TRUE : FALSE;
  520. }
  521. #endif // _OLEAUTO_H_
  522. #endif // !_ATL_NO_COM
  523. #if defined(_WTL_USE_CSTRING) || defined(__ATLSTR_H__)
  524. int GetText(int nIndex, _CSTRING_NS::CString& strText) const
  525. {
  526. ATLASSERT(::IsWindow(m_hWnd));
  527. int cchLen = GetTextLen(nIndex);
  528. if(cchLen == LB_ERR)
  529. return LB_ERR;
  530. int nRet = LB_ERR;
  531. LPTSTR lpstr = strText.GetBufferSetLength(cchLen);
  532. if(lpstr != NULL)
  533. {
  534. nRet = GetText(nIndex, lpstr);
  535. strText.ReleaseBuffer();
  536. }
  537. return nRet;
  538. }
  539. #endif // defined(_WTL_USE_CSTRING) || defined(__ATLSTR_H__)
  540. int GetTextLen(int nIndex) const
  541. {
  542. ATLASSERT(::IsWindow(m_hWnd));
  543. return (int)::SendMessage(m_hWnd, LB_GETTEXTLEN, nIndex, 0L);
  544. }
  545. int GetItemHeight(int nIndex) const
  546. {
  547. ATLASSERT(::IsWindow(m_hWnd));
  548. return (int)::SendMessage(m_hWnd, LB_GETITEMHEIGHT, nIndex, 0L);
  549. }
  550. int SetItemHeight(int nIndex, UINT cyItemHeight)
  551. {
  552. ATLASSERT(::IsWindow(m_hWnd));
  553. return (int)::SendMessage(m_hWnd, LB_SETITEMHEIGHT, nIndex, MAKELONG(cyItemHeight, 0));
  554. }
  555. // Settable only attributes
  556. void SetColumnWidth(int cxWidth)
  557. {
  558. ATLASSERT(::IsWindow(m_hWnd));
  559. ::SendMessage(m_hWnd, LB_SETCOLUMNWIDTH, cxWidth, 0L);
  560. }
  561. BOOL SetTabStops(int nTabStops, LPINT rgTabStops)
  562. {
  563. ATLASSERT(::IsWindow(m_hWnd));
  564. ATLASSERT((GetStyle() & LBS_USETABSTOPS) != 0);
  565. return (BOOL)::SendMessage(m_hWnd, LB_SETTABSTOPS, nTabStops, (LPARAM)rgTabStops);
  566. }
  567. BOOL SetTabStops()
  568. {
  569. ATLASSERT(::IsWindow(m_hWnd));
  570. ATLASSERT((GetStyle() & LBS_USETABSTOPS) != 0);
  571. return (BOOL)::SendMessage(m_hWnd, LB_SETTABSTOPS, 0, 0L);
  572. }
  573. BOOL SetTabStops(const int& cxEachStop) // takes an 'int'
  574. {
  575. ATLASSERT(::IsWindow(m_hWnd));
  576. ATLASSERT((GetStyle() & LBS_USETABSTOPS) != 0);
  577. return (BOOL)::SendMessage(m_hWnd, LB_SETTABSTOPS, 1, (LPARAM)(LPINT)&cxEachStop);
  578. }
  579. // Operations
  580. int InitStorage(int nItems, UINT nBytes)
  581. {
  582. ATLASSERT(::IsWindow(m_hWnd));
  583. return (int)::SendMessage(m_hWnd, LB_INITSTORAGE, (WPARAM)nItems, nBytes);
  584. }
  585. void ResetContent()
  586. {
  587. ATLASSERT(::IsWindow(m_hWnd));
  588. ::SendMessage(m_hWnd, LB_RESETCONTENT, 0, 0L);
  589. }
  590. UINT ItemFromPoint(POINT pt, BOOL& bOutside) const
  591. {
  592. ATLASSERT(::IsWindow(m_hWnd));
  593. DWORD dw = (DWORD)::SendMessage(m_hWnd, LB_ITEMFROMPOINT, 0, MAKELPARAM(pt.x, pt.y));
  594. bOutside = (BOOL)HIWORD(dw);
  595. return (UINT)LOWORD(dw);
  596. }
  597. // manipulating listbox items
  598. int AddString(LPCTSTR lpszItem)
  599. {
  600. ATLASSERT(::IsWindow(m_hWnd));
  601. return (int)::SendMessage(m_hWnd, LB_ADDSTRING, 0, (LPARAM)lpszItem);
  602. }
  603. int DeleteString(UINT nIndex)
  604. {
  605. ATLASSERT(::IsWindow(m_hWnd));
  606. return (int)::SendMessage(m_hWnd, LB_DELETESTRING, nIndex, 0L);
  607. }
  608. int InsertString(int nIndex, LPCTSTR lpszItem)
  609. {
  610. ATLASSERT(::IsWindow(m_hWnd));
  611. return (int)::SendMessage(m_hWnd, LB_INSERTSTRING, nIndex, (LPARAM)lpszItem);
  612. }
  613. #ifndef _WIN32_WCE
  614. int Dir(UINT attr, LPCTSTR lpszWildCard)
  615. {
  616. ATLASSERT(::IsWindow(m_hWnd));
  617. return (int)::SendMessage(m_hWnd, LB_DIR, attr, (LPARAM)lpszWildCard);
  618. }
  619. int AddFile(LPCTSTR lpstrFileName)
  620. {
  621. ATLASSERT(::IsWindow(m_hWnd));
  622. return (int)::SendMessage(m_hWnd, LB_ADDFILE, 0, (LPARAM)lpstrFileName);
  623. }
  624. #endif // !_WIN32_WCE
  625. // selection helpers
  626. int FindString(int nStartAfter, LPCTSTR lpszItem) const
  627. {
  628. ATLASSERT(::IsWindow(m_hWnd));
  629. return (int)::SendMessage(m_hWnd, LB_FINDSTRING, nStartAfter, (LPARAM)lpszItem);
  630. }
  631. int FindStringExact(int nIndexStart, LPCTSTR lpszFind) const
  632. {
  633. ATLASSERT(::IsWindow(m_hWnd));
  634. return (int)::SendMessage(m_hWnd, LB_FINDSTRINGEXACT, nIndexStart, (LPARAM)lpszFind);
  635. }
  636. int SelectString(int nStartAfter, LPCTSTR lpszItem)
  637. {
  638. ATLASSERT(::IsWindow(m_hWnd));
  639. return (int)::SendMessage(m_hWnd, LB_SELECTSTRING, nStartAfter, (LPARAM)lpszItem);
  640. }
  641. int SelItemRange(BOOL bSelect, int nFirstItem, int nLastItem)
  642. {
  643. ATLASSERT(::IsWindow(m_hWnd));
  644. ATLASSERT((GetStyle() & (LBS_MULTIPLESEL | LBS_EXTENDEDSEL)) != 0);
  645. ATLASSERT(nFirstItem <= nLastItem);
  646. return bSelect ? (int)::SendMessage(m_hWnd, LB_SELITEMRANGEEX, nFirstItem, nLastItem) : (int)::SendMessage(m_hWnd, LB_SELITEMRANGEEX, nLastItem, nFirstItem);
  647. }
  648. #ifdef WIN32_PLATFORM_WFSP // SmartPhone only messages
  649. DWORD GetInputMode(BOOL bCurrentMode = TRUE)
  650. {
  651. return SendMessage(LB_GETINPUTMODE, 0, (LPARAM)bCurrentMode);
  652. }
  653. BOOL SetInputMode(DWORD dwMode)
  654. {
  655. return SendMessage(LB_SETINPUTMODE, 0, (LPARAM)dwMode);
  656. }
  657. #endif // WIN32_PLATFORM_WFSP
  658. };
  659. typedef CListBoxT<ATL::CWindow> CListBox;
  660. ///////////////////////////////////////////////////////////////////////////////
  661. // CComboBox - client side for a Windows COMBOBOX control
  662. #ifndef WIN32_PLATFORM_WFSP // No COMBOBOX on SmartPhones
  663. template <class TBase>
  664. class CComboBoxT : public TBase
  665. {
  666. public:
  667. // Constructors
  668. CComboBoxT(HWND hWnd = NULL) : TBase(hWnd)
  669. { }
  670. CComboBoxT< TBase >& operator =(HWND hWnd)
  671. {
  672. m_hWnd = hWnd;
  673. return *this;
  674. }
  675. HWND Create(HWND hWndParent, ATL::_U_RECT rect = NULL, LPCTSTR szWindowName = NULL,
  676. DWORD dwStyle = 0, DWORD dwExStyle = 0,
  677. ATL::_U_MENUorID MenuOrID = 0U, LPVOID lpCreateParam = NULL)
  678. {
  679. return TBase::Create(GetWndClassName(), hWndParent, rect.m_lpRect, szWindowName, dwStyle, dwExStyle, MenuOrID.m_hMenu, lpCreateParam);
  680. }
  681. // Attributes
  682. static LPCTSTR GetWndClassName()
  683. {
  684. return _T("COMBOBOX");
  685. }
  686. // for entire combo box
  687. int GetCount() const
  688. {
  689. ATLASSERT(::IsWindow(m_hWnd));
  690. return (int)::SendMessage(m_hWnd, CB_GETCOUNT, 0, 0L);
  691. }
  692. int GetCurSel() const
  693. {
  694. ATLASSERT(::IsWindow(m_hWnd));
  695. return (int)::SendMessage(m_hWnd, CB_GETCURSEL, 0, 0L);
  696. }
  697. int SetCurSel(int nSelect)
  698. {
  699. ATLASSERT(::IsWindow(m_hWnd));
  700. return (int)::SendMessage(m_hWnd, CB_SETCURSEL, nSelect, 0L);
  701. }
  702. LCID GetLocale() const
  703. {
  704. ATLASSERT(::IsWindow(m_hWnd));
  705. return (LCID)::SendMessage(m_hWnd, CB_GETLOCALE, 0, 0L);
  706. }
  707. LCID SetLocale(LCID nNewLocale)
  708. {
  709. ATLASSERT(::IsWindow(m_hWnd));
  710. return (LCID)::SendMessage(m_hWnd, CB_SETLOCALE, (WPARAM)nNewLocale, 0L);
  711. }
  712. int GetTopIndex() const
  713. {
  714. ATLASSERT(::IsWindow(m_hWnd));
  715. return (int)::SendMessage(m_hWnd, CB_GETTOPINDEX, 0, 0L);
  716. }
  717. int SetTopIndex(int nIndex)
  718. {
  719. ATLASSERT(::IsWindow(m_hWnd));
  720. return (int)::SendMessage(m_hWnd, CB_SETTOPINDEX, nIndex, 0L);
  721. }
  722. UINT GetHorizontalExtent() const
  723. {
  724. ATLASSERT(::IsWindow(m_hWnd));
  725. return (UINT)::SendMessage(m_hWnd, CB_GETHORIZONTALEXTENT, 0, 0L);
  726. }
  727. void SetHorizontalExtent(UINT nExtent)
  728. {
  729. ATLASSERT(::IsWindow(m_hWnd));
  730. ::SendMessage(m_hWnd, CB_SETHORIZONTALEXTENT, nExtent, 0L);
  731. }
  732. int GetDroppedWidth() const
  733. {
  734. ATLASSERT(::IsWindow(m_hWnd));
  735. return (int)::SendMessage(m_hWnd, CB_GETDROPPEDWIDTH, 0, 0L);
  736. }
  737. int SetDroppedWidth(UINT nWidth)
  738. {
  739. ATLASSERT(::IsWindow(m_hWnd));
  740. return (int)::SendMessage(m_hWnd, CB_SETDROPPEDWIDTH, nWidth, 0L);
  741. }
  742. #if ((WINVER >= 0x0500) && !defined(_WIN32_WCE)) || (defined(_WIN32_WCE) && (_WIN32_WCE >= 420))
  743. BOOL GetComboBoxInfo(PCOMBOBOXINFO pComboBoxInfo) const
  744. {
  745. ATLASSERT(::IsWindow(m_hWnd));
  746. #if ((_WIN32_WINNT >= 0x0501) && !defined(_WIN32_WCE)) || (defined(_WIN32_WCE) && (_WIN32_WCE >= 420))
  747. return (BOOL)::SendMessage(m_hWnd, CB_GETCOMBOBOXINFO, 0, (LPARAM)pComboBoxInfo);
  748. #else // !((_WIN32_WINNT >= 0x0501) && !defined(_WIN32_WCE)) || (defined(_WIN32_WCE) && (_WIN32_WCE >= 420))
  749. return ::GetComboBoxInfo(m_hWnd, pComboBoxInfo);
  750. #endif // !((_WIN32_WINNT >= 0x0501) && !defined(_WIN32_WCE)) || (defined(_WIN32_WCE) && (_WIN32_WCE >= 420))
  751. }
  752. #endif // ((WINVER >= 0x0500) && !defined(_WIN32_WCE)) || (defined(_WIN32_WCE) && (_WIN32_WCE >= 420))
  753. // for edit control
  754. DWORD GetEditSel() const
  755. {
  756. ATLASSERT(::IsWindow(m_hWnd));
  757. return (DWORD)::SendMessage(m_hWnd, CB_GETEDITSEL, 0, 0L);
  758. }
  759. BOOL SetEditSel(int nStartChar, int nEndChar)
  760. {
  761. ATLASSERT(::IsWindow(m_hWnd));
  762. return (BOOL)::SendMessage(m_hWnd, CB_SETEDITSEL, 0, MAKELONG(nStartChar, nEndChar));
  763. }
  764. // for combobox item
  765. DWORD_PTR GetItemData(int nIndex) const
  766. {
  767. ATLASSERT(::IsWindow(m_hWnd));
  768. return (DWORD_PTR)::SendMessage(m_hWnd, CB_GETITEMDATA, nIndex, 0L);
  769. }
  770. int SetItemData(int nIndex, DWORD_PTR dwItemData)
  771. {
  772. ATLASSERT(::IsWindow(m_hWnd));
  773. return (int)::SendMessage(m_hWnd, CB_SETITEMDATA, nIndex, (LPARAM)dwItemData);
  774. }
  775. void* GetItemDataPtr(int nIndex) const
  776. {
  777. ATLASSERT(::IsWindow(m_hWnd));
  778. return (void*)GetItemData(nIndex);
  779. }
  780. int SetItemDataPtr(int nIndex, void* pData)
  781. {
  782. ATLASSERT(::IsWindow(m_hWnd));
  783. return SetItemData(nIndex, (DWORD_PTR)pData);
  784. }
  785. int GetLBText(int nIndex, LPTSTR lpszText) const
  786. {
  787. ATLASSERT(::IsWindow(m_hWnd));
  788. return (int)::SendMessage(m_hWnd, CB_GETLBTEXT, nIndex, (LPARAM)lpszText);
  789. }
  790. #ifndef _ATL_NO_COM
  791. BOOL GetLBTextBSTR(int nIndex, BSTR& bstrText) const
  792. {
  793. USES_CONVERSION;
  794. ATLASSERT(::IsWindow(m_hWnd));
  795. ATLASSERT(bstrText == NULL);
  796. int nLen = GetLBTextLen(nIndex);
  797. if(nLen == CB_ERR)
  798. return FALSE;
  799. CTempBuffer<TCHAR, _WTL_STACK_ALLOC_THRESHOLD> buff;
  800. LPTSTR lpstrText = buff.Allocate(nLen + 1);
  801. if(lpstrText == NULL)
  802. return FALSE;
  803. if(GetLBText(nIndex, lpstrText) == CB_ERR)
  804. return FALSE;
  805. bstrText = ::SysAllocString(T2OLE(lpstrText));
  806. return (bstrText != NULL) ? TRUE : FALSE;
  807. }
  808. #endif // !_ATL_NO_COM
  809. #if defined(_WTL_USE_CSTRING) || defined(__ATLSTR_H__)
  810. int GetLBText(int nIndex, _CSTRING_NS::CString& strText) const
  811. {
  812. ATLASSERT(::IsWindow(m_hWnd));
  813. int cchLen = GetLBTextLen(nIndex);
  814. if(cchLen == CB_ERR)
  815. return CB_ERR;
  816. int nRet = CB_ERR;
  817. LPTSTR lpstr = strText.GetBufferSetLength(cchLen);
  818. if(lpstr != NULL)
  819. {
  820. nRet = GetLBText(nIndex, lpstr);
  821. strText.ReleaseBuffer();
  822. }
  823. return nRet;
  824. }
  825. #endif // defined(_WTL_USE_CSTRING) || defined(__ATLSTR_H__)
  826. int GetLBTextLen(int nIndex) const
  827. {
  828. ATLASSERT(::IsWindow(m_hWnd));
  829. return (int)::SendMessage(m_hWnd, CB_GETLBTEXTLEN, nIndex, 0L);
  830. }
  831. int GetItemHeight(int nIndex) const
  832. {
  833. ATLASSERT(::IsWindow(m_hWnd));
  834. return (int)::SendMessage(m_hWnd, CB_GETITEMHEIGHT, nIndex, 0L);
  835. }
  836. int SetItemHeight(int nIndex, UINT cyItemHeight)
  837. {
  838. ATLASSERT(::IsWindow(m_hWnd));
  839. return (int)::SendMessage(m_hWnd, CB_SETITEMHEIGHT, nIndex, MAKELONG(cyItemHeight, 0));
  840. }
  841. BOOL GetExtendedUI() const
  842. {
  843. ATLASSERT(::IsWindow(m_hWnd));
  844. return (BOOL)::SendMessage(m_hWnd, CB_GETEXTENDEDUI, 0, 0L);
  845. }
  846. int SetExtendedUI(BOOL bExtended = TRUE)
  847. {
  848. ATLASSERT(::IsWindow(m_hWnd));
  849. return (int)::SendMessage(m_hWnd, CB_SETEXTENDEDUI, bExtended, 0L);
  850. }
  851. void GetDroppedControlRect(LPRECT lprect) const
  852. {
  853. ATLASSERT(::IsWindow(m_hWnd));
  854. ::SendMessage(m_hWnd, CB_GETDROPPEDCONTROLRECT, 0, (LPARAM)lprect);
  855. }
  856. BOOL GetDroppedState() const
  857. {
  858. ATLASSERT(::IsWindow(m_hWnd));
  859. return (BOOL)::SendMessage(m_hWnd, CB_GETDROPPEDSTATE, 0, 0L);
  860. }
  861. #if (_WIN32_WINNT >= 0x0501)
  862. int GetMinVisible() const
  863. {
  864. ATLASSERT(::IsWindow(m_hWnd));
  865. return (int)::SendMessage(m_hWnd, CB_GETMINVISIBLE, 0, 0L);
  866. }
  867. BOOL SetMinVisible(int nMinVisible)
  868. {
  869. ATLASSERT(::IsWindow(m_hWnd));
  870. return (BOOL)::SendMessage(m_hWnd, CB_SETMINVISIBLE, nMinVisible, 0L);
  871. }
  872. // Vista only
  873. BOOL GetCueBannerText(LPWSTR lpwText, int cchText) const
  874. {
  875. #ifndef CB_GETCUEBANNER
  876. const UINT CB_GETCUEBANNER = (CBM_FIRST + 4);
  877. #endif
  878. ATLASSERT(::IsWindow(m_hWnd));
  879. return (BOOL)::SendMessage(m_hWnd, CB_GETCUEBANNER, (WPARAM)lpwText, cchText);
  880. }
  881. // Vista only
  882. BOOL SetCueBannerText(LPCWSTR lpcwText)
  883. {
  884. #ifndef CB_SETCUEBANNER
  885. const UINT CB_SETCUEBANNER = (CBM_FIRST + 3);
  886. #endif
  887. ATLASSERT(::IsWindow(m_hWnd));
  888. return (BOOL)::SendMessage(m_hWnd, CB_SETCUEBANNER, 0, (LPARAM)lpcwText);
  889. }
  890. #endif // (_WIN32_WINNT >= 0x0501)
  891. // Operations
  892. int InitStorage(int nItems, UINT nBytes)
  893. {
  894. ATLASSERT(::IsWindow(m_hWnd));
  895. return (int)::SendMessage(m_hWnd, CB_INITSTORAGE, (WPARAM)nItems, nBytes);
  896. }
  897. void ResetContent()
  898. {
  899. ATLASSERT(::IsWindow(m_hWnd));
  900. ::SendMessage(m_hWnd, CB_RESETCONTENT, 0, 0L);
  901. }
  902. // for edit control
  903. BOOL LimitText(int nMaxChars)
  904. {
  905. ATLASSERT(::IsWindow(m_hWnd));
  906. return (BOOL)::SendMessage(m_hWnd, CB_LIMITTEXT, nMaxChars, 0L);
  907. }
  908. // for drop-down combo boxes
  909. void ShowDropDown(BOOL bShowIt = TRUE)
  910. {
  911. ATLASSERT(::IsWindow(m_hWnd));
  912. ::SendMessage(m_hWnd, CB_SHOWDROPDOWN, bShowIt, 0L);
  913. }
  914. // manipulating listbox items
  915. int AddString(LPCTSTR lpszString)
  916. {
  917. ATLASSERT(::IsWindow(m_hWnd));
  918. return (int)::SendMessage(m_hWnd, CB_ADDSTRING, 0, (LPARAM)lpszString);
  919. }
  920. int DeleteString(UINT nIndex)
  921. {
  922. ATLASSERT(::IsWindow(m_hWnd));
  923. return (int)::SendMessage(m_hWnd, CB_DELETESTRING, nIndex, 0L);
  924. }
  925. int InsertString(int nIndex, LPCTSTR lpszString)
  926. {
  927. ATLASSERT(::IsWindow(m_hWnd));
  928. return (int)::SendMessage(m_hWnd, CB_INSERTSTRING, nIndex, (LPARAM)lpszString);
  929. }
  930. #ifndef _WIN32_WCE
  931. int Dir(UINT attr, LPCTSTR lpszWildCard)
  932. {
  933. ATLASSERT(::IsWindow(m_hWnd));
  934. return (int)::SendMessage(m_hWnd, CB_DIR, attr, (LPARAM)lpszWildCard);
  935. }
  936. #endif // !_WIN32_WCE
  937. // selection helpers
  938. int FindString(int nStartAfter, LPCTSTR lpszString) const
  939. {
  940. ATLASSERT(::IsWindow(m_hWnd));
  941. return (int)::SendMessage(m_hWnd, CB_FINDSTRING, nStartAfter, (LPARAM)lpszString);
  942. }
  943. int FindStringExact(int nIndexStart, LPCTSTR lpszFind) const
  944. {
  945. ATLASSERT(::IsWindow(m_hWnd));
  946. return (int)::SendMessage(m_hWnd, CB_FINDSTRINGEXACT, nIndexStart, (LPARAM)lpszFind);
  947. }
  948. int SelectString(int nStartAfter, LPCTSTR lpszString)
  949. {
  950. ATLASSERT(::IsWindow(m_hWnd));
  951. return (int)::SendMessage(m_hWnd, CB_SELECTSTRING, nStartAfter, (LPARAM)lpszString);
  952. }
  953. // Clipboard operations
  954. void Clear()
  955. {
  956. ATLASSERT(::IsWindow(m_hWnd));
  957. ::SendMessage(m_hWnd, WM_CLEAR, 0, 0L);
  958. }
  959. void Copy()
  960. {
  961. ATLASSERT(::IsWindow(m_hWnd));
  962. ::SendMessage(m_hWnd, WM_COPY, 0, 0L);
  963. }
  964. void Cut()
  965. {
  966. ATLASSERT(::IsWindow(m_hWnd));
  967. ::SendMessage(m_hWnd, WM_CUT, 0, 0L);
  968. }
  969. void Paste()
  970. {
  971. ATLASSERT(::IsWindow(m_hWnd));
  972. ::SendMessage(m_hWnd, WM_PASTE, 0, 0L);
  973. }
  974. };
  975. typedef CComboBoxT<ATL::CWindow> CComboBox;
  976. #endif // !WIN32_PLATFORM_WFSP
  977. ///////////////////////////////////////////////////////////////////////////////
  978. // CEdit - client side for a Windows EDIT control
  979. template <class TBase>
  980. class CEditT : public TBase
  981. {
  982. public:
  983. // Constructors
  984. CEditT(HWND hWnd = NULL) : TBase(hWnd)
  985. { }
  986. CEditT< TBase >& operator =(HWND hWnd)
  987. {
  988. m_hWnd = hWnd;
  989. return *this;
  990. }
  991. HWND Create(HWND hWndParent, ATL::_U_RECT rect = NULL, LPCTSTR szWindowName = NULL,
  992. DWORD dwStyle = 0, DWORD dwExStyle = 0,
  993. ATL::_U_MENUorID MenuOrID = 0U, LPVOID lpCreateParam = NULL)
  994. {
  995. return TBase::Create(GetWndClassName(), hWndParent, rect.m_lpRect, szWindowName, dwStyle, dwExStyle, MenuOrID.m_hMenu, lpCreateParam);
  996. }
  997. // Attributes
  998. static LPCTSTR GetWndClassName()
  999. {
  1000. return _T("EDIT");
  1001. }
  1002. BOOL CanUndo() const
  1003. {
  1004. ATLASSERT(::IsWindow(m_hWnd));
  1005. return (BOOL)::SendMessage(m_hWnd, EM_CANUNDO, 0, 0L);
  1006. }
  1007. int GetLineCount() const
  1008. {
  1009. ATLASSERT(::IsWindow(m_hWnd));
  1010. return (int)::SendMessage(m_hWnd, EM_GETLINECOUNT, 0, 0L);
  1011. }
  1012. BOOL GetModify() const
  1013. {
  1014. ATLASSERT(::IsWindow(m_hWnd));
  1015. return (BOOL)::SendMessage(m_hWnd, EM_GETMODIFY, 0, 0L);
  1016. }
  1017. void SetModify(BOOL bModified = TRUE)
  1018. {
  1019. ATLASSERT(::IsWindow(m_hWnd));
  1020. ::SendMessage(m_hWnd, EM_SETMODIFY, bModified, 0L);
  1021. }
  1022. void GetRect(LPRECT lpRect) const
  1023. {
  1024. ATLASSERT(::IsWindow(m_hWnd));
  1025. ::SendMessage(m_hWnd, EM_GETRECT, 0, (LPARAM)lpRect);
  1026. }
  1027. DWORD GetSel() const
  1028. {
  1029. ATLASSERT(::IsWindow(m_hWnd));
  1030. return (DWORD)::SendMessage(m_hWnd, EM_GETSEL, 0, 0L);
  1031. }
  1032. void GetSel(int& nStartChar, int& nEndChar) const
  1033. {
  1034. ATLASSERT(::IsWindow(m_hWnd));
  1035. ::SendMessage(m_hWnd, EM_GETSEL, (WPARAM)&nStartChar, (LPARAM)&nEndChar);
  1036. }
  1037. #ifndef _WIN32_WCE
  1038. HLOCAL GetHandle() const
  1039. {
  1040. ATLASSERT(::IsWindow(m_hWnd));
  1041. return (HLOCAL)::SendMessage(m_hWnd, EM_GETHANDLE, 0, 0L);
  1042. }
  1043. void SetHandle(HLOCAL hBuffer)
  1044. {
  1045. ATLASSERT(::IsWindow(m_hWnd));
  1046. ::SendMessage(m_hWnd, EM_SETHANDLE, (WPARAM)hBuffer, 0L);
  1047. }
  1048. #endif // !_WIN32_WCE
  1049. DWORD GetMargins() const
  1050. {
  1051. ATLASSERT(::IsWindow(m_hWnd));
  1052. return (DWORD)::SendMessage(m_hWnd, EM_GETMARGINS, 0, 0L);
  1053. }
  1054. void SetMargins(UINT nLeft, UINT nRight)
  1055. {
  1056. ATLASSERT(::IsWindow(m_hWnd));
  1057. ::SendMessage(m_hWnd, EM_SETMARGINS, EC_LEFTMARGIN|EC_RIGHTMARGIN, MAKELONG(nLeft, nRight));
  1058. }
  1059. UINT GetLimitText() const
  1060. {
  1061. ATLASSERT(::IsWindow(m_hWnd));
  1062. return (UINT)::SendMessage(m_hWnd, EM_GETLIMITTEXT, 0, 0L);
  1063. }
  1064. void SetLimitText(UINT nMax)
  1065. {
  1066. ATLASSERT(::IsWindow(m_hWnd));
  1067. ::SendMessage(m_hWnd, EM_SETLIMITTEXT, nMax, 0L);
  1068. }
  1069. POINT PosFromChar(UINT nChar) const
  1070. {
  1071. ATLASSERT(::IsWindow(m_hWnd));
  1072. DWORD dwRet = (DWORD)::SendMessage(m_hWnd, EM_POSFROMCHAR, nChar, 0);
  1073. POINT point = { GET_X_LPARAM(dwRet), GET_Y_LPARAM(dwRet) };
  1074. return point;
  1075. }
  1076. int CharFromPos(POINT pt, int* pLine = NULL) const
  1077. {
  1078. ATLASSERT(::IsWindow(m_hWnd));
  1079. DWORD dwRet = (DWORD)::SendMessage(m_hWnd, EM_CHARFROMPOS, 0, MAKELPARAM(pt.x, pt.y));
  1080. if(pLine != NULL)
  1081. *pLine = (int)(short)HIWORD(dwRet);
  1082. return (int)(short)LOWORD(dwRet);
  1083. }
  1084. // NOTE: first word in lpszBuffer must contain the size of the buffer!
  1085. int GetLine(int nIndex, LPTSTR lpszBuffer) const
  1086. {
  1087. ATLASSERT(::IsWindow(m_hWnd));
  1088. return (int)::SendMessage(m_hWnd, EM_GETLINE, nIndex, (LPARAM)lpszBuffer);
  1089. }
  1090. int GetLine(int nIndex, LPTSTR lpszBuffer, int nMaxLength) const
  1091. {
  1092. ATLASSERT(::IsWindow(m_hWnd));
  1093. *(LPWORD)lpszBuffer = (WORD)nMaxLength;
  1094. return (int)::SendMessage(m_hWnd, EM_GETLINE, nIndex, (LPARAM)lpszBuffer);
  1095. }
  1096. TCHAR GetPasswordChar() const
  1097. {
  1098. ATLASSERT(::IsWindow(m_hWnd));
  1099. return (TCHAR)::SendMessage(m_hWnd, EM_GETPASSWORDCHAR, 0, 0L);
  1100. }
  1101. void SetPasswordChar(TCHAR ch)
  1102. {
  1103. ATLASSERT(::IsWindow(m_hWnd));
  1104. ::SendMessage(m_hWnd, EM_SETPASSWORDCHAR, ch, 0L);
  1105. }
  1106. #ifndef _WIN32_WCE
  1107. EDITWORDBREAKPROC GetWordBreakProc() const
  1108. {
  1109. ATLASSERT(::IsWindow(m_hWnd));
  1110. return (EDITWORDBREAKPROC)::SendMessage(m_hWnd, EM_GETWORDBREAKPROC, 0, 0L);
  1111. }
  1112. void SetWordBreakProc(EDITWORDBREAKPROC ewbprc)
  1113. {
  1114. ATLASSERT(::IsWindow(m_hWnd));
  1115. ::SendMessage(m_hWnd, EM_SETWORDBREAKPROC, 0, (LPARAM)ewbprc);
  1116. }
  1117. #endif // !_WIN32_WCE
  1118. int GetFirstVisibleLine() const
  1119. {
  1120. ATLASSERT(::IsWindow(m_hWnd));
  1121. return (int)::SendMessage(m_hWnd, EM_GETFIRSTVISIBLELINE, 0, 0L);
  1122. }
  1123. #ifndef _WIN32_WCE
  1124. int GetThumb() const
  1125. {
  1126. ATLASSERT(::IsWindow(m_hWnd));
  1127. ATLASSERT((GetStyle() & ES_MULTILINE) != 0);
  1128. return (int)::SendMessage(m_hWnd, EM_GETTHUMB, 0, 0L);
  1129. }
  1130. #endif // !_WIN32_WCE
  1131. BOOL SetReadOnly(BOOL bReadOnly = TRUE)
  1132. {
  1133. ATLASSERT(::IsWindow(m_hWnd));
  1134. return (BOOL)::SendMessage(m_hWnd, EM_SETREADONLY, bReadOnly, 0L);
  1135. }
  1136. #if (WINVER >= 0x0500) && !defined(_WIN32_WCE)
  1137. UINT GetImeStatus(UINT uStatus) const
  1138. {
  1139. ATLASSERT(::IsWindow(m_hWnd));
  1140. return (UINT)::SendMessage(m_hWnd, EM_GETIMESTATUS, uStatus, 0L);
  1141. }
  1142. UINT SetImeStatus(UINT uStatus, UINT uData)
  1143. {
  1144. ATLASSERT(::IsWindow(m_hWnd));
  1145. return (UINT)::SendMessage(m_hWnd, EM_SETIMESTATUS, uStatus, uData);
  1146. }
  1147. #endif // (WINVER >= 0x0500) && !defined(_WIN32_WCE)
  1148. #if (_WIN32_WINNT >= 0x0501)
  1149. BOOL GetCueBannerText(LPCWSTR lpstrText, int cchText) const
  1150. {
  1151. ATLASSERT(::IsWindow(m_hWnd));
  1152. return (BOOL)::SendMessage(m_hWnd, EM_GETCUEBANNER, (WPARAM)lpstrText, cchText);
  1153. }
  1154. // bKeepWithFocus - Vista only
  1155. BOOL SetCueBannerText(LPCWSTR lpstrText, BOOL bKeepWithFocus = FALSE)
  1156. {
  1157. ATLASSERT(::IsWindow(m_hWnd));
  1158. return (BOOL)::SendMessage(m_hWnd, EM_SETCUEBANNER, (WPARAM)bKeepWithFocus, (LPARAM)(lpstrText));
  1159. }
  1160. #endif // (_WIN32_WINNT >= 0x0501)
  1161. // Operations
  1162. void EmptyUndoBuffer()
  1163. {
  1164. ATLASSERT(::IsWindow(m_hWnd));
  1165. ::SendMessage(m_hWnd, EM_EMPTYUNDOBUFFER, 0, 0L);
  1166. }
  1167. BOOL FmtLines(BOOL bAddEOL)
  1168. {
  1169. ATLASSERT(::IsWindow(m_hWnd));
  1170. return (BOOL)::SendMessage(m_hWnd, EM_FMTLINES, bAddEOL, 0L);
  1171. }
  1172. void LimitText(int nChars = 0)
  1173. {
  1174. ATLASSERT(::IsWindow(m_hWnd));
  1175. ::SendMessage(m_hWnd, EM_LIMITTEXT, nChars, 0L);
  1176. }
  1177. int LineFromChar(int nIndex = -1) const
  1178. {
  1179. ATLASSERT(::IsWindow(m_hWnd));
  1180. return (int)::SendMessage(m_hWnd, EM_LINEFROMCHAR, nIndex, 0L);
  1181. }
  1182. int LineIndex(int nLine = -1) const
  1183. {
  1184. ATLASSERT(::IsWindow(m_hWnd));
  1185. return (int)::SendMessage(m_hWnd, EM_LINEINDEX, nLine, 0L);
  1186. }
  1187. int LineLength(int nLine = -1) const
  1188. {
  1189. ATLASSERT(::IsWindow(m_hWnd));
  1190. return (int)::SendMessage(m_hWnd, EM_LINELENGTH, nLine, 0L);
  1191. }
  1192. void LineScroll(int nLines, int nChars = 0)
  1193. {
  1194. ATLASSERT(::IsWindow(m_hWnd));
  1195. ::SendMessage(m_hWnd, EM_LINESCROLL, nChars, nLines);
  1196. }
  1197. void ReplaceSel(LPCTSTR lpszNewText, BOOL bCanUndo = FALSE)
  1198. {
  1199. ATLASSERT(::IsWindow(m_hWnd));
  1200. ::SendMessage(m_hWnd, EM_REPLACESEL, (WPARAM) bCanUndo, (LPARAM)lpszNewText);
  1201. }
  1202. void SetRect(LPCRECT lpRect)
  1203. {
  1204. ATLASSERT(::IsWindow(m_hWnd));
  1205. ::SendMessage(m_hWnd, EM_SETRECT, 0, (LPARAM)lpRect);
  1206. }
  1207. void SetRectNP(LPCRECT lpRect)
  1208. {
  1209. ATLASSERT(::IsWindow(m_hWnd));
  1210. ::SendMessage(m_hWnd, EM_SETRECTNP, 0, (LPARAM)lpRect);
  1211. }
  1212. void SetSel(DWORD dwSelection, BOOL bNoScroll = FALSE)
  1213. {
  1214. ATLASSERT(::IsWindow(m_hWnd));
  1215. ::SendMessage(m_hWnd, EM_SETSEL, LOWORD(dwSelection), HIWORD(dwSelection));
  1216. if(!bNoScroll)
  1217. ::SendMessage(m_hWnd, EM_SCROLLCARET, 0, 0L);
  1218. }
  1219. void SetSel(int nStartChar, int nEndChar, BOOL bNoScroll = FALSE)
  1220. {
  1221. ATLASSERT(::IsWindow(m_hWnd));
  1222. ::SendMessage(m_hWnd, EM_SETSEL, nStartChar, nEndChar);
  1223. if(!bNoScroll)
  1224. ::SendMessage(m_hWnd, EM_SCROLLCARET, 0, 0L);
  1225. }
  1226. void SetSelAll(BOOL bNoScroll = FALSE)
  1227. {
  1228. SetSel(0, -1, bNoScroll);
  1229. }
  1230. void SetSelNone(BOOL bNoScroll = FALSE)
  1231. {
  1232. SetSel(-1, 0, bNoScroll);
  1233. }
  1234. BOOL SetTabStops(int nTabStops, LPINT rgTabStops)
  1235. {
  1236. ATLASSERT(::IsWindow(m_hWnd));
  1237. return (BOOL)::SendMessage(m_hWnd, EM_SETTABSTOPS, nTabStops, (LPARAM)rgTabStops);
  1238. }
  1239. BOOL SetTabStops()
  1240. {
  1241. ATLASSERT(::IsWindow(m_hWnd));
  1242. return (BOOL)::SendMessage(m_hWnd, EM_SETTABSTOPS, 0, 0L);
  1243. }
  1244. BOOL SetTabStops(const int& cxEachStop) // takes an 'int'
  1245. {
  1246. ATLASSERT(::IsWindow(m_hWnd));
  1247. return (BOOL)::SendMessage(m_hWnd, EM_SETTABSTOPS, 1, (LPARAM)(LPINT)&cxEachStop);
  1248. }
  1249. void ScrollCaret()
  1250. {
  1251. ATLASSERT(::IsWindow(m_hWnd));
  1252. ::SendMessage(m_hWnd, EM_SCROLLCARET, 0, 0L);
  1253. }
  1254. int Scroll(int nScrollAction)
  1255. {
  1256. ATLASSERT(::IsWindow(m_hWnd));
  1257. ATLASSERT((GetStyle() & ES_MULTILINE) != 0);
  1258. LRESULT lRet = ::SendMessage(m_hWnd, EM_SCROLL, nScrollAction, 0L);
  1259. if(!(BOOL)HIWORD(lRet))
  1260. return -1; // failed
  1261. return (int)(short)LOWORD(lRet);
  1262. }
  1263. void InsertText(int nInsertAfterChar, LPCTSTR lpstrText, BOOL bNoScroll = FALSE, BOOL bCanUndo = FALSE)
  1264. {
  1265. SetSel(nInsertAfterChar, nInsertAfterChar, bNoScroll);
  1266. ReplaceSel(lpstrText, bCanUndo);
  1267. }
  1268. void AppendText(LPCTSTR lpstrText, BOOL bNoScroll = FALSE, BOOL bCanUndo = FALSE)
  1269. {
  1270. InsertText(GetWindowTextLength(), lpstrText, bNoScroll, bCanUndo);
  1271. }
  1272. #if (_WIN32_WINNT >= 0x0501)
  1273. BOOL ShowBalloonTip(PEDITBALLOONTIP pEditBaloonTip)
  1274. {
  1275. ATLASSERT(::IsWindow(m_hWnd));
  1276. return (BOOL)::SendMessage(m_hWnd, EM_SHOWBALLOONTIP, 0, (LPARAM)pEditBaloonTip);
  1277. }
  1278. BOOL HideBalloonTip()
  1279. {
  1280. ATLASSERT(::IsWindow(m_hWnd));
  1281. return (BOOL)::SendMessage(m_hWnd, EM_HIDEBALLOONTIP, 0, 0L);
  1282. }
  1283. #endif // (_WIN32_WINNT >= 0x0501)
  1284. #if (_WIN32_WINNT >= 0x0600)
  1285. DWORD GetHilite() const
  1286. {
  1287. ATLASSERT(::IsWindow(m_hWnd));
  1288. return (DWORD)::SendMessage(m_hWnd, EM_GETHILITE, 0, 0L);
  1289. }
  1290. void GetHilite(int& nStartChar, int& nEndChar) const
  1291. {
  1292. ATLASSERT(::IsWindow(m_hWnd));
  1293. DWORD dwRet = (DWORD)::SendMessage(m_hWnd, EM_GETHILITE, 0, 0L);
  1294. nStartChar = (int)(short)LOWORD(dwRet);
  1295. nEndChar = (int)(short)HIWORD(dwRet);
  1296. }
  1297. void SetHilite(int nStartChar, int nEndChar)
  1298. {
  1299. ATLASSERT(::IsWindow(m_hWnd));
  1300. ::SendMessage(m_hWnd, EM_SETHILITE, nStartChar, nEndChar);
  1301. }
  1302. #endif // (_WIN32_WINNT >= 0x0600)
  1303. // Clipboard operations
  1304. BOOL Undo()
  1305. {
  1306. ATLASSERT(::IsWindow(m_hWnd));
  1307. return (BOOL)::SendMessage(m_hWnd, EM_UNDO, 0, 0L);
  1308. }
  1309. void Clear()
  1310. {
  1311. ATLASSERT(::IsWindow(m_hWnd));
  1312. ::SendMessage(m_hWnd, WM_CLEAR, 0, 0L);
  1313. }
  1314. void Copy()
  1315. {
  1316. ATLASSERT(::IsWindow(m_hWnd));
  1317. ::SendMessage(m_hWnd, WM_COPY, 0, 0L);
  1318. }
  1319. void Cut()
  1320. {
  1321. ATLASSERT(::IsWindow(m_hWnd));
  1322. ::SendMessage(m_hWnd, WM_CUT, 0, 0L);
  1323. }
  1324. void Paste()
  1325. {
  1326. ATLASSERT(::IsWindow(m_hWnd));
  1327. ::SendMessage(m_hWnd, WM_PASTE, 0, 0L);
  1328. }
  1329. #ifdef WIN32_PLATFORM_WFSP // SmartPhone only messages
  1330. DWORD GetExtendedStyle()
  1331. {
  1332. return SendMessage(EM_GETEXTENDEDSTYLE);
  1333. }
  1334. DWORD SetExtendedStyle(DWORD dwMask, DWORD dwExStyle)
  1335. {
  1336. return SendMessage(EM_SETEXTENDEDSTYLE, (WPARAM)dwMask, (LPARAM)dwExStyle);
  1337. }
  1338. DWORD GetInputMode(BOOL bCurrentMode = TRUE)
  1339. {
  1340. return SendMessage(EM_GETINPUTMODE, 0, (LPARAM)bCurrentMode);
  1341. }
  1342. BOOL SetInputMode(DWORD dwMode)
  1343. {
  1344. return SendMessage(EM_SETINPUTMODE, 0, (LPARAM)dwMode);
  1345. }
  1346. BOOL SetSymbols(LPCTSTR szSymbols)
  1347. {
  1348. return SendMessage(EM_SETSYMBOLS, 0, (LPARAM)szSymbols);
  1349. }
  1350. BOOL ResetSymbols()
  1351. {
  1352. return SendMessage(EM_SETSYMBOLS);
  1353. }
  1354. #endif // WIN32_PLATFORM_WFSP
  1355. };
  1356. typedef CEditT<ATL::CWindow> CEdit;
  1357. ///////////////////////////////////////////////////////////////////////////////
  1358. // CEditCommands - message handlers for standard EDIT commands
  1359. // Chain to CEditCommands message map. Your class must also derive from CEdit.
  1360. // Example:
  1361. // class CMyEdit : public CWindowImpl<CMyEdit, CEdit>,
  1362. // public CEditCommands<CMyEdit>
  1363. // {
  1364. // public:
  1365. // BEGIN_MSG_MAP(CMyEdit)
  1366. // // your handlers...
  1367. // CHAIN_MSG_MAP_ALT(CEditCommands<CMyEdit>, 1)
  1368. // END_MSG_MAP()
  1369. // // other stuff...
  1370. // };
  1371. template <class T>
  1372. class CEditCommands
  1373. {
  1374. public:
  1375. BEGIN_MSG_MAP(CEditCommands< T >)
  1376. ALT_MSG_MAP(1)
  1377. COMMAND_ID_HANDLER(ID_EDIT_CLEAR, OnEditClear)
  1378. COMMAND_ID_HANDLER(ID_EDIT_CLEAR_ALL, OnEditClearAll)
  1379. COMMAND_ID_HANDLER(ID_EDIT_COPY, OnEditCopy)
  1380. COMMAND_ID_HANDLER(ID_EDIT_CUT, OnEditCut)
  1381. COMMAND_ID_HANDLER(ID_EDIT_PASTE, OnEditPaste)
  1382. COMMAND_ID_HANDLER(ID_EDIT_SELECT_ALL, OnEditSelectAll)
  1383. COMMAND_ID_HANDLER(ID_EDIT_UNDO, OnEditUndo)
  1384. END_MSG_MAP()
  1385. LRESULT OnEditClear(WORD /*wNotifyCode*/, WORD /*wID*/, HWND /*hWndCtl*/, BOOL& /*bHandled*/)
  1386. {
  1387. T* pT = static_cast<T*>(this);
  1388. pT->Clear();
  1389. return 0;
  1390. }
  1391. LRESULT OnEditClearAll(WORD /*wNotifyCode*/, WORD /*wID*/, HWND /*hWndCtl*/, BOOL& /*bHandled*/)
  1392. {
  1393. T* pT = static_cast<T*>(this);
  1394. pT->SetSel(0, -1);
  1395. pT->Clear();
  1396. return 0;
  1397. }
  1398. LRESULT OnEditCopy(WORD /*wNotifyCode*/, WORD /*wID*/, HWND /*hWndCtl*/, BOOL& /*bHandled*/)
  1399. {
  1400. T* pT = static_cast<T*>(this);
  1401. pT->Copy();
  1402. return 0;
  1403. }
  1404. LRESULT OnEditCut(WORD /*wNotifyCode*/, WORD /*wID*/, HWND /*hWndCtl*/, BOOL& /*bHandled*/)
  1405. {
  1406. T* pT = static_cast<T*>(this);
  1407. pT->Cut();
  1408. return 0;
  1409. }
  1410. LRESULT OnEditPaste(WORD /*wNotifyCode*/, WORD /*wID*/, HWND /*hWndCtl*/, BOOL& /*bHandled*/)
  1411. {
  1412. T* pT = static_cast<T*>(this);
  1413. pT->Paste();
  1414. return 0;
  1415. }
  1416. LRESULT OnEditSelectAll(WORD /*wNotifyCode*/, WORD /*wID*/, HWND /*hWndCtl*/, BOOL& /*bHandled*/)
  1417. {
  1418. T* pT = static_cast<T*>(this);
  1419. pT->SetSel(0, -1);
  1420. return 0;
  1421. }
  1422. LRESULT OnEditUndo(WORD /*wNotifyCode*/, WORD /*wID*/, HWND /*hWndCtl*/, BOOL& /*bHandled*/)
  1423. {
  1424. T* pT = static_cast<T*>(this);
  1425. pT->Undo();
  1426. return 0;
  1427. }
  1428. // State (update UI) helpers
  1429. BOOL CanCut() const
  1430. { return HasSelection(); }
  1431. BOOL CanCopy() const
  1432. { return HasSelection(); }
  1433. BOOL CanClear() const
  1434. { return HasSelection(); }
  1435. BOOL CanSelectAll() const
  1436. { return HasText(); }
  1437. BOOL CanFind() const
  1438. { return HasText(); }
  1439. BOOL CanRepeat() const
  1440. { return HasText(); }
  1441. BOOL CanReplace() const
  1442. { return HasText(); }
  1443. BOOL CanClearAll() const
  1444. { return HasText(); }
  1445. // Implementation
  1446. BOOL HasSelection() const
  1447. {
  1448. const T* pT = static_cast<const T*>(this);
  1449. int nMin, nMax;
  1450. ::SendMessage(pT->m_hWnd, EM_GETSEL, (WPARAM)&nMin, (LPARAM)&nMax);
  1451. return (nMin != nMax);
  1452. }
  1453. BOOL HasText() const
  1454. {
  1455. const T* pT = static_cast<const T*>(this);
  1456. return (pT->GetWindowTextLength() > 0);
  1457. }
  1458. };
  1459. ///////////////////////////////////////////////////////////////////////////////
  1460. // CScrollBar - client side for a Windows SCROLLBAR control
  1461. template <class TBase>
  1462. class CScrollBarT : public TBase
  1463. {
  1464. public:
  1465. // Constructors
  1466. CScrollBarT(HWND hWnd = NULL) : TBase(hWnd)
  1467. { }
  1468. CScrollBarT< TBase >& operator =(HWND hWnd)
  1469. {
  1470. m_hWnd = hWnd;
  1471. return *this;
  1472. }
  1473. HWND Create(HWND hWndParent, ATL::_U_RECT rect = NULL, LPCTSTR szWindowName = NULL,
  1474. DWORD dwStyle = 0, DWORD dwExStyle = 0,
  1475. ATL::_U_MENUorID MenuOrID = 0U, LPVOID lpCreateParam = NULL)
  1476. {
  1477. return TBase::Create(GetWndClassName(), hWndParent, rect.m_lpRect, szWindowName, dwStyle, dwExStyle, MenuOrID.m_hMenu, lpCreateParam);
  1478. }
  1479. // Attributes
  1480. static LPCTSTR GetWndClassName()
  1481. {
  1482. return _T("SCROLLBAR");
  1483. }
  1484. #ifndef _WIN32_WCE
  1485. int GetScrollPos() const
  1486. {
  1487. ATLASSERT(::IsWindow(m_hWnd));
  1488. return ::GetScrollPos(m_hWnd, SB_CTL);
  1489. }
  1490. #endif // !_WIN32_WCE
  1491. int SetScrollPos(int nPos, BOOL bRedraw = TRUE)
  1492. {
  1493. ATLASSERT(::IsWindow(m_hWnd));
  1494. return ::SetScrollPos(m_hWnd, SB_CTL, nPos, bRedraw);
  1495. }
  1496. #ifndef _WIN32_WCE
  1497. void GetScrollRange(LPINT lpMinPos, LPINT lpMaxPos) const
  1498. {
  1499. ATLASSERT(::IsWindow(m_hWnd));
  1500. ::GetScrollRange(m_hWnd, SB_CTL, lpMinPos, lpMaxPos);
  1501. }
  1502. #endif // !_WIN32_WCE
  1503. void SetScrollRange(int nMinPos, int nMaxPos, BOOL bRedraw = TRUE)
  1504. {
  1505. ATLASSERT(::IsWindow(m_hWnd));
  1506. ::SetScrollRange(m_hWnd, SB_CTL, nMinPos, nMaxPos, bRedraw);
  1507. }
  1508. BOOL GetScrollInfo(LPSCROLLINFO lpScrollInfo) const
  1509. {
  1510. ATLASSERT(::IsWindow(m_hWnd));
  1511. return ::GetScrollInfo(m_hWnd, SB_CTL, lpScrollInfo);
  1512. }
  1513. int SetScrollInfo(LPSCROLLINFO lpScrollInfo, BOOL bRedraw = TRUE)
  1514. {
  1515. ATLASSERT(::IsWindow(m_hWnd));
  1516. return ::SetScrollInfo(m_hWnd, SB_CTL, lpScrollInfo, bRedraw);
  1517. }
  1518. #ifndef _WIN32_WCE
  1519. int GetScrollLimit() const
  1520. {
  1521. int nMin = 0, nMax = 0;
  1522. ::GetScrollRange(m_hWnd, SB_CTL, &nMin, &nMax);
  1523. SCROLLINFO info = { sizeof(SCROLLINFO), SIF_PAGE };
  1524. if(::GetScrollInfo(m_hWnd, SB_CTL, &info))
  1525. nMax -= ((info.nPage - 1) > 0) ? (info.nPage - 1) : 0;
  1526. return nMax;
  1527. }
  1528. #if (WINVER >= 0x0500)
  1529. BOOL GetScrollBarInfo(PSCROLLBARINFO pScrollBarInfo) const
  1530. {
  1531. ATLASSERT(::IsWindow(m_hWnd));
  1532. #if (_WIN32_WINNT >= 0x0501)
  1533. return (BOOL)::SendMessage(m_hWnd, SBM_GETSCROLLBARINFO, 0, (LPARAM)pScrollBarInfo);
  1534. #else // !(_WIN32_WINNT >= 0x0501)
  1535. return ::GetScrollBarInfo(m_hWnd, OBJID_CLIENT, pScrollBarInfo);
  1536. #endif // !(_WIN32_WINNT >= 0x0501)
  1537. }
  1538. #endif // (WINVER >= 0x0500)
  1539. // Operations
  1540. void ShowScrollBar(BOOL bShow = TRUE)
  1541. {
  1542. ATLASSERT(::IsWindow(m_hWnd));
  1543. ::ShowScrollBar(m_hWnd, SB_CTL, bShow);
  1544. }
  1545. BOOL EnableScrollBar(UINT nArrowFlags = ESB_ENABLE_BOTH)
  1546. {
  1547. ATLASSERT(::IsWindow(m_hWnd));
  1548. return ::EnableScrollBar(m_hWnd, SB_CTL, nArrowFlags);
  1549. }
  1550. #endif // !_WIN32_WCE
  1551. };
  1552. typedef CScrollBarT<ATL::CWindow> CScrollBar;
  1553. // --- Windows Common Controls ---
  1554. ///////////////////////////////////////////////////////////////////////////////
  1555. // CImageList
  1556. class CImageList
  1557. {
  1558. public:
  1559. HIMAGELIST m_hImageList;
  1560. // Constructor
  1561. CImageList(HIMAGELIST hImageList = NULL) : m_hImageList(hImageList)
  1562. { }
  1563. // Operators, etc.
  1564. CImageList& operator =(HIMAGELIST hImageList)
  1565. {
  1566. m_hImageList = hImageList;
  1567. return *this;
  1568. }
  1569. operator HIMAGELIST() const { return m_hImageList; }
  1570. void Attach(HIMAGELIST hImageList)
  1571. {
  1572. ATLASSERT(m_hImageList == NULL);
  1573. ATLASSERT(hImageList != NULL);
  1574. m_hImageList = hImageList;
  1575. }
  1576. HIMAGELIST Detach()
  1577. {
  1578. HIMAGELIST hImageList = m_hImageList;
  1579. m_hImageList = NULL;
  1580. return hImageList;
  1581. }
  1582. bool IsNull() const { return (m_hImageList == NULL); }
  1583. // Attributes
  1584. int GetImageCount() const
  1585. {
  1586. ATLASSERT(m_hImageList != NULL);
  1587. return ImageList_GetImageCount(m_hImageList);
  1588. }
  1589. COLORREF GetBkColor() const
  1590. {
  1591. ATLASSERT(m_hImageList != NULL);
  1592. return ImageList_GetBkColor(m_hImageList);
  1593. }
  1594. COLORREF SetBkColor(COLORREF cr)
  1595. {
  1596. ATLASSERT(m_hImageList != NULL);
  1597. return ImageList_SetBkColor(m_hImageList, cr);
  1598. }
  1599. BOOL GetImageInfo(int nImage, IMAGEINFO* pImageInfo) const
  1600. {
  1601. ATLASSERT(m_hImageList != NULL);
  1602. return ImageList_GetImageInfo(m_hImageList, nImage, pImageInfo);
  1603. }
  1604. HICON GetIcon(int nIndex, UINT uFlags = ILD_NORMAL) const
  1605. {
  1606. ATLASSERT(m_hImageList != NULL);
  1607. return ImageList_GetIcon(m_hImageList, nIndex, uFlags);
  1608. }
  1609. BOOL GetIconSize(int& cx, int& cy) const
  1610. {
  1611. ATLASSERT(m_hImageList != NULL);
  1612. return ImageList_GetIconSize(m_hImageList, &cx, &cy);
  1613. }
  1614. BOOL GetIconSize(SIZE& size) const
  1615. {
  1616. ATLASSERT(m_hImageList != NULL);
  1617. return ImageList_GetIconSize(m_hImageList, (int*)&size.cx, (int*)&size.cy);
  1618. }
  1619. BOOL SetIconSize(int cx, int cy)
  1620. {
  1621. ATLASSERT(m_hImageList != NULL);
  1622. return ImageList_SetIconSize(m_hImageList, cx, cy);
  1623. }
  1624. BOOL SetIconSize(SIZE size)
  1625. {
  1626. ATLASSERT(m_hImageList != NULL);
  1627. return ImageList_SetIconSize(m_hImageList, size.cx, size.cy);
  1628. }
  1629. BOOL SetImageCount(UINT uNewCount)
  1630. {
  1631. ATLASSERT(m_hImageList != NULL);
  1632. return ImageList_SetImageCount(m_hImageList, uNewCount);
  1633. }
  1634. BOOL SetOverlayImage(int nImage, int nOverlay)
  1635. {
  1636. ATLASSERT(m_hImageList != NULL);
  1637. return ImageList_SetOverlayImage(m_hImageList, nImage, nOverlay);
  1638. }
  1639. // Operations
  1640. BOOL Create(int cx, int cy, UINT nFlags, int nInitial, int nGrow)
  1641. {
  1642. ATLASSERT(m_hImageList == NULL);
  1643. m_hImageList = ImageList_Create(cx, cy, nFlags, nInitial, nGrow);
  1644. return (m_hImageList != NULL) ? TRUE : FALSE;
  1645. }
  1646. BOOL Create(ATL::_U_STRINGorID bitmap, int cx, int nGrow, COLORREF crMask)
  1647. {
  1648. ATLASSERT(m_hImageList == NULL);
  1649. m_hImageList = ImageList_LoadBitmap(ModuleHelper::GetResourceInstance(), bitmap.m_lpstr, cx, nGrow, crMask);
  1650. return (m_hImageList != NULL) ? TRUE : FALSE;
  1651. }
  1652. BOOL CreateFromImage(ATL::_U_STRINGorID image, int cx, int nGrow, COLORREF crMask, UINT uType, UINT uFlags = LR_DEFAULTCOLOR | LR_DEFAULTSIZE)
  1653. {
  1654. ATLASSERT(m_hImageList == NULL);
  1655. m_hImageList = ImageList_LoadImage(ModuleHelper::GetResourceInstance(), image.m_lpstr, cx, nGrow, crMask, uType, uFlags);
  1656. return (m_hImageList != NULL) ? TRUE : FALSE;
  1657. }
  1658. BOOL Merge(HIMAGELIST hImageList1, int nImage1, HIMAGELIST hImageList2, int nImage2, int dx, int dy)
  1659. {
  1660. ATLASSERT(m_hImageList == NULL);
  1661. m_hImageList = ImageList_Merge(hImageList1, nImage1, hImageList2, nImage2, dx, dy);
  1662. return (m_hImageList != NULL) ? TRUE : FALSE;
  1663. }
  1664. #ifndef _WIN32_WCE
  1665. #ifdef __IStream_INTERFACE_DEFINED__
  1666. BOOL CreateFromStream(LPSTREAM lpStream)
  1667. {
  1668. ATLASSERT(m_hImageList == NULL);
  1669. m_hImageList = ImageList_Read(lpStream);
  1670. return (m_hImageList != NULL) ? TRUE : FALSE;
  1671. }
  1672. #endif // __IStream_INTERFACE_DEFINED__
  1673. #endif // !_WIN32_WCE
  1674. BOOL Destroy()
  1675. {
  1676. if (m_hImageList == NULL)
  1677. return FALSE;
  1678. BOOL bRet = ImageList_Destroy(m_hImageList);
  1679. if(bRet)
  1680. m_hImageList = NULL;
  1681. return bRet;
  1682. }
  1683. int Add(HBITMAP hBitmap, HBITMAP hBitmapMask = NULL)
  1684. {
  1685. ATLASSERT(m_hImageList != NULL);
  1686. return ImageList_Add(m_hImageList, hBitmap, hBitmapMask);
  1687. }
  1688. int Add(HBITMAP hBitmap, COLORREF crMask)
  1689. {
  1690. ATLASSERT(m_hImageList != NULL);
  1691. return ImageList_AddMasked(m_hImageList, hBitmap, crMask);
  1692. }
  1693. BOOL Remove(int nImage)
  1694. {
  1695. ATLASSERT(m_hImageList != NULL);
  1696. return ImageList_Remove(m_hImageList, nImage);
  1697. }
  1698. BOOL RemoveAll()
  1699. {
  1700. ATLASSERT(m_hImageList != NULL);
  1701. return ImageList_RemoveAll(m_hImageList);
  1702. }
  1703. BOOL Replace(int nImage, HBITMAP hBitmap, HBITMAP hBitmapMask)
  1704. {
  1705. ATLASSERT(m_hImageList != NULL);
  1706. return ImageList_Replace(m_hImageList, nImage, hBitmap, hBitmapMask);
  1707. }
  1708. int AddIcon(HICON hIcon)
  1709. {
  1710. ATLASSERT(m_hImageList != NULL);
  1711. return ImageList_AddIcon(m_hImageList, hIcon);
  1712. }
  1713. int ReplaceIcon(int nImage, HICON hIcon)
  1714. {
  1715. ATLASSERT(m_hImageList != NULL);
  1716. return ImageList_ReplaceIcon(m_hImageList, nImage, hIcon);
  1717. }
  1718. HICON ExtractIcon(int nImage)
  1719. {
  1720. ATLASSERT(m_hImageList != NULL);
  1721. return ImageList_ExtractIcon(NULL, m_hImageList, nImage);
  1722. }
  1723. BOOL Draw(HDC hDC, int nImage, int x, int y, UINT nStyle)
  1724. {
  1725. ATLASSERT(m_hImageList != NULL);
  1726. ATLASSERT(hDC != NULL);
  1727. return ImageList_Draw(m_hImageList, nImage, hDC, x, y, nStyle);
  1728. }
  1729. BOOL Draw(HDC hDC, int nImage, POINT pt, UINT nStyle)
  1730. {
  1731. ATLASSERT(m_hImageList != NULL);
  1732. ATLASSERT(hDC != NULL);
  1733. return ImageList_Draw(m_hImageList, nImage, hDC, pt.x, pt.y, nStyle);
  1734. }
  1735. BOOL DrawEx(int nImage, HDC hDC, int x, int y, int dx, int dy, COLORREF rgbBk, COLORREF rgbFg, UINT fStyle)
  1736. {
  1737. ATLASSERT(m_hImageList != NULL);
  1738. ATLASSERT(hDC != NULL);
  1739. return ImageList_DrawEx(m_hImageList, nImage, hDC, x, y, dx, dy, rgbBk, rgbFg, fStyle);
  1740. }
  1741. BOOL DrawEx(int nImage, HDC hDC, RECT& rect, COLORREF rgbBk, COLORREF rgbFg, UINT fStyle)
  1742. {
  1743. ATLASSERT(m_hImageList != NULL);
  1744. ATLASSERT(hDC != NULL);
  1745. return ImageList_DrawEx(m_hImageList, nImage, hDC, rect.left, rect.top, rect.right - rect.left, rect.bottom - rect.top, rgbBk, rgbFg, fStyle);
  1746. }
  1747. static BOOL DrawIndirect(IMAGELISTDRAWPARAMS* pimldp)
  1748. {
  1749. return ImageList_DrawIndirect(pimldp);
  1750. }
  1751. BOOL Copy(int nSrc, int nDst, UINT uFlags = ILCF_MOVE)
  1752. {
  1753. ATLASSERT(m_hImageList != NULL);
  1754. return ImageList_Copy(m_hImageList, nDst, m_hImageList, nSrc, uFlags);
  1755. }
  1756. #ifdef __IStream_INTERFACE_DEFINED__
  1757. #ifndef _WIN32_WCE
  1758. static HIMAGELIST Read(LPSTREAM lpStream)
  1759. {
  1760. return ImageList_Read(lpStream);
  1761. }
  1762. BOOL Write(LPSTREAM lpStream)
  1763. {
  1764. ATLASSERT(m_hImageList != NULL);
  1765. return ImageList_Write(m_hImageList, lpStream);
  1766. }
  1767. #endif // !_WIN32_WCE
  1768. #if (_WIN32_WINNT >= 0x0501)
  1769. static HRESULT ReadEx(DWORD dwFlags, LPSTREAM lpStream, REFIID riid, PVOID* ppv)
  1770. {
  1771. return ImageList_ReadEx(dwFlags, lpStream, riid, ppv);
  1772. }
  1773. HRESULT WriteEx(DWORD dwFlags, LPSTREAM lpStream)
  1774. {
  1775. ATLASSERT(m_hImageList != NULL);
  1776. return ImageList_WriteEx(m_hImageList, dwFlags, lpStream);
  1777. }
  1778. #endif // (_WIN32_WINNT >= 0x0501)
  1779. #endif // __IStream_INTERFACE_DEFINED__
  1780. // Drag operations
  1781. BOOL BeginDrag(int nImage, POINT ptHotSpot)
  1782. {
  1783. ATLASSERT(m_hImageList != NULL);
  1784. return ImageList_BeginDrag(m_hImageList, nImage, ptHotSpot.x, ptHotSpot.y);
  1785. }
  1786. BOOL BeginDrag(int nImage, int xHotSpot, int yHotSpot)
  1787. {
  1788. ATLASSERT(m_hImageList != NULL);
  1789. return ImageList_BeginDrag(m_hImageList, nImage, xHotSpot, yHotSpot);
  1790. }
  1791. static void EndDrag()
  1792. {
  1793. ImageList_EndDrag();
  1794. }
  1795. static BOOL DragMove(POINT pt)
  1796. {
  1797. return ImageList_DragMove(pt.x, pt.y);
  1798. }
  1799. static BOOL DragMove(int x, int y)
  1800. {
  1801. return ImageList_DragMove(x, y);
  1802. }
  1803. BOOL SetDragCursorImage(int nDrag, POINT ptHotSpot)
  1804. {
  1805. ATLASSERT(m_hImageList != NULL);
  1806. return ImageList_SetDragCursorImage(m_hImageList, nDrag, ptHotSpot.x, ptHotSpot.y);
  1807. }
  1808. BOOL SetDragCursorImage(int nDrag, int xHotSpot, int yHotSpot)
  1809. {
  1810. ATLASSERT(m_hImageList != NULL);
  1811. return ImageList_SetDragCursorImage(m_hImageList, nDrag, xHotSpot, yHotSpot);
  1812. }
  1813. static BOOL DragShowNolock(BOOL bShow = TRUE)
  1814. {
  1815. return ImageList_DragShowNolock(bShow);
  1816. }
  1817. static CImageList GetDragImage(LPPOINT lpPoint, LPPOINT lpPointHotSpot)
  1818. {
  1819. return CImageList(ImageList_GetDragImage(lpPoint, lpPointHotSpot));
  1820. }
  1821. static BOOL DragEnter(HWND hWnd, POINT point)
  1822. {
  1823. return ImageList_DragEnter(hWnd, point.x, point.y);
  1824. }
  1825. static BOOL DragEnter(HWND hWnd, int x, int y)
  1826. {
  1827. return ImageList_DragEnter(hWnd, x, y);
  1828. }
  1829. static BOOL DragLeave(HWND hWnd)
  1830. {
  1831. return ImageList_DragLeave(hWnd);
  1832. }
  1833. #if (_WIN32_IE >= 0x0400)
  1834. CImageList Duplicate() const
  1835. {
  1836. ATLASSERT(m_hImageList != NULL);
  1837. return CImageList(ImageList_Duplicate(m_hImageList));
  1838. }
  1839. static CImageList Duplicate(HIMAGELIST hImageList)
  1840. {
  1841. ATLASSERT(hImageList != NULL);
  1842. return CImageList(ImageList_Duplicate(hImageList));
  1843. }
  1844. #endif // (_WIN32_IE >= 0x0400)
  1845. };
  1846. ///////////////////////////////////////////////////////////////////////////////
  1847. // CToolTipCtrl
  1848. #ifndef _WIN32_WCE
  1849. class CToolInfo : public TOOLINFO
  1850. {
  1851. public:
  1852. CToolInfo(UINT nFlags, HWND hWnd, UINT nIDTool = 0, LPRECT lpRect = NULL, LPTSTR lpstrText = LPSTR_TEXTCALLBACK, LPARAM lUserParam = NULL)
  1853. {
  1854. Init(nFlags, hWnd, nIDTool, lpRect, lpstrText, lUserParam);
  1855. }
  1856. operator LPTOOLINFO() { return this; }
  1857. operator LPARAM() { return (LPARAM)this; }
  1858. void Init(UINT nFlags, HWND hWnd, UINT nIDTool = 0, LPRECT lpRect = NULL, LPTSTR lpstrText = LPSTR_TEXTCALLBACK, LPARAM lUserParam = NULL)
  1859. {
  1860. ATLASSERT(::IsWindow(hWnd));
  1861. memset(this, 0, sizeof(TOOLINFO));
  1862. cbSize = sizeof(TOOLINFO);
  1863. uFlags = nFlags;
  1864. if(nIDTool == 0)
  1865. {
  1866. hwnd = ::GetParent(hWnd);
  1867. uFlags |= TTF_IDISHWND;
  1868. uId = (UINT_PTR)hWnd;
  1869. }
  1870. else
  1871. {
  1872. hwnd = hWnd;
  1873. uId = nIDTool;
  1874. }
  1875. if(lpRect != NULL)
  1876. rect = *lpRect;
  1877. hinst = ModuleHelper::GetResourceInstance();
  1878. lpszText = lpstrText;
  1879. lParam = lUserParam;
  1880. }
  1881. };
  1882. template <class TBase>
  1883. class CToolTipCtrlT : public TBase
  1884. {
  1885. public:
  1886. // Constructors
  1887. CToolTipCtrlT(HWND hWnd = NULL) : TBase(hWnd)
  1888. { }
  1889. CToolTipCtrlT< TBase >& operator =(HWND hWnd)
  1890. {
  1891. m_hWnd = hWnd;
  1892. return *this;
  1893. }
  1894. HWND Create(HWND hWndParent, ATL::_U_RECT rect = NULL, LPCTSTR szWindowName = NULL,
  1895. DWORD dwStyle = 0, DWORD dwExStyle = 0,
  1896. ATL::_U_MENUorID MenuOrID = 0U, LPVOID lpCreateParam = NULL)
  1897. {
  1898. return TBase::Create(GetWndClassName(), hWndParent, rect.m_lpRect, szWindowName, dwStyle, dwExStyle, MenuOrID.m_hMenu, lpCreateParam);
  1899. }
  1900. // Attributes
  1901. static LPCTSTR GetWndClassName()
  1902. {
  1903. return TOOLTIPS_CLASS;
  1904. }
  1905. void GetText(LPTOOLINFO lpToolInfo) const
  1906. {
  1907. ATLASSERT(::IsWindow(m_hWnd));
  1908. ::SendMessage(m_hWnd, TTM_GETTEXT, 0, (LPARAM)&lpToolInfo);
  1909. }
  1910. void GetText(LPTSTR lpstrText, HWND hWnd, UINT nIDTool = 0) const
  1911. {
  1912. ATLASSERT(::IsWindow(m_hWnd));
  1913. ATLASSERT(hWnd != NULL);
  1914. CToolInfo ti(0, hWnd, nIDTool, NULL, lpstrText);
  1915. ::SendMessage(m_hWnd, TTM_GETTEXT, 0, ti);
  1916. }
  1917. BOOL GetToolInfo(LPTOOLINFO lpToolInfo) const
  1918. {
  1919. ATLASSERT(::IsWindow(m_hWnd));
  1920. return (BOOL)::SendMessage(m_hWnd, TTM_GETTOOLINFO, 0, (LPARAM)lpToolInfo);
  1921. }
  1922. BOOL GetToolInfo(HWND hWnd, UINT nIDTool, UINT* puFlags, LPRECT lpRect, LPTSTR lpstrText) const
  1923. {
  1924. ATLASSERT(::IsWindow(m_hWnd));
  1925. ATLASSERT(hWnd != NULL);
  1926. ATLASSERT(puFlags != NULL);
  1927. ATLASSERT(lpRect != NULL);
  1928. CToolInfo ti(0, hWnd, nIDTool, NULL, lpstrText);
  1929. BOOL bRet = (BOOL)::SendMessage(m_hWnd, TTM_GETTOOLINFO, 0, ti);
  1930. if(bRet != FALSE)
  1931. {
  1932. *puFlags = ti.uFlags;
  1933. *lpRect = ti.rect;
  1934. }
  1935. return bRet;
  1936. }
  1937. void SetToolInfo(LPTOOLINFO lpToolInfo)
  1938. {
  1939. ATLASSERT(::IsWindow(m_hWnd));
  1940. ::SendMessage(m_hWnd, TTM_SETTOOLINFO, 0, (LPARAM)lpToolInfo);
  1941. }
  1942. void SetToolRect(LPTOOLINFO lpToolInfo)
  1943. {
  1944. ATLASSERT(::IsWindow(m_hWnd));
  1945. ::SendMessage(m_hWnd, TTM_NEWTOOLRECT, 0, (LPARAM)lpToolInfo);
  1946. }
  1947. void SetToolRect(HWND hWnd, UINT nIDTool, LPCRECT lpRect)
  1948. {
  1949. ATLASSERT(::IsWindow(m_hWnd));
  1950. ATLASSERT(hWnd != NULL);
  1951. ATLASSERT(nIDTool != 0);
  1952. CToolInfo ti(0, hWnd, nIDTool, (LPRECT)lpRect, NULL);
  1953. ::SendMessage(m_hWnd, TTM_NEWTOOLRECT, 0, ti);
  1954. }
  1955. int GetToolCount() const
  1956. {
  1957. ATLASSERT(::IsWindow(m_hWnd));
  1958. return (int)::SendMessage(m_hWnd, TTM_GETTOOLCOUNT, 0, 0L);
  1959. }
  1960. int GetDelayTime(DWORD dwType) const
  1961. {
  1962. ATLASSERT(::IsWindow(m_hWnd));
  1963. return (int)::SendMessage(m_hWnd, TTM_GETDELAYTIME, dwType, 0L);
  1964. }
  1965. void SetDelayTime(DWORD dwType, int nTime)
  1966. {
  1967. ATLASSERT(::IsWindow(m_hWnd));
  1968. ::SendMessage(m_hWnd, TTM_SETDELAYTIME, dwType, MAKELPARAM(nTime, 0));
  1969. }
  1970. void GetMargin(LPRECT lpRect) const
  1971. {
  1972. ATLASSERT(::IsWindow(m_hWnd));
  1973. ::SendMessage(m_hWnd, TTM_GETMARGIN, 0, (LPARAM)lpRect);
  1974. }
  1975. void SetMargin(LPRECT lpRect)
  1976. {
  1977. ATLASSERT(::IsWindow(m_hWnd));
  1978. ::SendMessage(m_hWnd, TTM_SETMARGIN, 0, (LPARAM)lpRect);
  1979. }
  1980. int GetMaxTipWidth() const
  1981. {
  1982. ATLASSERT(::IsWindow(m_hWnd));
  1983. return (int)::SendMessage(m_hWnd, TTM_GETMAXTIPWIDTH, 0, 0L);
  1984. }
  1985. int SetMaxTipWidth(int nWidth)
  1986. {
  1987. ATLASSERT(::IsWindow(m_hWnd));
  1988. return (int)::SendMessage(m_hWnd, TTM_SETMAXTIPWIDTH, 0, nWidth);
  1989. }
  1990. COLORREF GetTipBkColor() const
  1991. {
  1992. ATLASSERT(::IsWindow(m_hWnd));
  1993. return (COLORREF)::SendMessage(m_hWnd, TTM_GETTIPBKCOLOR, 0, 0L);
  1994. }
  1995. void SetTipBkColor(COLORREF clr)
  1996. {
  1997. ATLASSERT(::IsWindow(m_hWnd));
  1998. ::SendMessage(m_hWnd, TTM_SETTIPBKCOLOR, (WPARAM)clr, 0L);
  1999. }
  2000. COLORREF GetTipTextColor() const
  2001. {
  2002. ATLASSERT(::IsWindow(m_hWnd));
  2003. return (COLORREF)::SendMessage(m_hWnd, TTM_GETTIPTEXTCOLOR, 0, 0L);
  2004. }
  2005. void SetTipTextColor(COLORREF clr)
  2006. {
  2007. ATLASSERT(::IsWindow(m_hWnd));
  2008. ::SendMessage(m_hWnd, TTM_SETTIPTEXTCOLOR, (WPARAM)clr, 0L);
  2009. }
  2010. BOOL GetCurrentTool(LPTOOLINFO lpToolInfo) const
  2011. {
  2012. ATLASSERT(::IsWindow(m_hWnd));
  2013. return (BOOL)::SendMessage(m_hWnd, TTM_GETCURRENTTOOL, 0, (LPARAM)lpToolInfo);
  2014. }
  2015. #if (_WIN32_IE >= 0x0500)
  2016. SIZE GetBubbleSize(LPTOOLINFO lpToolInfo) const
  2017. {
  2018. ATLASSERT(::IsWindow(m_hWnd));
  2019. DWORD dwRet = (DWORD)::SendMessage(m_hWnd, TTM_GETBUBBLESIZE, 0, (LPARAM)lpToolInfo);
  2020. SIZE size = { GET_X_LPARAM(dwRet), GET_Y_LPARAM(dwRet) };
  2021. return size;
  2022. }
  2023. BOOL SetTitle(UINT uIcon, LPCTSTR lpstrTitle)
  2024. {
  2025. ATLASSERT(::IsWindow(m_hWnd));
  2026. return (BOOL)::SendMessage(m_hWnd, TTM_SETTITLE, uIcon, (LPARAM)lpstrTitle);
  2027. }
  2028. #endif // (_WIN32_IE >= 0x0500)
  2029. #if (_WIN32_WINNT >= 0x0501)
  2030. void GetTitle(PTTGETTITLE pTTGetTitle) const
  2031. {
  2032. ATLASSERT(::IsWindow(m_hWnd));
  2033. ::SendMessage(m_hWnd, TTM_GETTITLE, 0, (LPARAM)pTTGetTitle);
  2034. }
  2035. void SetWindowTheme(LPCWSTR lpstrTheme)
  2036. {
  2037. ATLASSERT(::IsWindow(m_hWnd));
  2038. ::SendMessage(m_hWnd, TTM_SETWINDOWTHEME, 0, (LPARAM)lpstrTheme);
  2039. }
  2040. #endif // (_WIN32_WINNT >= 0x0501)
  2041. // Operations
  2042. void Activate(BOOL bActivate)
  2043. {
  2044. ATLASSERT(::IsWindow(m_hWnd));
  2045. ::SendMessage(m_hWnd, TTM_ACTIVATE, bActivate, 0L);
  2046. }
  2047. BOOL AddTool(LPTOOLINFO lpToolInfo)
  2048. {
  2049. ATLASSERT(::IsWindow(m_hWnd));
  2050. return (BOOL)::SendMessage(m_hWnd, TTM_ADDTOOL, 0, (LPARAM)lpToolInfo);
  2051. }
  2052. BOOL AddTool(HWND hWnd, ATL::_U_STRINGorID text = LPSTR_TEXTCALLBACK, LPCRECT lpRectTool = NULL, UINT nIDTool = 0)
  2053. {
  2054. ATLASSERT(::IsWindow(m_hWnd));
  2055. ATLASSERT(hWnd != NULL);
  2056. // the toolrect and toolid must both be zero or both valid
  2057. ATLASSERT((lpRectTool != NULL && nIDTool != 0) || (lpRectTool == NULL && nIDTool == 0));
  2058. CToolInfo ti(0, hWnd, nIDTool, (LPRECT)lpRectTool, (LPTSTR)text.m_lpstr);
  2059. return (BOOL)::SendMessage(m_hWnd, TTM_ADDTOOL, 0, ti);
  2060. }
  2061. void DelTool(LPTOOLINFO lpToolInfo)
  2062. {
  2063. ATLASSERT(::IsWindow(m_hWnd));
  2064. ::SendMessage(m_hWnd, TTM_DELTOOL, 0, (LPARAM)lpToolInfo);
  2065. }
  2066. void DelTool(HWND hWnd, UINT nIDTool = 0)
  2067. {
  2068. ATLASSERT(::IsWindow(m_hWnd));
  2069. ATLASSERT(hWnd != NULL);
  2070. CToolInfo ti(0, hWnd, nIDTool, NULL, NULL);
  2071. ::SendMessage(m_hWnd, TTM_DELTOOL, 0, ti);
  2072. }
  2073. BOOL HitTest(LPTTHITTESTINFO lpHitTestInfo) const
  2074. {
  2075. ATLASSERT(::IsWindow(m_hWnd));
  2076. return (BOOL)::SendMessage(m_hWnd, TTM_HITTEST, 0, (LPARAM)lpHitTestInfo);
  2077. }
  2078. BOOL HitTest(HWND hWnd, POINT pt, LPTOOLINFO lpToolInfo) const
  2079. {
  2080. ATLASSERT(::IsWindow(m_hWnd));
  2081. ATLASSERT(hWnd != NULL);
  2082. ATLASSERT(lpToolInfo != NULL);
  2083. TTHITTESTINFO hti = { 0 };
  2084. hti.ti.cbSize = sizeof(TOOLINFO);
  2085. hti.hwnd = hWnd;
  2086. hti.pt.x = pt.x;
  2087. hti.pt.y = pt.y;
  2088. if((BOOL)::SendMessage(m_hWnd, TTM_HITTEST, 0, (LPARAM)&hti) != FALSE)
  2089. {
  2090. *lpToolInfo = hti.ti;
  2091. return TRUE;
  2092. }
  2093. return FALSE;
  2094. }
  2095. void RelayEvent(LPMSG lpMsg)
  2096. {
  2097. ATLASSERT(::IsWindow(m_hWnd));
  2098. ::SendMessage(m_hWnd, TTM_RELAYEVENT, 0, (LPARAM)lpMsg);
  2099. }
  2100. void UpdateTipText(LPTOOLINFO lpToolInfo)
  2101. {
  2102. ATLASSERT(::IsWindow(m_hWnd));
  2103. ::SendMessage(m_hWnd, TTM_UPDATETIPTEXT, 0, (LPARAM)lpToolInfo);
  2104. }
  2105. void UpdateTipText(ATL::_U_STRINGorID text, HWND hWnd, UINT nIDTool = 0)
  2106. {
  2107. ATLASSERT(::IsWindow(m_hWnd));
  2108. ATLASSERT(hWnd != NULL);
  2109. CToolInfo ti(0, hWnd, nIDTool, NULL, (LPTSTR)text.m_lpstr);
  2110. ::SendMessage(m_hWnd, TTM_UPDATETIPTEXT, 0, ti);
  2111. }
  2112. BOOL EnumTools(UINT nTool, LPTOOLINFO lpToolInfo) const
  2113. {
  2114. ATLASSERT(::IsWindow(m_hWnd));
  2115. return (BOOL)::SendMessage(m_hWnd, TTM_ENUMTOOLS, nTool, (LPARAM)lpToolInfo);
  2116. }
  2117. void Pop()
  2118. {
  2119. ATLASSERT(::IsWindow(m_hWnd));
  2120. ::SendMessage(m_hWnd, TTM_POP, 0, 0L);
  2121. }
  2122. void TrackActivate(LPTOOLINFO lpToolInfo, BOOL bActivate)
  2123. {
  2124. ATLASSERT(::IsWindow(m_hWnd));
  2125. ::SendMessage(m_hWnd, TTM_TRACKACTIVATE, bActivate, (LPARAM)lpToolInfo);
  2126. }
  2127. void TrackPosition(int xPos, int yPos)
  2128. {
  2129. ATLASSERT(::IsWindow(m_hWnd));
  2130. ::SendMessage(m_hWnd, TTM_TRACKPOSITION, 0, MAKELPARAM(xPos, yPos));
  2131. }
  2132. #if (_WIN32_IE >= 0x0400)
  2133. void Update()
  2134. {
  2135. ATLASSERT(::IsWindow(m_hWnd));
  2136. ::SendMessage(m_hWnd, TTM_UPDATE, 0, 0L);
  2137. }
  2138. #endif // (_WIN32_IE >= 0x0400)
  2139. #if (_WIN32_IE >= 0x0500)
  2140. BOOL AdjustRect(LPRECT lpRect, BOOL bLarger /*= TRUE*/)
  2141. {
  2142. ATLASSERT(::IsWindow(m_hWnd));
  2143. return (BOOL)::SendMessage(m_hWnd, TTM_ADJUSTRECT, bLarger, (LPARAM)lpRect);
  2144. }
  2145. #endif // (_WIN32_IE >= 0x0500)
  2146. #if (_WIN32_WINNT >= 0x0501)
  2147. void Popup()
  2148. {
  2149. ATLASSERT(::IsWindow(m_hWnd));
  2150. ::SendMessage(m_hWnd, TTM_POPUP, 0, 0L);
  2151. }
  2152. #endif // (_WIN32_WINNT >= 0x0501)
  2153. };
  2154. typedef CToolTipCtrlT<ATL::CWindow> CToolTipCtrl;
  2155. #endif // !_WIN32_WCE
  2156. ///////////////////////////////////////////////////////////////////////////////
  2157. // CHeaderCtrl
  2158. template <class TBase>
  2159. class CHeaderCtrlT : public TBase
  2160. {
  2161. public:
  2162. // Constructors
  2163. CHeaderCtrlT(HWND hWnd = NULL) : TBase(hWnd)
  2164. { }
  2165. CHeaderCtrlT< TBase >& operator =(HWND hWnd)
  2166. {
  2167. m_hWnd = hWnd;
  2168. return *this;
  2169. }
  2170. HWND Create(HWND hWndParent, ATL::_U_RECT rect = NULL, LPCTSTR szWindowName = NULL,
  2171. DWORD dwStyle = 0, DWORD dwExStyle = 0,
  2172. ATL::_U_MENUorID MenuOrID = 0U, LPVOID lpCreateParam = NULL)
  2173. {
  2174. return TBase::Create(GetWndClassName(), hWndParent, rect.m_lpRect, szWindowName, dwStyle, dwExStyle, MenuOrID.m_hMenu, lpCreateParam);
  2175. }
  2176. // Attributes
  2177. static LPCTSTR GetWndClassName()
  2178. {
  2179. return WC_HEADER;
  2180. }
  2181. int GetItemCount() const
  2182. {
  2183. ATLASSERT(::IsWindow(m_hWnd));
  2184. return (int)::SendMessage(m_hWnd, HDM_GETITEMCOUNT, 0, 0L);
  2185. }
  2186. BOOL GetItem(int nIndex, LPHDITEM pHeaderItem) const
  2187. {
  2188. ATLASSERT(::IsWindow(m_hWnd));
  2189. return (BOOL)::SendMessage(m_hWnd, HDM_GETITEM, nIndex, (LPARAM)pHeaderItem);
  2190. }
  2191. BOOL SetItem(int nIndex, LPHDITEM pHeaderItem)
  2192. {
  2193. ATLASSERT(::IsWindow(m_hWnd));
  2194. return (BOOL)::SendMessage(m_hWnd, HDM_SETITEM, nIndex, (LPARAM)pHeaderItem);
  2195. }
  2196. CImageList GetImageList() const
  2197. {
  2198. ATLASSERT(::IsWindow(m_hWnd));
  2199. return CImageList((HIMAGELIST)::SendMessage(m_hWnd, HDM_GETIMAGELIST, 0, 0L));
  2200. }
  2201. CImageList SetImageList(HIMAGELIST hImageList)
  2202. {
  2203. ATLASSERT(::IsWindow(m_hWnd));
  2204. return CImageList((HIMAGELIST)::SendMessage(m_hWnd, HDM_SETIMAGELIST, 0, (LPARAM)hImageList));
  2205. }
  2206. BOOL GetOrderArray(int nSize, int* lpnArray) const
  2207. {
  2208. ATLASSERT(::IsWindow(m_hWnd));
  2209. return (BOOL)::SendMessage(m_hWnd, HDM_GETORDERARRAY, nSize, (LPARAM)lpnArray);
  2210. }
  2211. BOOL SetOrderArray(int nSize, int* lpnArray)
  2212. {
  2213. ATLASSERT(::IsWindow(m_hWnd));
  2214. return (BOOL)::SendMessage(m_hWnd, HDM_SETORDERARRAY, nSize, (LPARAM)lpnArray);
  2215. }
  2216. BOOL GetItemRect(int nIndex, LPRECT lpItemRect) const
  2217. {
  2218. ATLASSERT(::IsWindow(m_hWnd));
  2219. return (BOOL)::SendMessage(m_hWnd, HDM_GETITEMRECT, nIndex, (LPARAM)lpItemRect);
  2220. }
  2221. int SetHotDivider(BOOL bPos, DWORD dwInputValue)
  2222. {
  2223. ATLASSERT(::IsWindow(m_hWnd));
  2224. return (int)::SendMessage(m_hWnd, HDM_SETHOTDIVIDER, bPos, dwInputValue);
  2225. }
  2226. #if (_WIN32_IE >= 0x0400) && !defined(_WIN32_WCE)
  2227. BOOL GetUnicodeFormat() const
  2228. {
  2229. ATLASSERT(::IsWindow(m_hWnd));
  2230. return (BOOL)::SendMessage(m_hWnd, HDM_GETUNICODEFORMAT, 0, 0L);
  2231. }
  2232. BOOL SetUnicodeFormat(BOOL bUnicode = TRUE)
  2233. {
  2234. ATLASSERT(::IsWindow(m_hWnd));
  2235. return (BOOL)::SendMessage(m_hWnd, HDM_SETUNICODEFORMAT, bUnicode, 0L);
  2236. }
  2237. #endif // (_WIN32_IE >= 0x0400) && !defined(_WIN32_WCE)
  2238. #if (_WIN32_IE >= 0x0500) && !defined(_WIN32_WCE)
  2239. int GetBitmapMargin() const
  2240. {
  2241. ATLASSERT(::IsWindow(m_hWnd));
  2242. return (int)::SendMessage(m_hWnd, HDM_GETBITMAPMARGIN, 0, 0L);
  2243. }
  2244. int SetBitmapMargin(int nWidth)
  2245. {
  2246. ATLASSERT(::IsWindow(m_hWnd));
  2247. return (int)::SendMessage(m_hWnd, HDM_SETBITMAPMARGIN, nWidth, 0L);
  2248. }
  2249. int SetFilterChangeTimeout(DWORD dwTimeOut)
  2250. {
  2251. ATLASSERT(::IsWindow(m_hWnd));
  2252. return (int)::SendMessage(m_hWnd, HDM_SETFILTERCHANGETIMEOUT, 0, dwTimeOut);
  2253. }
  2254. #endif // (_WIN32_IE >= 0x0500) && !defined(_WIN32_WCE)
  2255. #if (_WIN32_WINNT >= 0x0600)
  2256. BOOL GetItemDropDownRect(int nIndex, LPRECT lpRect) const
  2257. {
  2258. ATLASSERT(::IsWindow(m_hWnd));
  2259. return (BOOL)::SendMessage(m_hWnd, HDM_GETITEMDROPDOWNRECT, nIndex, (LPARAM)lpRect);
  2260. }
  2261. BOOL GetOverflowRect(LPRECT lpRect) const
  2262. {
  2263. ATLASSERT(::IsWindow(m_hWnd));
  2264. return (BOOL)::SendMessage(m_hWnd, HDM_GETOVERFLOWRECT, 0, (LPARAM)lpRect);
  2265. }
  2266. int GetFocusedItem() const
  2267. {
  2268. ATLASSERT(::IsWindow(m_hWnd));
  2269. return (int)::SendMessage(m_hWnd, HDM_GETFOCUSEDITEM, 0, 0L);
  2270. }
  2271. BOOL SetFocusedItem(int nIndex)
  2272. {
  2273. ATLASSERT(::IsWindow(m_hWnd));
  2274. return (BOOL)::SendMessage(m_hWnd, HDM_SETFOCUSEDITEM, 0, nIndex);
  2275. }
  2276. #endif // (_WIN32_WINNT >= 0x0600)
  2277. // Operations
  2278. int InsertItem(int nIndex, LPHDITEM phdi)
  2279. {
  2280. ATLASSERT(::IsWindow(m_hWnd));
  2281. return (int)::SendMessage(m_hWnd, HDM_INSERTITEM, nIndex, (LPARAM)phdi);
  2282. }
  2283. int AddItem(LPHDITEM phdi)
  2284. {
  2285. return InsertItem(GetItemCount(), phdi);
  2286. }
  2287. BOOL DeleteItem(int nIndex)
  2288. {
  2289. ATLASSERT(::IsWindow(m_hWnd));
  2290. return (BOOL)::SendMessage(m_hWnd, HDM_DELETEITEM, nIndex, 0L);
  2291. }
  2292. BOOL Layout(HD_LAYOUT* pHeaderLayout)
  2293. {
  2294. ATLASSERT(::IsWindow(m_hWnd));
  2295. return (BOOL)::SendMessage(m_hWnd, HDM_LAYOUT, 0, (LPARAM)pHeaderLayout);
  2296. }
  2297. int HitTest(LPHDHITTESTINFO lpHitTestInfo) const
  2298. {
  2299. ATLASSERT(::IsWindow(m_hWnd));
  2300. return (int)::SendMessage(m_hWnd, HDM_HITTEST, 0, (LPARAM)lpHitTestInfo);
  2301. }
  2302. int OrderToIndex(int nOrder)
  2303. {
  2304. ATLASSERT(::IsWindow(m_hWnd));
  2305. return (int)::SendMessage(m_hWnd, HDM_ORDERTOINDEX, nOrder, 0L);
  2306. }
  2307. CImageList CreateDragImage(int nIndex)
  2308. {
  2309. ATLASSERT(::IsWindow(m_hWnd));
  2310. return CImageList((HIMAGELIST)::SendMessage(m_hWnd, HDM_CREATEDRAGIMAGE, nIndex, 0L));
  2311. }
  2312. #if (_WIN32_IE >= 0x0500) && !defined(_WIN32_WCE)
  2313. int EditFilter(int nColumn, BOOL bDiscardChanges)
  2314. {
  2315. ATLASSERT(::IsWindow(m_hWnd));
  2316. return (int)::SendMessage(m_hWnd, HDM_EDITFILTER, nColumn, MAKELPARAM(bDiscardChanges, 0));
  2317. }
  2318. int ClearFilter(int nColumn)
  2319. {
  2320. ATLASSERT(::IsWindow(m_hWnd));
  2321. return (int)::SendMessage(m_hWnd, HDM_CLEARFILTER, nColumn, 0L);
  2322. }
  2323. int ClearAllFilters()
  2324. {
  2325. ATLASSERT(::IsWindow(m_hWnd));
  2326. return (int)::SendMessage(m_hWnd, HDM_CLEARFILTER, (WPARAM)-1, 0L);
  2327. }
  2328. #endif // (_WIN32_IE >= 0x0500) && !defined(_WIN32_WCE)
  2329. };
  2330. typedef CHeaderCtrlT<ATL::CWindow> CHeaderCtrl;
  2331. ///////////////////////////////////////////////////////////////////////////////
  2332. // CListViewCtrl
  2333. template <class TBase>
  2334. class CListViewCtrlT : public TBase
  2335. {
  2336. public:
  2337. // Constructors
  2338. CListViewCtrlT(HWND hWnd = NULL) : TBase(hWnd)
  2339. { }
  2340. CListViewCtrlT< TBase >& operator =(HWND hWnd)
  2341. {
  2342. m_hWnd = hWnd;
  2343. return *this;
  2344. }
  2345. HWND Create(HWND hWndParent, ATL::_U_RECT rect = NULL, LPCTSTR szWindowName = NULL,
  2346. DWORD dwStyle = 0, DWORD dwExStyle = 0,
  2347. ATL::_U_MENUorID MenuOrID = 0U, LPVOID lpCreateParam = NULL)
  2348. {
  2349. return TBase::Create(GetWndClassName(), hWndParent, rect.m_lpRect, szWindowName, dwStyle, dwExStyle, MenuOrID.m_hMenu, lpCreateParam);
  2350. }
  2351. // Attributes
  2352. static LPCTSTR GetWndClassName()
  2353. {
  2354. return WC_LISTVIEW;
  2355. }
  2356. COLORREF GetBkColor() const
  2357. {
  2358. ATLASSERT(::IsWindow(m_hWnd));
  2359. return (COLORREF)::SendMessage(m_hWnd, LVM_GETBKCOLOR, 0, 0L);
  2360. }
  2361. BOOL SetBkColor(COLORREF cr)
  2362. {
  2363. ATLASSERT(::IsWindow(m_hWnd));
  2364. return (BOOL)::SendMessage(m_hWnd, LVM_SETBKCOLOR, 0, cr);
  2365. }
  2366. CImageList GetImageList(int nImageListType) const
  2367. {
  2368. ATLASSERT(::IsWindow(m_hWnd));
  2369. return CImageList((HIMAGELIST)::SendMessage(m_hWnd, LVM_GETIMAGELIST, nImageListType, 0L));
  2370. }
  2371. CImageList SetImageList(HIMAGELIST hImageList, int nImageList)
  2372. {
  2373. ATLASSERT(::IsWindow(m_hWnd));
  2374. return CImageList((HIMAGELIST)::SendMessage(m_hWnd, LVM_SETIMAGELIST, nImageList, (LPARAM)hImageList));
  2375. }
  2376. int GetItemCount() const
  2377. {
  2378. ATLASSERT(::IsWindow(m_hWnd));
  2379. return (int)::SendMessage(m_hWnd, LVM_GETITEMCOUNT, 0, 0L);
  2380. }
  2381. BOOL SetItemCount(int nItems)
  2382. {
  2383. ATLASSERT(::IsWindow(m_hWnd));
  2384. return (BOOL)::SendMessage(m_hWnd, LVM_SETITEMCOUNT, nItems, 0L);
  2385. }
  2386. BOOL GetItem(LPLVITEM pItem) const
  2387. {
  2388. ATLASSERT(::IsWindow(m_hWnd));
  2389. return (BOOL)::SendMessage(m_hWnd, LVM_GETITEM, 0, (LPARAM)pItem);
  2390. }
  2391. BOOL SetItem(const LVITEM* pItem)
  2392. {
  2393. ATLASSERT(::IsWindow(m_hWnd));
  2394. return (BOOL)::SendMessage(m_hWnd, LVM_SETITEM, 0, (LPARAM)pItem);
  2395. }
  2396. BOOL SetItem(int nItem, int nSubItem, UINT nMask, LPCTSTR lpszItem,
  2397. int nImage, UINT nState, UINT nStateMask, LPARAM lParam)
  2398. {
  2399. ATLASSERT(::IsWindow(m_hWnd));
  2400. LVITEM lvi = { 0 };
  2401. lvi.mask = nMask;
  2402. lvi.iItem = nItem;
  2403. lvi.iSubItem = nSubItem;
  2404. lvi.stateMask = nStateMask;
  2405. lvi.state = nState;
  2406. lvi.pszText = (LPTSTR) lpszItem;
  2407. lvi.iImage = nImage;
  2408. lvi.lParam = lParam;
  2409. return (BOOL)::SendMessage(m_hWnd, LVM_SETITEM, 0, (LPARAM)&lvi);
  2410. }
  2411. UINT GetItemState(int nItem, UINT nMask) const
  2412. {
  2413. ATLASSERT(::IsWindow(m_hWnd));
  2414. return (UINT)::SendMessage(m_hWnd, LVM_GETITEMSTATE, nItem, nMask);
  2415. }
  2416. BOOL SetItemState(int nItem, UINT nState, UINT nStateMask)
  2417. {
  2418. ATLASSERT(::IsWindow(m_hWnd));
  2419. LVITEM lvi = { 0 };
  2420. lvi.state = nState;
  2421. lvi.stateMask = nStateMask;
  2422. return (BOOL)::SendMessage(m_hWnd, LVM_SETITEMSTATE, nItem, (LPARAM)&lvi);
  2423. }
  2424. BOOL SetItemState(int nItem, LPLVITEM pItem)
  2425. {
  2426. ATLASSERT(::IsWindow(m_hWnd));
  2427. return (BOOL)::SendMessage(m_hWnd, LVM_SETITEMSTATE, nItem, (LPARAM)pItem);
  2428. }
  2429. #ifndef _ATL_NO_COM
  2430. BOOL GetItemText(int nItem, int nSubItem, BSTR& bstrText) const
  2431. {
  2432. USES_CONVERSION;
  2433. ATLASSERT(::IsWindow(m_hWnd));
  2434. ATLASSERT(bstrText == NULL);
  2435. LVITEM lvi = { 0 };
  2436. lvi.iSubItem = nSubItem;
  2437. LPTSTR lpstrText = NULL;
  2438. int nRes = 0;
  2439. for(int nLen = 256; ; nLen *= 2)
  2440. {
  2441. ATLTRY(lpstrText = new TCHAR[nLen]);
  2442. if(lpstrText == NULL)
  2443. break;
  2444. lpstrText[0] = NULL;
  2445. lvi.cchTextMax = nLen;
  2446. lvi.pszText = lpstrText;
  2447. nRes = (int)::SendMessage(m_hWnd, LVM_GETITEMTEXT, (WPARAM)nItem, (LPARAM)&lvi);
  2448. if(nRes < nLen - 1)
  2449. break;
  2450. delete [] lpstrText;
  2451. lpstrText = NULL;
  2452. }
  2453. if(lpstrText != NULL)
  2454. {
  2455. if(nRes != 0)
  2456. bstrText = ::SysAllocString(T2OLE(lpstrText));
  2457. delete [] lpstrText;
  2458. }
  2459. return (bstrText != NULL) ? TRUE : FALSE;
  2460. }
  2461. #endif // !_ATL_NO_COM
  2462. #if defined(_WTL_USE_CSTRING) || defined(__ATLSTR_H__)
  2463. int GetItemText(int nItem, int nSubItem, _CSTRING_NS::CString& strText) const
  2464. {
  2465. ATLASSERT(::IsWindow(m_hWnd));
  2466. LVITEM lvi = { 0 };
  2467. lvi.iSubItem = nSubItem;
  2468. strText.Empty();
  2469. int nRes = 0;
  2470. for(int nLen = 256; ; nLen *= 2)
  2471. {
  2472. lvi.cchTextMax = nLen;
  2473. lvi.pszText = strText.GetBufferSetLength(nLen);
  2474. if(lvi.pszText == NULL)
  2475. {
  2476. nRes = 0;
  2477. break;
  2478. }
  2479. nRes = (int)::SendMessage(m_hWnd, LVM_GETITEMTEXT, (WPARAM)nItem, (LPARAM)&lvi);
  2480. if(nRes < nLen - 1)
  2481. break;
  2482. }
  2483. strText.ReleaseBuffer();
  2484. return nRes;
  2485. }
  2486. #endif // defined(_WTL_USE_CSTRING) || defined(__ATLSTR_H__)
  2487. int GetItemText(int nItem, int nSubItem, LPTSTR lpszText, int nLen) const
  2488. {
  2489. ATLASSERT(::IsWindow(m_hWnd));
  2490. LVITEM lvi = { 0 };
  2491. lvi.iSubItem = nSubItem;
  2492. lvi.cchTextMax = nLen;
  2493. lvi.pszText = lpszText;
  2494. return (int)::SendMessage(m_hWnd, LVM_GETITEMTEXT, (WPARAM)nItem, (LPARAM)&lvi);
  2495. }
  2496. BOOL SetItemText(int nItem, int nSubItem, LPCTSTR lpszText)
  2497. {
  2498. ATLASSERT(::IsWindow(m_hWnd));
  2499. return SetItem(nItem, nSubItem, LVIF_TEXT, lpszText, 0, 0, 0, 0);
  2500. }
  2501. DWORD_PTR GetItemData(int nItem) const
  2502. {
  2503. ATLASSERT(::IsWindow(m_hWnd));
  2504. LVITEM lvi = { 0 };
  2505. lvi.iItem = nItem;
  2506. lvi.mask = LVIF_PARAM;
  2507. BOOL bRet = (BOOL)::SendMessage(m_hWnd, LVM_GETITEM, 0, (LPARAM)&lvi);
  2508. return (DWORD_PTR)(bRet ? lvi.lParam : NULL);
  2509. }
  2510. BOOL SetItemData(int nItem, DWORD_PTR dwData)
  2511. {
  2512. ATLASSERT(::IsWindow(m_hWnd));
  2513. return SetItem(nItem, 0, LVIF_PARAM, NULL, 0, 0, 0, (LPARAM)dwData);
  2514. }
  2515. UINT GetCallbackMask() const
  2516. {
  2517. ATLASSERT(::IsWindow(m_hWnd));
  2518. return (UINT)::SendMessage(m_hWnd, LVM_GETCALLBACKMASK, 0, 0L);
  2519. }
  2520. BOOL SetCallbackMask(UINT nMask)
  2521. {
  2522. ATLASSERT(::IsWindow(m_hWnd));
  2523. return (BOOL)::SendMessage(m_hWnd, LVM_SETCALLBACKMASK, nMask, 0L);
  2524. }
  2525. BOOL GetItemPosition(int nItem, LPPOINT lpPoint) const
  2526. {
  2527. ATLASSERT(::IsWindow(m_hWnd));
  2528. return (BOOL)::SendMessage(m_hWnd, LVM_GETITEMPOSITION, nItem, (LPARAM)lpPoint);
  2529. }
  2530. BOOL SetItemPosition(int nItem, POINT pt)
  2531. {
  2532. ATLASSERT(::IsWindow(m_hWnd));
  2533. ATLASSERT(((GetStyle() & LVS_TYPEMASK) == LVS_ICON) || ((GetStyle() & LVS_TYPEMASK) == LVS_SMALLICON));
  2534. return (BOOL)::SendMessage(m_hWnd, LVM_SETITEMPOSITION32, nItem, (LPARAM)&pt);
  2535. }
  2536. BOOL SetItemPosition(int nItem, int x, int y)
  2537. {
  2538. ATLASSERT(::IsWindow(m_hWnd));
  2539. ATLASSERT(((GetStyle() & LVS_TYPEMASK) == LVS_ICON) || ((GetStyle() & LVS_TYPEMASK) == LVS_SMALLICON));
  2540. POINT pt = { x, y };
  2541. return (BOOL)::SendMessage(m_hWnd, LVM_SETITEMPOSITION32, nItem, (LPARAM)&pt);
  2542. }
  2543. int GetStringWidth(LPCTSTR lpsz) const
  2544. {
  2545. ATLASSERT(::IsWindow(m_hWnd));
  2546. return (int)::SendMessage(m_hWnd, LVM_GETSTRINGWIDTH, 0, (LPARAM)lpsz);
  2547. }
  2548. CEdit GetEditControl() const
  2549. {
  2550. ATLASSERT(::IsWindow(m_hWnd));
  2551. return CEdit((HWND)::SendMessage(m_hWnd, LVM_GETEDITCONTROL, 0, 0L));
  2552. }
  2553. BOOL GetColumn(int nCol, LVCOLUMN* pColumn) const
  2554. {
  2555. ATLASSERT(::IsWindow(m_hWnd));
  2556. return (BOOL)::SendMessage(m_hWnd, LVM_GETCOLUMN, nCol, (LPARAM)pColumn);
  2557. }
  2558. BOOL SetColumn(int nCol, const LVCOLUMN* pColumn)
  2559. {
  2560. ATLASSERT(::IsWindow(m_hWnd));
  2561. return (BOOL)::SendMessage(m_hWnd, LVM_SETCOLUMN, nCol, (LPARAM)pColumn);
  2562. }
  2563. int GetColumnWidth(int nCol) const
  2564. {
  2565. ATLASSERT(::IsWindow(m_hWnd));
  2566. return (int)::SendMessage(m_hWnd, LVM_GETCOLUMNWIDTH, nCol, 0L);
  2567. }
  2568. BOOL SetColumnWidth(int nCol, int cx)
  2569. {
  2570. ATLASSERT(::IsWindow(m_hWnd));
  2571. return (BOOL)::SendMessage(m_hWnd, LVM_SETCOLUMNWIDTH, nCol, MAKELPARAM(cx, 0));
  2572. }
  2573. BOOL GetViewRect(LPRECT lpRect) const
  2574. {
  2575. ATLASSERT(::IsWindow(m_hWnd));
  2576. return (BOOL)::SendMessage(m_hWnd, LVM_GETVIEWRECT, 0, (LPARAM)lpRect);
  2577. }
  2578. COLORREF GetTextColor() const
  2579. {
  2580. ATLASSERT(::IsWindow(m_hWnd));
  2581. return (COLORREF)::SendMessage(m_hWnd, LVM_GETTEXTCOLOR, 0, 0L);
  2582. }
  2583. BOOL SetTextColor(COLORREF cr)
  2584. {
  2585. ATLASSERT(::IsWindow(m_hWnd));
  2586. return (BOOL)::SendMessage(m_hWnd, LVM_SETTEXTCOLOR, 0, cr);
  2587. }
  2588. COLORREF GetTextBkColor() const
  2589. {
  2590. ATLASSERT(::IsWindow(m_hWnd));
  2591. return (COLORREF)::SendMessage(m_hWnd, LVM_GETTEXTBKCOLOR, 0, 0L);
  2592. }
  2593. BOOL SetTextBkColor(COLORREF cr)
  2594. {
  2595. ATLASSERT(::IsWindow(m_hWnd));
  2596. return (BOOL)::SendMessage(m_hWnd, LVM_SETTEXTBKCOLOR, 0, cr);
  2597. }
  2598. int GetTopIndex() const
  2599. {
  2600. ATLASSERT(::IsWindow(m_hWnd));
  2601. return (int)::SendMessage(m_hWnd, LVM_GETTOPINDEX, 0, 0L);
  2602. }
  2603. int GetCountPerPage() const
  2604. {
  2605. ATLASSERT(::IsWindow(m_hWnd));
  2606. return (int)::SendMessage(m_hWnd, LVM_GETCOUNTPERPAGE, 0, 0L);
  2607. }
  2608. BOOL GetOrigin(LPPOINT lpPoint) const
  2609. {
  2610. ATLASSERT(::IsWindow(m_hWnd));
  2611. return (BOOL)::SendMessage(m_hWnd, LVM_GETORIGIN, 0, (LPARAM)lpPoint);
  2612. }
  2613. UINT GetSelectedCount() const
  2614. {
  2615. ATLASSERT(::IsWindow(m_hWnd));
  2616. return (UINT)::SendMessage(m_hWnd, LVM_GETSELECTEDCOUNT, 0, 0L);
  2617. }
  2618. BOOL GetItemRect(int nItem, LPRECT lpRect, UINT nCode) const
  2619. {
  2620. ATLASSERT(::IsWindow(m_hWnd));
  2621. lpRect->left = nCode;
  2622. return (BOOL)::SendMessage(m_hWnd, LVM_GETITEMRECT, (WPARAM)nItem, (LPARAM)lpRect);
  2623. }
  2624. #ifndef _WIN32_WCE
  2625. HCURSOR GetHotCursor() const
  2626. {
  2627. ATLASSERT(::IsWindow(m_hWnd));
  2628. return (HCURSOR)::SendMessage(m_hWnd, LVM_GETHOTCURSOR, 0, 0L);
  2629. }
  2630. HCURSOR SetHotCursor(HCURSOR hHotCursor)
  2631. {
  2632. ATLASSERT(::IsWindow(m_hWnd));
  2633. return (HCURSOR)::SendMessage(m_hWnd, LVM_SETHOTCURSOR, 0, (LPARAM)hHotCursor);
  2634. }
  2635. int GetHotItem() const
  2636. {
  2637. ATLASSERT(::IsWindow(m_hWnd));
  2638. return (int)::SendMessage(m_hWnd, LVM_GETHOTITEM, 0, 0L);
  2639. }
  2640. int SetHotItem(int nIndex)
  2641. {
  2642. ATLASSERT(::IsWindow(m_hWnd));
  2643. return (int)::SendMessage(m_hWnd, LVM_SETHOTITEM, nIndex, 0L);
  2644. }
  2645. #endif // !_WIN32_WCE
  2646. BOOL GetColumnOrderArray(int nCount, int* lpnArray) const
  2647. {
  2648. ATLASSERT(::IsWindow(m_hWnd));
  2649. return (BOOL)::SendMessage(m_hWnd, LVM_GETCOLUMNORDERARRAY, nCount, (LPARAM)lpnArray);
  2650. }
  2651. BOOL SetColumnOrderArray(int nCount, int* lpnArray)
  2652. {
  2653. ATLASSERT(::IsWindow(m_hWnd));
  2654. return (BOOL)::SendMessage(m_hWnd, LVM_SETCOLUMNORDERARRAY, nCount, (LPARAM)lpnArray);
  2655. }
  2656. CHeaderCtrl GetHeader() const
  2657. {
  2658. ATLASSERT(::IsWindow(m_hWnd));
  2659. return CHeaderCtrl((HWND)::SendMessage(m_hWnd, LVM_GETHEADER, 0, 0L));
  2660. }
  2661. BOOL GetSubItemRect(int nItem, int nSubItem, int nFlag, LPRECT lpRect) const
  2662. {
  2663. ATLASSERT(::IsWindow(m_hWnd));
  2664. ATLASSERT((GetStyle() & LVS_TYPEMASK) == LVS_REPORT);
  2665. ATLASSERT(lpRect != NULL);
  2666. lpRect->top = nSubItem;
  2667. lpRect->left = nFlag;
  2668. return (BOOL)::SendMessage(m_hWnd, LVM_GETSUBITEMRECT, nItem, (LPARAM)lpRect);
  2669. }
  2670. DWORD SetIconSpacing(int cx, int cy)
  2671. {
  2672. ATLASSERT(::IsWindow(m_hWnd));
  2673. ATLASSERT((GetStyle() & LVS_TYPEMASK) == LVS_ICON);
  2674. return (DWORD)::SendMessage(m_hWnd, LVM_SETICONSPACING, 0, MAKELPARAM(cx, cy));
  2675. }
  2676. int GetISearchString(LPTSTR lpstr) const
  2677. {
  2678. ATLASSERT(::IsWindow(m_hWnd));
  2679. return (int)::SendMessage(m_hWnd, LVM_GETISEARCHSTRING, 0, (LPARAM)lpstr);
  2680. }
  2681. void GetItemSpacing(SIZE& sizeSpacing, BOOL bSmallIconView = FALSE) const
  2682. {
  2683. ATLASSERT(::IsWindow(m_hWnd));
  2684. DWORD dwRet = (DWORD)::SendMessage(m_hWnd, LVM_GETITEMSPACING, bSmallIconView, 0L);
  2685. sizeSpacing.cx = GET_X_LPARAM(dwRet);
  2686. sizeSpacing.cy = GET_Y_LPARAM(dwRet);
  2687. }
  2688. #if (_WIN32_WCE >= 410)
  2689. void SetItemSpacing(INT cySpacing)
  2690. {
  2691. ATLASSERT(::IsWindow(m_hWnd));
  2692. ListView_SetItemSpacing(m_hWnd, cySpacing);
  2693. }
  2694. #endif // (_WIN32_WCE >= 410)
  2695. // single-selection only
  2696. int GetSelectedIndex() const
  2697. {
  2698. ATLASSERT(::IsWindow(m_hWnd));
  2699. ATLASSERT((GetStyle() & LVS_SINGLESEL) != 0);
  2700. return (int)::SendMessage(m_hWnd, LVM_GETNEXTITEM, (WPARAM)-1, MAKELPARAM(LVNI_ALL | LVNI_SELECTED, 0));
  2701. }
  2702. BOOL GetSelectedItem(LPLVITEM pItem) const
  2703. {
  2704. ATLASSERT(::IsWindow(m_hWnd));
  2705. ATLASSERT((GetStyle() & LVS_SINGLESEL) != 0);
  2706. ATLASSERT(pItem != NULL);
  2707. pItem->iItem = (int)::SendMessage(m_hWnd, LVM_GETNEXTITEM, (WPARAM)-1, MAKELPARAM(LVNI_ALL | LVNI_SELECTED, 0));
  2708. if(pItem->iItem == -1)
  2709. return FALSE;
  2710. return (BOOL)::SendMessage(m_hWnd, LVM_GETITEM, 0, (LPARAM)pItem);
  2711. }
  2712. // extended list view styles
  2713. DWORD GetExtendedListViewStyle() const
  2714. {
  2715. ATLASSERT(::IsWindow(m_hWnd));
  2716. return (DWORD)::SendMessage(m_hWnd, LVM_GETEXTENDEDLISTVIEWSTYLE, 0, 0L);
  2717. }
  2718. // dwExMask = 0 means all styles
  2719. DWORD SetExtendedListViewStyle(DWORD dwExStyle, DWORD dwExMask = 0)
  2720. {
  2721. ATLASSERT(::IsWindow(m_hWnd));
  2722. return (DWORD)::SendMessage(m_hWnd, LVM_SETEXTENDEDLISTVIEWSTYLE, dwExMask, dwExStyle);
  2723. }
  2724. // checkboxes only
  2725. BOOL GetCheckState(int nIndex) const
  2726. {
  2727. ATLASSERT(::IsWindow(m_hWnd));
  2728. ATLASSERT((GetExtendedListViewStyle() & LVS_EX_CHECKBOXES) != 0);
  2729. UINT uRet = GetItemState(nIndex, LVIS_STATEIMAGEMASK);
  2730. return (uRet >> 12) - 1;
  2731. }
  2732. BOOL SetCheckState(int nItem, BOOL bCheck)
  2733. {
  2734. int nCheck = bCheck ? 2 : 1; // one based index
  2735. return SetItemState(nItem, INDEXTOSTATEIMAGEMASK(nCheck), LVIS_STATEIMAGEMASK);
  2736. }
  2737. // view type
  2738. DWORD GetViewType() const
  2739. {
  2740. ATLASSERT(::IsWindow(m_hWnd));
  2741. return (GetStyle() & LVS_TYPEMASK);
  2742. }
  2743. DWORD SetViewType(DWORD dwType)
  2744. {
  2745. ATLASSERT(::IsWindow(m_hWnd));
  2746. ATLASSERT(dwType == LVS_ICON || dwType == LVS_SMALLICON || dwType == LVS_LIST || dwType == LVS_REPORT);
  2747. DWORD dwOldType = GetViewType();
  2748. if(dwType != dwOldType)
  2749. ModifyStyle(LVS_TYPEMASK, (dwType & LVS_TYPEMASK));
  2750. return dwOldType;
  2751. }
  2752. #if (_WIN32_IE >= 0x0400)
  2753. #ifndef _WIN32_WCE
  2754. BOOL GetBkImage(LPLVBKIMAGE plvbki) const
  2755. {
  2756. ATLASSERT(::IsWindow(m_hWnd));
  2757. return (BOOL)::SendMessage(m_hWnd, LVM_GETBKIMAGE, 0, (LPARAM)plvbki);
  2758. }
  2759. BOOL SetBkImage(LPLVBKIMAGE plvbki)
  2760. {
  2761. ATLASSERT(::IsWindow(m_hWnd));
  2762. return (BOOL)::SendMessage(m_hWnd, LVM_SETBKIMAGE, 0, (LPARAM)plvbki);
  2763. }
  2764. #endif // !_WIN32_WCE
  2765. int GetSelectionMark() const
  2766. {
  2767. ATLASSERT(::IsWindow(m_hWnd));
  2768. return (int)::SendMessage(m_hWnd, LVM_GETSELECTIONMARK, 0, 0L);
  2769. }
  2770. int SetSelectionMark(int nIndex)
  2771. {
  2772. ATLASSERT(::IsWindow(m_hWnd));
  2773. return (int)::SendMessage(m_hWnd, LVM_SETSELECTIONMARK, 0, nIndex);
  2774. }
  2775. #ifndef _WIN32_WCE
  2776. BOOL GetWorkAreas(int nWorkAreas, LPRECT lpRect) const
  2777. {
  2778. ATLASSERT(::IsWindow(m_hWnd));
  2779. return (BOOL)::SendMessage(m_hWnd, LVM_GETWORKAREAS, nWorkAreas, (LPARAM)lpRect);
  2780. }
  2781. BOOL SetWorkAreas(int nWorkAreas, LPRECT lpRect)
  2782. {
  2783. ATLASSERT(::IsWindow(m_hWnd));
  2784. return (BOOL)::SendMessage(m_hWnd, LVM_SETWORKAREAS, nWorkAreas, (LPARAM)lpRect);
  2785. }
  2786. DWORD GetHoverTime() const
  2787. {
  2788. ATLASSERT(::IsWindow(m_hWnd));
  2789. ATLASSERT((GetExtendedListViewStyle() & (LVS_EX_TRACKSELECT | LVS_EX_ONECLICKACTIVATE | LVS_EX_TWOCLICKACTIVATE)) != 0);
  2790. return (DWORD)::SendMessage(m_hWnd, LVM_GETHOVERTIME, 0, 0L);
  2791. }
  2792. DWORD SetHoverTime(DWORD dwHoverTime)
  2793. {
  2794. ATLASSERT(::IsWindow(m_hWnd));
  2795. ATLASSERT((GetExtendedListViewStyle() & (LVS_EX_TRACKSELECT | LVS_EX_ONECLICKACTIVATE | LVS_EX_TWOCLICKACTIVATE)) != 0);
  2796. return (DWORD)::SendMessage(m_hWnd, LVM_SETHOVERTIME, 0, dwHoverTime);
  2797. }
  2798. BOOL GetNumberOfWorkAreas(int* pnWorkAreas) const
  2799. {
  2800. ATLASSERT(::IsWindow(m_hWnd));
  2801. return (BOOL)::SendMessage(m_hWnd, LVM_GETNUMBEROFWORKAREAS, 0, (LPARAM)pnWorkAreas);
  2802. }
  2803. #endif // !_WIN32_WCE
  2804. BOOL SetItemCountEx(int nItems, DWORD dwFlags)
  2805. {
  2806. ATLASSERT(::IsWindow(m_hWnd));
  2807. ATLASSERT(((GetStyle() & LVS_OWNERDATA) != 0) && (((GetStyle() & LVS_TYPEMASK) == LVS_REPORT) || ((GetStyle() & LVS_TYPEMASK) == LVS_LIST)));
  2808. return (BOOL)::SendMessage(m_hWnd, LVM_SETITEMCOUNT, nItems, dwFlags);
  2809. }
  2810. #ifndef _WIN32_WCE
  2811. CToolTipCtrl GetToolTips() const
  2812. {
  2813. ATLASSERT(::IsWindow(m_hWnd));
  2814. return CToolTipCtrl((HWND)::SendMessage(m_hWnd, LVM_GETTOOLTIPS, 0, 0L));
  2815. }
  2816. CToolTipCtrl SetToolTips(HWND hWndTT)
  2817. {
  2818. ATLASSERT(::IsWindow(m_hWnd));
  2819. return CToolTipCtrl((HWND)::SendMessage(m_hWnd, LVM_SETTOOLTIPS, (WPARAM)hWndTT, 0L));
  2820. }
  2821. BOOL GetUnicodeFormat() const
  2822. {
  2823. ATLASSERT(::IsWindow(m_hWnd));
  2824. return (BOOL)::SendMessage(m_hWnd, LVM_GETUNICODEFORMAT, 0, 0L);
  2825. }
  2826. BOOL SetUnicodeFormat(BOOL bUnicode = TRUE)
  2827. {
  2828. ATLASSERT(::IsWindow(m_hWnd));
  2829. return (BOOL)::SendMessage(m_hWnd, LVM_SETUNICODEFORMAT, bUnicode, 0L);
  2830. }
  2831. #endif // !_WIN32_WCE
  2832. #endif // (_WIN32_IE >= 0x0400)
  2833. #if (_WIN32_WINNT >= 0x0501)
  2834. int GetSelectedColumn() const
  2835. {
  2836. ATLASSERT(::IsWindow(m_hWnd));
  2837. return (int)::SendMessage(m_hWnd, LVM_GETSELECTEDCOLUMN, 0, 0L);
  2838. }
  2839. void SetSelectedColumn(int nColumn)
  2840. {
  2841. ATLASSERT(::IsWindow(m_hWnd));
  2842. ::SendMessage(m_hWnd, LVM_SETSELECTEDCOLUMN, nColumn, 0L);
  2843. }
  2844. DWORD GetView() const
  2845. {
  2846. ATLASSERT(::IsWindow(m_hWnd));
  2847. return (DWORD)::SendMessage(m_hWnd, LVM_GETVIEW, 0, 0L);
  2848. }
  2849. int SetView(DWORD dwView)
  2850. {
  2851. ATLASSERT(::IsWindow(m_hWnd));
  2852. return (int)::SendMessage(m_hWnd, LVM_SETVIEW, dwView, 0L);
  2853. }
  2854. BOOL IsGroupViewEnabled() const
  2855. {
  2856. ATLASSERT(::IsWindow(m_hWnd));
  2857. return (BOOL)::SendMessage(m_hWnd, LVM_ISGROUPVIEWENABLED, 0, 0L);
  2858. }
  2859. int GetGroupInfo(int nGroupID, PLVGROUP pGroup) const
  2860. {
  2861. ATLASSERT(::IsWindow(m_hWnd));
  2862. return (int)::SendMessage(m_hWnd, LVM_GETGROUPINFO, nGroupID, (LPARAM)pGroup);
  2863. }
  2864. int SetGroupInfo(int nGroupID, PLVGROUP pGroup)
  2865. {
  2866. ATLASSERT(::IsWindow(m_hWnd));
  2867. return (int)::SendMessage(m_hWnd, LVM_SETGROUPINFO, nGroupID, (LPARAM)pGroup);
  2868. }
  2869. void GetGroupMetrics(PLVGROUPMETRICS pGroupMetrics) const
  2870. {
  2871. ATLASSERT(::IsWindow(m_hWnd));
  2872. ::SendMessage(m_hWnd, LVM_GETGROUPMETRICS, 0, (LPARAM)pGroupMetrics);
  2873. }
  2874. void SetGroupMetrics(PLVGROUPMETRICS pGroupMetrics)
  2875. {
  2876. ATLASSERT(::IsWindow(m_hWnd));
  2877. ::SendMessage(m_hWnd, LVM_SETGROUPMETRICS, 0, (LPARAM)pGroupMetrics);
  2878. }
  2879. void GetTileViewInfo(PLVTILEVIEWINFO pTileViewInfo) const
  2880. {
  2881. ATLASSERT(::IsWindow(m_hWnd));
  2882. ::SendMessage(m_hWnd, LVM_GETTILEVIEWINFO, 0, (LPARAM)pTileViewInfo);
  2883. }
  2884. BOOL SetTileViewInfo(PLVTILEVIEWINFO pTileViewInfo)
  2885. {
  2886. ATLASSERT(::IsWindow(m_hWnd));
  2887. return (BOOL)::SendMessage(m_hWnd, LVM_SETTILEVIEWINFO, 0, (LPARAM)pTileViewInfo);
  2888. }
  2889. void GetTileInfo(PLVTILEINFO pTileInfo) const
  2890. {
  2891. ATLASSERT(::IsWindow(m_hWnd));
  2892. ::SendMessage(m_hWnd, LVM_GETTILEINFO, 0, (LPARAM)pTileInfo);
  2893. }
  2894. BOOL SetTileInfo(PLVTILEINFO pTileInfo)
  2895. {
  2896. ATLASSERT(::IsWindow(m_hWnd));
  2897. return (BOOL)::SendMessage(m_hWnd, LVM_SETTILEINFO, 0, (LPARAM)pTileInfo);
  2898. }
  2899. BOOL GetInsertMark(LPLVINSERTMARK pInsertMark) const
  2900. {
  2901. ATLASSERT(::IsWindow(m_hWnd));
  2902. return (BOOL)::SendMessage(m_hWnd, LVM_GETINSERTMARK, 0, (LPARAM)pInsertMark);
  2903. }
  2904. BOOL SetInsertMark(LPLVINSERTMARK pInsertMark)
  2905. {
  2906. ATLASSERT(::IsWindow(m_hWnd));
  2907. return (BOOL)::SendMessage(m_hWnd, LVM_SETINSERTMARK, 0, (LPARAM)pInsertMark);
  2908. }
  2909. int GetInsertMarkRect(LPRECT lpRect) const
  2910. {
  2911. ATLASSERT(::IsWindow(m_hWnd));
  2912. return (int)::SendMessage(m_hWnd, LVM_GETINSERTMARKRECT, 0, (LPARAM)lpRect);
  2913. }
  2914. COLORREF GetInsertMarkColor() const
  2915. {
  2916. ATLASSERT(::IsWindow(m_hWnd));
  2917. return (COLORREF)::SendMessage(m_hWnd, LVM_GETINSERTMARKCOLOR, 0, 0L);
  2918. }
  2919. COLORREF SetInsertMarkColor(COLORREF clr)
  2920. {
  2921. ATLASSERT(::IsWindow(m_hWnd));
  2922. return (COLORREF)::SendMessage(m_hWnd, LVM_SETINSERTMARKCOLOR, 0, clr);
  2923. }
  2924. COLORREF GetOutlineColor() const
  2925. {
  2926. ATLASSERT(::IsWindow(m_hWnd));
  2927. return (COLORREF)::SendMessage(m_hWnd, LVM_GETOUTLINECOLOR, 0, 0L);
  2928. }
  2929. COLORREF SetOutlineColor(COLORREF clr)
  2930. {
  2931. ATLASSERT(::IsWindow(m_hWnd));
  2932. return (COLORREF)::SendMessage(m_hWnd, LVM_SETOUTLINECOLOR, 0, clr);
  2933. }
  2934. #endif // (_WIN32_WINNT >= 0x0501)
  2935. #if (_WIN32_WINNT >= 0x0600)
  2936. int GetGroupCount() const
  2937. {
  2938. ATLASSERT(::IsWindow(m_hWnd));
  2939. return (int)::SendMessage(m_hWnd, LVM_GETGROUPCOUNT, 0, 0L);
  2940. }
  2941. BOOL GetGroupInfoByIndex(int nIndex, PLVGROUP pGroup) const
  2942. {
  2943. ATLASSERT(::IsWindow(m_hWnd));
  2944. return (BOOL)::SendMessage(m_hWnd, LVM_GETGROUPINFOBYINDEX, nIndex, (LPARAM)pGroup);
  2945. }
  2946. BOOL GetGroupRect(int nGroupID, int nType, LPRECT lpRect) const
  2947. {
  2948. ATLASSERT(::IsWindow(m_hWnd));
  2949. ATLASSERT(lpRect != NULL);
  2950. if(lpRect != NULL)
  2951. lpRect->top = nType;
  2952. return (BOOL)::SendMessage(m_hWnd, LVM_GETGROUPRECT, nGroupID, (LPARAM)lpRect);
  2953. }
  2954. UINT GetGroupState(int nGroupID, UINT uMask) const
  2955. {
  2956. ATLASSERT(::IsWindow(m_hWnd));
  2957. return (UINT)::SendMessage(m_hWnd, LVM_GETGROUPSTATE, nGroupID, (LPARAM)uMask);
  2958. }
  2959. int GetFocusedGroup() const
  2960. {
  2961. ATLASSERT(::IsWindow(m_hWnd));
  2962. return (int)::SendMessage(m_hWnd, LVM_GETFOCUSEDGROUP, 0, 0L);
  2963. }
  2964. BOOL GetEmptyText(LPWSTR lpstrText, int cchText) const
  2965. {
  2966. ATLASSERT(::IsWindow(m_hWnd));
  2967. return (BOOL)::SendMessage(m_hWnd, LVM_GETEMPTYTEXT, cchText, (LPARAM)lpstrText);
  2968. }
  2969. BOOL GetFooterRect(LPRECT lpRect) const
  2970. {
  2971. ATLASSERT(::IsWindow(m_hWnd));
  2972. return (BOOL)::SendMessage(m_hWnd, LVM_GETFOOTERRECT, 0, (LPARAM)lpRect);
  2973. }
  2974. BOOL GetFooterInfo(LPLVFOOTERINFO lpFooterInfo) const
  2975. {
  2976. ATLASSERT(::IsWindow(m_hWnd));
  2977. return (BOOL)::SendMessage(m_hWnd, LVM_GETFOOTERINFO, 0, (LPARAM)lpFooterInfo);
  2978. }
  2979. BOOL GetFooterItemRect(int nItem, LPRECT lpRect) const
  2980. {
  2981. ATLASSERT(::IsWindow(m_hWnd));
  2982. return (BOOL)::SendMessage(m_hWnd, LVM_GETFOOTERITEMRECT, nItem, (LPARAM)lpRect);
  2983. }
  2984. BOOL GetFooterItem(int nItem, LPLVFOOTERITEM lpFooterItem) const
  2985. {
  2986. ATLASSERT(::IsWindow(m_hWnd));
  2987. return (BOOL)::SendMessage(m_hWnd, LVM_GETFOOTERITEM, nItem, (LPARAM)lpFooterItem);
  2988. }
  2989. BOOL GetItemIndexRect(PLVITEMINDEX pItemIndex, int nSubItem, int nType, LPRECT lpRect) const
  2990. {
  2991. ATLASSERT(::IsWindow(m_hWnd));
  2992. ATLASSERT(pItemIndex != NULL);
  2993. ATLASSERT(lpRect != NULL);
  2994. if(lpRect != NULL)
  2995. {
  2996. lpRect->top = nSubItem;
  2997. lpRect->left = nType;
  2998. }
  2999. return (BOOL)::SendMessage(m_hWnd, LVM_GETITEMINDEXRECT, (WPARAM)pItemIndex, (LPARAM)lpRect);
  3000. }
  3001. BOOL SetItemIndexState(PLVITEMINDEX pItemIndex, UINT uState, UINT dwMask)
  3002. {
  3003. ATLASSERT(::IsWindow(m_hWnd));
  3004. LVITEM lvi = { 0 };
  3005. lvi.state = uState;
  3006. lvi.stateMask = dwMask;
  3007. return (BOOL)::SendMessage(m_hWnd, LVM_SETITEMINDEXSTATE, (WPARAM)pItemIndex, (LPARAM)&lvi);
  3008. }
  3009. BOOL GetNextItemIndex(PLVITEMINDEX pItemIndex, WORD wFlags) const
  3010. {
  3011. ATLASSERT(::IsWindow(m_hWnd));
  3012. return (BOOL)::SendMessage(m_hWnd, LVM_GETNEXTITEMINDEX, (WPARAM)pItemIndex, MAKELPARAM(wFlags, 0));
  3013. }
  3014. #endif // (_WIN32_WINNT >= 0x0600)
  3015. // Operations
  3016. int InsertColumn(int nCol, const LVCOLUMN* pColumn)
  3017. {
  3018. ATLASSERT(::IsWindow(m_hWnd));
  3019. return (int)::SendMessage(m_hWnd, LVM_INSERTCOLUMN, nCol, (LPARAM)pColumn);
  3020. }
  3021. int InsertColumn(int nCol, LPCTSTR lpszColumnHeading, int nFormat = LVCFMT_LEFT,
  3022. int nWidth = -1, int nSubItem = -1, int iImage = -1, int iOrder = -1)
  3023. {
  3024. LVCOLUMN column = { 0 };
  3025. column.mask = LVCF_TEXT|LVCF_FMT;
  3026. column.pszText = (LPTSTR)lpszColumnHeading;
  3027. column.fmt = nFormat;
  3028. if (nWidth != -1)
  3029. {
  3030. column.mask |= LVCF_WIDTH;
  3031. column.cx = nWidth;
  3032. }
  3033. if (nSubItem != -1)
  3034. {
  3035. column.mask |= LVCF_SUBITEM;
  3036. column.iSubItem = nSubItem;
  3037. }
  3038. if (iImage != -1)
  3039. {
  3040. column.mask |= LVCF_IMAGE;
  3041. column.iImage = iImage;
  3042. }
  3043. if (iOrder != -1)
  3044. {
  3045. column.mask |= LVCF_ORDER;
  3046. column.iOrder = iOrder;
  3047. }
  3048. return InsertColumn(nCol, &column);
  3049. }
  3050. BOOL DeleteColumn(int nCol)
  3051. {
  3052. ATLASSERT(::IsWindow(m_hWnd));
  3053. return (BOOL)::SendMessage(m_hWnd, LVM_DELETECOLUMN, nCol, 0L);
  3054. }
  3055. int InsertItem(UINT nMask, int nItem, LPCTSTR lpszItem, UINT nState, UINT nStateMask, int nImage, LPARAM lParam)
  3056. {
  3057. ATLASSERT(::IsWindow(m_hWnd));
  3058. LVITEM item = { 0 };
  3059. item.mask = nMask;
  3060. item.iItem = nItem;
  3061. item.iSubItem = 0;
  3062. item.pszText = (LPTSTR)lpszItem;
  3063. item.state = nState;
  3064. item.stateMask = nStateMask;
  3065. item.iImage = nImage;
  3066. item.lParam = lParam;
  3067. return InsertItem(&item);
  3068. }
  3069. int InsertItem(const LVITEM* pItem)
  3070. {
  3071. ATLASSERT(::IsWindow(m_hWnd));
  3072. return (int)::SendMessage(m_hWnd, LVM_INSERTITEM, 0, (LPARAM)pItem);
  3073. }
  3074. int InsertItem(int nItem, LPCTSTR lpszItem)
  3075. {
  3076. ATLASSERT(::IsWindow(m_hWnd));
  3077. return InsertItem(LVIF_TEXT, nItem, lpszItem, 0, 0, 0, 0);
  3078. }
  3079. int InsertItem(int nItem, LPCTSTR lpszItem, int nImage)
  3080. {
  3081. ATLASSERT(::IsWindow(m_hWnd));
  3082. return InsertItem(LVIF_TEXT|LVIF_IMAGE, nItem, lpszItem, 0, 0, nImage, 0);
  3083. }
  3084. int GetNextItem(int nItem, int nFlags) const
  3085. {
  3086. ATLASSERT(::IsWindow(m_hWnd));
  3087. return (int)::SendMessage(m_hWnd, LVM_GETNEXTITEM, nItem, MAKELPARAM(nFlags, 0));
  3088. }
  3089. BOOL DeleteItem(int nItem)
  3090. {
  3091. ATLASSERT(::IsWindow(m_hWnd));
  3092. return (BOOL)::SendMessage(m_hWnd, LVM_DELETEITEM, nItem, 0L);
  3093. }
  3094. BOOL DeleteAllItems()
  3095. {
  3096. ATLASSERT(::IsWindow(m_hWnd));
  3097. return (BOOL)::SendMessage(m_hWnd, LVM_DELETEALLITEMS, 0, 0L);
  3098. }
  3099. int FindItem(LVFINDINFO* pFindInfo, int nStart) const
  3100. {
  3101. ATLASSERT(::IsWindow(m_hWnd));
  3102. return (int)::SendMessage(m_hWnd, LVM_FINDITEM, nStart, (LPARAM)pFindInfo);
  3103. }
  3104. int HitTest(LVHITTESTINFO* pHitTestInfo) const
  3105. {
  3106. ATLASSERT(::IsWindow(m_hWnd));
  3107. return (int)::SendMessage(m_hWnd, LVM_HITTEST, 0, (LPARAM)pHitTestInfo);
  3108. }
  3109. int HitTest(POINT pt, UINT* pFlags) const
  3110. {
  3111. ATLASSERT(::IsWindow(m_hWnd));
  3112. LVHITTESTINFO hti = { 0 };
  3113. hti.pt = pt;
  3114. int nRes = (int)::SendMessage(m_hWnd, LVM_HITTEST, 0, (LPARAM)&hti);
  3115. if (pFlags != NULL)
  3116. *pFlags = hti.flags;
  3117. return nRes;
  3118. }
  3119. BOOL EnsureVisible(int nItem, BOOL bPartialOK)
  3120. {
  3121. ATLASSERT(::IsWindow(m_hWnd));
  3122. return (BOOL)::SendMessage(m_hWnd, LVM_ENSUREVISIBLE, nItem, MAKELPARAM(bPartialOK, 0));
  3123. }
  3124. BOOL Scroll(SIZE size)
  3125. {
  3126. ATLASSERT(::IsWindow(m_hWnd));
  3127. return (BOOL)::SendMessage(m_hWnd, LVM_SCROLL, size.cx, size.cy);
  3128. }
  3129. BOOL RedrawItems(int nFirst, int nLast)
  3130. {
  3131. ATLASSERT(::IsWindow(m_hWnd));
  3132. return (BOOL)::SendMessage(m_hWnd, LVM_REDRAWITEMS, nFirst, nLast);
  3133. }
  3134. BOOL Arrange(UINT nCode)
  3135. {
  3136. ATLASSERT(::IsWindow(m_hWnd));
  3137. return (BOOL)::SendMessage(m_hWnd, LVM_ARRANGE, nCode, 0L);
  3138. }
  3139. CEdit EditLabel(int nItem)
  3140. {
  3141. ATLASSERT(::IsWindow(m_hWnd));
  3142. return CEdit((HWND)::SendMessage(m_hWnd, LVM_EDITLABEL, nItem, 0L));
  3143. }
  3144. BOOL Update(int nItem)
  3145. {
  3146. ATLASSERT(::IsWindow(m_hWnd));
  3147. return (BOOL)::SendMessage(m_hWnd, LVM_UPDATE, nItem, 0L);
  3148. }
  3149. BOOL SortItems(PFNLVCOMPARE pfnCompare, LPARAM lParamSort)
  3150. {
  3151. ATLASSERT(::IsWindow(m_hWnd));
  3152. return (BOOL)::SendMessage(m_hWnd, LVM_SORTITEMS, (WPARAM)lParamSort, (LPARAM)pfnCompare);
  3153. }
  3154. CImageList RemoveImageList(int nImageList)
  3155. {
  3156. ATLASSERT(::IsWindow(m_hWnd));
  3157. return CImageList((HIMAGELIST)::SendMessage(m_hWnd, LVM_SETIMAGELIST, (WPARAM)nImageList, NULL));
  3158. }
  3159. CImageList CreateDragImage(int nItem, LPPOINT lpPoint)
  3160. {
  3161. ATLASSERT(::IsWindow(m_hWnd));
  3162. return CImageList((HIMAGELIST)::SendMessage(m_hWnd, LVM_CREATEDRAGIMAGE, nItem, (LPARAM)lpPoint));
  3163. }
  3164. DWORD ApproximateViewRect(int cx = -1, int cy = -1, int nCount = -1)
  3165. {
  3166. ATLASSERT(::IsWindow(m_hWnd));
  3167. return (DWORD)::SendMessage(m_hWnd, LVM_APPROXIMATEVIEWRECT, nCount, MAKELPARAM(cx, cy));
  3168. }
  3169. int SubItemHitTest(LPLVHITTESTINFO lpInfo) const
  3170. {
  3171. ATLASSERT(::IsWindow(m_hWnd));
  3172. return (int)::SendMessage(m_hWnd, LVM_SUBITEMHITTEST, 0, (LPARAM)lpInfo);
  3173. }
  3174. int AddColumn(LPCTSTR strItem, int nItem, int nSubItem = -1,
  3175. int nMask = LVCF_FMT | LVCF_WIDTH | LVCF_TEXT | LVCF_SUBITEM,
  3176. int nFmt = LVCFMT_LEFT)
  3177. {
  3178. const int cxOffset = 15;
  3179. ATLASSERT(::IsWindow(m_hWnd));
  3180. LVCOLUMN lvc = { 0 };
  3181. lvc.mask = nMask;
  3182. lvc.fmt = nFmt;
  3183. lvc.pszText = (LPTSTR)strItem;
  3184. lvc.cx = GetStringWidth(lvc.pszText) + cxOffset;
  3185. if(nMask & LVCF_SUBITEM)
  3186. lvc.iSubItem = (nSubItem != -1) ? nSubItem : nItem;
  3187. return InsertColumn(nItem, &lvc);
  3188. }
  3189. int AddItem(int nItem, int nSubItem, LPCTSTR strItem, int nImageIndex = -1)
  3190. {
  3191. ATLASSERT(::IsWindow(m_hWnd));
  3192. LVITEM lvItem = { 0 };
  3193. lvItem.mask = LVIF_TEXT;
  3194. lvItem.iItem = nItem;
  3195. lvItem.iSubItem = nSubItem;
  3196. lvItem.pszText = (LPTSTR)strItem;
  3197. if(nImageIndex != -1)
  3198. {
  3199. lvItem.mask |= LVIF_IMAGE;
  3200. lvItem.iImage = nImageIndex;
  3201. }
  3202. if(nSubItem == 0)
  3203. return InsertItem(&lvItem);
  3204. return SetItem(&lvItem) ? nItem : -1;
  3205. }
  3206. #if (_WIN32_IE >= 0x0500) && !defined(_WIN32_WCE)
  3207. BOOL SortItemsEx(PFNLVCOMPARE pfnCompare, LPARAM lParamSort)
  3208. {
  3209. ATLASSERT(::IsWindow(m_hWnd));
  3210. return (BOOL)::SendMessage(m_hWnd, LVM_SORTITEMSEX, (WPARAM)lParamSort, (LPARAM)pfnCompare);
  3211. }
  3212. #endif // (_WIN32_IE >= 0x0500) && !defined(_WIN32_WCE)
  3213. #if (_WIN32_WINNT >= 0x0501)
  3214. int InsertGroup(int nItem, PLVGROUP pGroup)
  3215. {
  3216. ATLASSERT(::IsWindow(m_hWnd));
  3217. return (int)::SendMessage(m_hWnd, LVM_INSERTGROUP, nItem, (LPARAM)pGroup);
  3218. }
  3219. int AddGroup(PLVGROUP pGroup)
  3220. {
  3221. return InsertGroup(-1, pGroup);
  3222. }
  3223. int RemoveGroup(int nGroupID)
  3224. {
  3225. ATLASSERT(::IsWindow(m_hWnd));
  3226. return (int)::SendMessage(m_hWnd, LVM_REMOVEGROUP, nGroupID, 0L);
  3227. }
  3228. void MoveGroup(int nGroupID, int nItem)
  3229. {
  3230. ATLASSERT(::IsWindow(m_hWnd));
  3231. ::SendMessage(m_hWnd, LVM_MOVEGROUP, nGroupID, nItem);
  3232. }
  3233. void MoveItemToGroup(int nItem, int nGroupID)
  3234. {
  3235. ATLASSERT(::IsWindow(m_hWnd));
  3236. ::SendMessage(m_hWnd, LVM_MOVEITEMTOGROUP, nItem, nGroupID);
  3237. }
  3238. int EnableGroupView(BOOL bEnable)
  3239. {
  3240. ATLASSERT(::IsWindow(m_hWnd));
  3241. return (int)::SendMessage(m_hWnd, LVM_ENABLEGROUPVIEW, bEnable, 0L);
  3242. }
  3243. int SortGroups(PFNLVGROUPCOMPARE pCompareFunc, LPVOID lpVoid = NULL)
  3244. {
  3245. ATLASSERT(::IsWindow(m_hWnd));
  3246. return (int)::SendMessage(m_hWnd, LVM_SORTGROUPS, (WPARAM)pCompareFunc, (LPARAM)lpVoid);
  3247. }
  3248. void InsertGroupSorted(PLVINSERTGROUPSORTED pInsertGroupSorted)
  3249. {
  3250. ATLASSERT(::IsWindow(m_hWnd));
  3251. ::SendMessage(m_hWnd, LVM_INSERTGROUPSORTED, (WPARAM)pInsertGroupSorted, 0L);
  3252. }
  3253. void RemoveAllGroups()
  3254. {
  3255. ATLASSERT(::IsWindow(m_hWnd));
  3256. ::SendMessage(m_hWnd, LVM_REMOVEALLGROUPS, 0, 0L);
  3257. }
  3258. BOOL HasGroup(int nGroupID)
  3259. {
  3260. ATLASSERT(::IsWindow(m_hWnd));
  3261. return (BOOL)::SendMessage(m_hWnd, LVM_HASGROUP, nGroupID, 0L);
  3262. }
  3263. BOOL InsertMarkHitTest(LPPOINT lpPoint, LPLVINSERTMARK pInsertMark) const
  3264. {
  3265. ATLASSERT(::IsWindow(m_hWnd));
  3266. return (BOOL)::SendMessage(m_hWnd, LVM_INSERTMARKHITTEST, (WPARAM)lpPoint, (LPARAM)pInsertMark);
  3267. }
  3268. BOOL SetInfoTip(PLVSETINFOTIP pSetInfoTip)
  3269. {
  3270. ATLASSERT(::IsWindow(m_hWnd));
  3271. return (BOOL)::SendMessage(m_hWnd, LVM_SETINFOTIP, 0, (LPARAM)pSetInfoTip);
  3272. }
  3273. void CancelEditLabel()
  3274. {
  3275. ATLASSERT(::IsWindow(m_hWnd));
  3276. ::SendMessage(m_hWnd, LVM_CANCELEDITLABEL, 0, 0L);
  3277. }
  3278. UINT MapIndexToID(int nIndex) const
  3279. {
  3280. ATLASSERT(::IsWindow(m_hWnd));
  3281. return (UINT)::SendMessage(m_hWnd, LVM_MAPINDEXTOID, nIndex, 0L);
  3282. }
  3283. int MapIDToIndex(UINT uID) const
  3284. {
  3285. ATLASSERT(::IsWindow(m_hWnd));
  3286. return (int)::SendMessage(m_hWnd, LVM_MAPIDTOINDEX, uID, 0L);
  3287. }
  3288. #endif // (_WIN32_WINNT >= 0x0501)
  3289. #if (_WIN32_WINNT >= 0x0600)
  3290. int HitTestEx(LPLVHITTESTINFO lpHitTestInfo) const
  3291. {
  3292. ATLASSERT(::IsWindow(m_hWnd));
  3293. return (int)::SendMessage(m_hWnd, LVM_HITTEST, (WPARAM)-1, (LPARAM)lpHitTestInfo);
  3294. }
  3295. int HitTestEx(POINT pt, UINT* pFlags) const
  3296. {
  3297. ATLASSERT(::IsWindow(m_hWnd));
  3298. LVHITTESTINFO hti = { 0 };
  3299. hti.pt = pt;
  3300. int nRes = (int)::SendMessage(m_hWnd, LVM_HITTEST, (WPARAM)-1, (LPARAM)&hti);
  3301. if (pFlags != NULL)
  3302. *pFlags = hti.flags;
  3303. return nRes;
  3304. }
  3305. int SubItemHitTestEx(LPLVHITTESTINFO lpHitTestInfo) const
  3306. {
  3307. ATLASSERT(::IsWindow(m_hWnd));
  3308. return (int)::SendMessage(m_hWnd, LVM_SUBITEMHITTEST, (WPARAM)-1, (LPARAM)lpHitTestInfo);
  3309. }
  3310. #endif // (_WIN32_WINNT >= 0x0600)
  3311. // Note: selects only one item
  3312. BOOL SelectItem(int nIndex)
  3313. {
  3314. ATLASSERT(::IsWindow(m_hWnd));
  3315. // multi-selection only: de-select all items
  3316. if((GetStyle() & LVS_SINGLESEL) == 0)
  3317. SetItemState(-1, 0, LVIS_SELECTED);
  3318. BOOL bRet = SetItemState(nIndex, LVIS_SELECTED | LVIS_FOCUSED, LVIS_SELECTED | LVIS_FOCUSED);
  3319. if(bRet)
  3320. bRet = EnsureVisible(nIndex, FALSE);
  3321. return bRet;
  3322. }
  3323. };
  3324. typedef CListViewCtrlT<ATL::CWindow> CListViewCtrl;
  3325. ///////////////////////////////////////////////////////////////////////////////
  3326. // CTreeViewCtrl
  3327. template <class TBase>
  3328. class CTreeViewCtrlT : public TBase
  3329. {
  3330. public:
  3331. // Constructors
  3332. CTreeViewCtrlT(HWND hWnd = NULL) : TBase(hWnd)
  3333. { }
  3334. CTreeViewCtrlT< TBase >& operator =(HWND hWnd)
  3335. {
  3336. m_hWnd = hWnd;
  3337. return *this;
  3338. }
  3339. HWND Create(HWND hWndParent, ATL::_U_RECT rect = NULL, LPCTSTR szWindowName = NULL,
  3340. DWORD dwStyle = 0, DWORD dwExStyle = 0,
  3341. ATL::_U_MENUorID MenuOrID = 0U, LPVOID lpCreateParam = NULL)
  3342. {
  3343. return TBase::Create(GetWndClassName(), hWndParent, rect.m_lpRect, szWindowName, dwStyle, dwExStyle, MenuOrID.m_hMenu, lpCreateParam);
  3344. }
  3345. // Attributes
  3346. static LPCTSTR GetWndClassName()
  3347. {
  3348. return WC_TREEVIEW;
  3349. }
  3350. UINT GetCount() const
  3351. {
  3352. ATLASSERT(::IsWindow(m_hWnd));
  3353. return (UINT)::SendMessage(m_hWnd, TVM_GETCOUNT, 0, 0L);
  3354. }
  3355. UINT GetIndent() const
  3356. {
  3357. ATLASSERT(::IsWindow(m_hWnd));
  3358. return (UINT)::SendMessage(m_hWnd, TVM_GETINDENT, 0, 0L);
  3359. }
  3360. void SetIndent(UINT nIndent)
  3361. {
  3362. ATLASSERT(::IsWindow(m_hWnd));
  3363. ::SendMessage(m_hWnd, TVM_SETINDENT, nIndent, 0L);
  3364. }
  3365. CImageList GetImageList(int nImageListType = TVSIL_NORMAL) const
  3366. {
  3367. ATLASSERT(::IsWindow(m_hWnd));
  3368. return CImageList((HIMAGELIST)::SendMessage(m_hWnd, TVM_GETIMAGELIST, (WPARAM)nImageListType, 0L));
  3369. }
  3370. CImageList SetImageList(HIMAGELIST hImageList, int nImageListType = TVSIL_NORMAL)
  3371. {
  3372. ATLASSERT(::IsWindow(m_hWnd));
  3373. return CImageList((HIMAGELIST)::SendMessage(m_hWnd, TVM_SETIMAGELIST, (WPARAM)nImageListType, (LPARAM)hImageList));
  3374. }
  3375. BOOL GetItem(LPTVITEM pItem) const
  3376. {
  3377. ATLASSERT(::IsWindow(m_hWnd));
  3378. return (BOOL)::SendMessage(m_hWnd, TVM_GETITEM, 0, (LPARAM)pItem);
  3379. }
  3380. BOOL SetItem(LPTVITEM pItem)
  3381. {
  3382. ATLASSERT(::IsWindow(m_hWnd));
  3383. return (BOOL)::SendMessage(m_hWnd, TVM_SETITEM, 0, (LPARAM)pItem);
  3384. }
  3385. BOOL SetItem(HTREEITEM hItem, UINT nMask, LPCTSTR lpszItem, int nImage,
  3386. int nSelectedImage, UINT nState, UINT nStateMask, LPARAM lParam)
  3387. {
  3388. ATLASSERT(::IsWindow(m_hWnd));
  3389. TVITEM item = { 0 };
  3390. item.hItem = hItem;
  3391. item.mask = nMask;
  3392. item.pszText = (LPTSTR) lpszItem;
  3393. item.iImage = nImage;
  3394. item.iSelectedImage = nSelectedImage;
  3395. item.state = nState;
  3396. item.stateMask = nStateMask;
  3397. item.lParam = lParam;
  3398. return (BOOL)::SendMessage(m_hWnd, TVM_SETITEM, 0, (LPARAM)&item);
  3399. }
  3400. BOOL GetItemText(HTREEITEM hItem, LPTSTR lpstrText, int nLen) const
  3401. {
  3402. ATLASSERT(::IsWindow(m_hWnd));
  3403. ATLASSERT(lpstrText != NULL);
  3404. TVITEM item = { 0 };
  3405. item.hItem = hItem;
  3406. item.mask = TVIF_TEXT;
  3407. item.pszText = lpstrText;
  3408. item.cchTextMax = nLen;
  3409. return (BOOL)::SendMessage(m_hWnd, TVM_GETITEM, 0, (LPARAM)&item);
  3410. }
  3411. #ifndef _ATL_NO_COM
  3412. BOOL GetItemText(HTREEITEM hItem, BSTR& bstrText) const
  3413. {
  3414. USES_CONVERSION;
  3415. ATLASSERT(::IsWindow(m_hWnd));
  3416. ATLASSERT(bstrText == NULL);
  3417. TVITEM item = { 0 };
  3418. item.hItem = hItem;
  3419. item.mask = TVIF_TEXT;
  3420. LPTSTR lpstrText = NULL;
  3421. BOOL bRet = FALSE;
  3422. for(int nLen = 256; ; nLen *= 2)
  3423. {
  3424. ATLTRY(lpstrText = new TCHAR[nLen]);
  3425. if(lpstrText == NULL)
  3426. break;
  3427. lpstrText[0] = NULL;
  3428. item.pszText = lpstrText;
  3429. item.cchTextMax = nLen;
  3430. bRet = (BOOL)::SendMessage(m_hWnd, TVM_GETITEM, 0, (LPARAM)&item);
  3431. if(!bRet || (lstrlen(item.pszText) < nLen - 1))
  3432. break;
  3433. delete [] lpstrText;
  3434. lpstrText = NULL;
  3435. }
  3436. if(lpstrText != NULL)
  3437. {
  3438. if(bRet)
  3439. bstrText = ::SysAllocString(T2OLE(lpstrText));
  3440. delete [] lpstrText;
  3441. }
  3442. return (bstrText != NULL) ? TRUE : FALSE;
  3443. }
  3444. #endif // !_ATL_NO_COM
  3445. #if defined(_WTL_USE_CSTRING) || defined(__ATLSTR_H__)
  3446. BOOL GetItemText(HTREEITEM hItem, _CSTRING_NS::CString& strText) const
  3447. {
  3448. ATLASSERT(::IsWindow(m_hWnd));
  3449. TVITEM item = { 0 };
  3450. item.hItem = hItem;
  3451. item.mask = TVIF_TEXT;
  3452. strText.Empty();
  3453. BOOL bRet = FALSE;
  3454. for(int nLen = 256; ; nLen *= 2)
  3455. {
  3456. item.pszText = strText.GetBufferSetLength(nLen);
  3457. if(item.pszText == NULL)
  3458. {
  3459. bRet = FALSE;
  3460. break;
  3461. }
  3462. item.cchTextMax = nLen;
  3463. bRet = (BOOL)::SendMessage(m_hWnd, TVM_GETITEM, 0, (LPARAM)&item);
  3464. if(!bRet || (lstrlen(item.pszText) < nLen - 1))
  3465. break;
  3466. }
  3467. strText.ReleaseBuffer();
  3468. return bRet;
  3469. }
  3470. #endif // defined(_WTL_USE_CSTRING) || defined(__ATLSTR_H__)
  3471. BOOL SetItemText(HTREEITEM hItem, LPCTSTR lpszItem)
  3472. {
  3473. ATLASSERT(::IsWindow(m_hWnd));
  3474. return SetItem(hItem, TVIF_TEXT, lpszItem, 0, 0, 0, 0, NULL);
  3475. }
  3476. BOOL GetItemImage(HTREEITEM hItem, int& nImage, int& nSelectedImage) const
  3477. {
  3478. ATLASSERT(::IsWindow(m_hWnd));
  3479. TVITEM item = { 0 };
  3480. item.hItem = hItem;
  3481. item.mask = TVIF_IMAGE|TVIF_SELECTEDIMAGE;
  3482. BOOL bRes = (BOOL)::SendMessage(m_hWnd, TVM_GETITEM, 0, (LPARAM)&item);
  3483. if (bRes)
  3484. {
  3485. nImage = item.iImage;
  3486. nSelectedImage = item.iSelectedImage;
  3487. }
  3488. return bRes;
  3489. }
  3490. BOOL SetItemImage(HTREEITEM hItem, int nImage, int nSelectedImage)
  3491. {
  3492. ATLASSERT(::IsWindow(m_hWnd));
  3493. return SetItem(hItem, TVIF_IMAGE|TVIF_SELECTEDIMAGE, NULL, nImage, nSelectedImage, 0, 0, NULL);
  3494. }
  3495. UINT GetItemState(HTREEITEM hItem, UINT nStateMask) const
  3496. {
  3497. ATLASSERT(::IsWindow(m_hWnd));
  3498. #if (_WIN32_IE >= 0x0500) && !defined(_WIN32_WCE)
  3499. return (((UINT)::SendMessage(m_hWnd, TVM_GETITEMSTATE, (WPARAM)hItem, (LPARAM)nStateMask)) & nStateMask);
  3500. #else // !((_WIN32_IE >= 0x0500) && !defined(_WIN32_WCE))
  3501. TVITEM item = { 0 };
  3502. item.hItem = hItem;
  3503. item.mask = TVIF_STATE;
  3504. item.state = 0;
  3505. item.stateMask = nStateMask;
  3506. ::SendMessage(m_hWnd, TVM_GETITEM, 0, (LPARAM)&item);
  3507. return (item.state & nStateMask);
  3508. #endif // !((_WIN32_IE >= 0x0500) && !defined(_WIN32_WCE))
  3509. }
  3510. BOOL SetItemState(HTREEITEM hItem, UINT nState, UINT nStateMask)
  3511. {
  3512. ATLASSERT(::IsWindow(m_hWnd));
  3513. return SetItem(hItem, TVIF_STATE, NULL, 0, 0, nState, nStateMask, NULL);
  3514. }
  3515. DWORD_PTR GetItemData(HTREEITEM hItem) const
  3516. {
  3517. ATLASSERT(::IsWindow(m_hWnd));
  3518. TVITEM item = { 0 };
  3519. item.hItem = hItem;
  3520. item.mask = TVIF_PARAM;
  3521. BOOL bRet = (BOOL)::SendMessage(m_hWnd, TVM_GETITEM, 0, (LPARAM)&item);
  3522. return (DWORD_PTR)(bRet ? item.lParam : NULL);
  3523. }
  3524. BOOL SetItemData(HTREEITEM hItem, DWORD_PTR dwData)
  3525. {
  3526. ATLASSERT(::IsWindow(m_hWnd));
  3527. return SetItem(hItem, TVIF_PARAM, NULL, 0, 0, 0, 0, (LPARAM)dwData);
  3528. }
  3529. CEdit GetEditControl() const
  3530. {
  3531. ATLASSERT(::IsWindow(m_hWnd));
  3532. return CEdit((HWND)::SendMessage(m_hWnd, TVM_GETEDITCONTROL, 0, 0L));
  3533. }
  3534. UINT GetVisibleCount() const
  3535. {
  3536. ATLASSERT(::IsWindow(m_hWnd));
  3537. return (UINT)::SendMessage(m_hWnd, TVM_GETVISIBLECOUNT, 0, 0L);
  3538. }
  3539. BOOL GetItemRect(HTREEITEM hItem, LPRECT lpRect, BOOL bTextOnly) const
  3540. {
  3541. ATLASSERT(::IsWindow(m_hWnd));
  3542. *(HTREEITEM*)lpRect = hItem;
  3543. return (BOOL)::SendMessage(m_hWnd, TVM_GETITEMRECT, (WPARAM)bTextOnly, (LPARAM)lpRect);
  3544. }
  3545. BOOL ItemHasChildren(HTREEITEM hItem) const
  3546. {
  3547. ATLASSERT(::IsWindow(m_hWnd));
  3548. TVITEM item = { 0 };
  3549. item.hItem = hItem;
  3550. item.mask = TVIF_CHILDREN;
  3551. ::SendMessage(m_hWnd, TVM_GETITEM, 0, (LPARAM)&item);
  3552. return item.cChildren;
  3553. }
  3554. #ifndef _WIN32_WCE
  3555. CToolTipCtrl GetToolTips() const
  3556. {
  3557. ATLASSERT(::IsWindow(m_hWnd));
  3558. return CToolTipCtrl((HWND)::SendMessage(m_hWnd, TVM_GETTOOLTIPS, 0, 0L));
  3559. }
  3560. CToolTipCtrl SetToolTips(HWND hWndTT)
  3561. {
  3562. ATLASSERT(::IsWindow(m_hWnd));
  3563. return CToolTipCtrl((HWND)::SendMessage(m_hWnd, TVM_SETTOOLTIPS, (WPARAM)hWndTT, 0L));
  3564. }
  3565. #endif // !_WIN32_WCE
  3566. int GetISearchString(LPTSTR lpstr) const
  3567. {
  3568. ATLASSERT(::IsWindow(m_hWnd));
  3569. return (int)::SendMessage(m_hWnd, TVM_GETISEARCHSTRING, 0, (LPARAM)lpstr);
  3570. }
  3571. // checkboxes only
  3572. BOOL GetCheckState(HTREEITEM hItem) const
  3573. {
  3574. ATLASSERT(::IsWindow(m_hWnd));
  3575. ATLASSERT((GetStyle() & TVS_CHECKBOXES) != 0);
  3576. UINT uRet = GetItemState(hItem, TVIS_STATEIMAGEMASK);
  3577. return (uRet >> 12) - 1;
  3578. }
  3579. BOOL SetCheckState(HTREEITEM hItem, BOOL bCheck)
  3580. {
  3581. int nCheck = bCheck ? 2 : 1; // one based index
  3582. return SetItemState(hItem, INDEXTOSTATEIMAGEMASK(nCheck), TVIS_STATEIMAGEMASK);
  3583. }
  3584. #if (_WIN32_IE >= 0x0400) && !defined(_WIN32_WCE)
  3585. COLORREF GetBkColor() const
  3586. {
  3587. ATLASSERT(::IsWindow(m_hWnd));
  3588. return (COLORREF)::SendMessage(m_hWnd, TVM_GETBKCOLOR, 0, 0L);
  3589. }
  3590. COLORREF SetBkColor(COLORREF clr)
  3591. {
  3592. ATLASSERT(::IsWindow(m_hWnd));
  3593. return (COLORREF)::SendMessage(m_hWnd, TVM_SETBKCOLOR, 0, (LPARAM)clr);
  3594. }
  3595. COLORREF GetInsertMarkColor() const
  3596. {
  3597. ATLASSERT(::IsWindow(m_hWnd));
  3598. return (COLORREF)::SendMessage(m_hWnd, TVM_GETINSERTMARKCOLOR, 0, 0L);
  3599. }
  3600. COLORREF SetInsertMarkColor(COLORREF clr)
  3601. {
  3602. ATLASSERT(::IsWindow(m_hWnd));
  3603. return (COLORREF)::SendMessage(m_hWnd, TVM_SETINSERTMARKCOLOR, 0, (LPARAM)clr);
  3604. }
  3605. int GetItemHeight() const
  3606. {
  3607. ATLASSERT(::IsWindow(m_hWnd));
  3608. return (int)::SendMessage(m_hWnd, TVM_GETITEMHEIGHT, 0, 0L);
  3609. }
  3610. int SetItemHeight(int cyHeight)
  3611. {
  3612. ATLASSERT(::IsWindow(m_hWnd));
  3613. return (int)::SendMessage(m_hWnd, TVM_SETITEMHEIGHT, cyHeight, 0L);
  3614. }
  3615. int GetScrollTime() const
  3616. {
  3617. ATLASSERT(::IsWindow(m_hWnd));
  3618. return (int)::SendMessage(m_hWnd, TVM_GETSCROLLTIME, 0, 0L);
  3619. }
  3620. int SetScrollTime(int nScrollTime)
  3621. {
  3622. ATLASSERT(::IsWindow(m_hWnd));
  3623. return (int)::SendMessage(m_hWnd, TVM_SETSCROLLTIME, nScrollTime, 0L);
  3624. }
  3625. COLORREF GetTextColor() const
  3626. {
  3627. ATLASSERT(::IsWindow(m_hWnd));
  3628. return (COLORREF)::SendMessage(m_hWnd, TVM_GETTEXTCOLOR, 0, 0L);
  3629. }
  3630. COLORREF SetTextColor(COLORREF clr)
  3631. {
  3632. ATLASSERT(::IsWindow(m_hWnd));
  3633. return (COLORREF)::SendMessage(m_hWnd, TVM_SETTEXTCOLOR, 0, (LPARAM)clr);
  3634. }
  3635. BOOL GetUnicodeFormat() const
  3636. {
  3637. ATLASSERT(::IsWindow(m_hWnd));
  3638. return (BOOL)::SendMessage(m_hWnd, TVM_GETUNICODEFORMAT, 0, 0L);
  3639. }
  3640. BOOL SetUnicodeFormat(BOOL bUnicode = TRUE)
  3641. {
  3642. ATLASSERT(::IsWindow(m_hWnd));
  3643. return (BOOL)::SendMessage(m_hWnd, TVM_SETUNICODEFORMAT, bUnicode, 0L);
  3644. }
  3645. #endif // (_WIN32_IE >= 0x0400) && !defined(_WIN32_WCE)
  3646. #if (_WIN32_IE >= 0x0500) && !defined(_WIN32_WCE)
  3647. COLORREF GetLineColor() const
  3648. {
  3649. ATLASSERT(::IsWindow(m_hWnd));
  3650. return (COLORREF)::SendMessage(m_hWnd, TVM_GETLINECOLOR, 0, 0L);
  3651. }
  3652. COLORREF SetLineColor(COLORREF clrNew /*= CLR_DEFAULT*/)
  3653. {
  3654. ATLASSERT(::IsWindow(m_hWnd));
  3655. return (COLORREF)::SendMessage(m_hWnd, TVM_SETLINECOLOR, 0, (LPARAM)clrNew);
  3656. }
  3657. #endif // (_WIN32_IE >= 0x0500) && !defined(_WIN32_WCE)
  3658. #if (_WIN32_IE >= 0x0400) && !defined(_WIN32_WCE)
  3659. BOOL GetItem(LPTVITEMEX pItem) const
  3660. {
  3661. ATLASSERT(::IsWindow(m_hWnd));
  3662. return (BOOL)::SendMessage(m_hWnd, TVM_GETITEM, 0, (LPARAM)pItem);
  3663. }
  3664. BOOL SetItem(LPTVITEMEX pItem)
  3665. {
  3666. ATLASSERT(::IsWindow(m_hWnd));
  3667. return (BOOL)::SendMessage(m_hWnd, TVM_SETITEM, 0, (LPARAM)pItem);
  3668. }
  3669. #endif // (_WIN32_IE >= 0x0400) && !defined(_WIN32_WCE)
  3670. DWORD GetExtendedStyle() const
  3671. {
  3672. #ifndef TVM_GETEXTENDEDSTYLE
  3673. const UINT TVM_GETEXTENDEDSTYLE = (TV_FIRST + 45);
  3674. #endif
  3675. ATLASSERT(::IsWindow(m_hWnd));
  3676. return (DWORD)::SendMessage(m_hWnd, TVM_GETEXTENDEDSTYLE, 0, 0L);
  3677. }
  3678. DWORD SetExtendedStyle(DWORD dwStyle, DWORD dwMask)
  3679. {
  3680. #ifndef TVM_SETEXTENDEDSTYLE
  3681. const UINT TVM_SETEXTENDEDSTYLE = (TV_FIRST + 44);
  3682. #endif
  3683. ATLASSERT(::IsWindow(m_hWnd));
  3684. return (DWORD)::SendMessage(m_hWnd, TVM_SETEXTENDEDSTYLE, dwMask, dwStyle);
  3685. }
  3686. #if (_WIN32_WINNT >= 0x0600)
  3687. BOOL SetAutoScrollInfo(UINT uPixPerSec, UINT uUpdateTime)
  3688. {
  3689. ATLASSERT(::IsWindow(m_hWnd));
  3690. return (BOOL)::SendMessage(m_hWnd, TVM_SETAUTOSCROLLINFO, (WPARAM)uPixPerSec, (LPARAM)uUpdateTime);
  3691. }
  3692. DWORD GetSelectedCount() const
  3693. {
  3694. ATLASSERT(::IsWindow(m_hWnd));
  3695. return (DWORD)::SendMessage(m_hWnd, TVM_GETSELECTEDCOUNT, 0, 0L);
  3696. }
  3697. BOOL GetItemPartRect(HTREEITEM hItem, TVITEMPART partID, LPRECT lpRect) const
  3698. {
  3699. ATLASSERT(::IsWindow(m_hWnd));
  3700. TVGETITEMPARTRECTINFO gipri = { hItem, lpRect, partID };
  3701. return (BOOL)::SendMessage(m_hWnd, TVM_GETITEMPARTRECT, 0, (LPARAM)&gipri);
  3702. }
  3703. #endif // (_WIN32_WINNT >= 0x0600)
  3704. // Operations
  3705. HTREEITEM InsertItem(LPTVINSERTSTRUCT lpInsertStruct)
  3706. {
  3707. ATLASSERT(::IsWindow(m_hWnd));
  3708. return (HTREEITEM)::SendMessage(m_hWnd, TVM_INSERTITEM, 0, (LPARAM)lpInsertStruct);
  3709. }
  3710. HTREEITEM InsertItem(LPCTSTR lpszItem, int nImage,
  3711. int nSelectedImage, HTREEITEM hParent, HTREEITEM hInsertAfter)
  3712. {
  3713. ATLASSERT(::IsWindow(m_hWnd));
  3714. return InsertItem(TVIF_TEXT | TVIF_IMAGE | TVIF_SELECTEDIMAGE, lpszItem, nImage, nSelectedImage, 0, 0, 0, hParent, hInsertAfter);
  3715. }
  3716. HTREEITEM InsertItem(LPCTSTR lpszItem, HTREEITEM hParent, HTREEITEM hInsertAfter)
  3717. {
  3718. ATLASSERT(::IsWindow(m_hWnd));
  3719. return InsertItem(TVIF_TEXT, lpszItem, 0, 0, 0, 0, 0, hParent, hInsertAfter);
  3720. }
  3721. HTREEITEM InsertItem(UINT nMask, LPCTSTR lpszItem, int nImage,
  3722. int nSelectedImage, UINT nState, UINT nStateMask, LPARAM lParam,
  3723. HTREEITEM hParent, HTREEITEM hInsertAfter)
  3724. {
  3725. ATLASSERT(::IsWindow(m_hWnd));
  3726. TVINSERTSTRUCT tvis = { 0 };
  3727. tvis.hParent = hParent;
  3728. tvis.hInsertAfter = hInsertAfter;
  3729. tvis.item.mask = nMask;
  3730. tvis.item.pszText = (LPTSTR) lpszItem;
  3731. tvis.item.iImage = nImage;
  3732. tvis.item.iSelectedImage = nSelectedImage;
  3733. tvis.item.state = nState;
  3734. tvis.item.stateMask = nStateMask;
  3735. tvis.item.lParam = lParam;
  3736. return (HTREEITEM)::SendMessage(m_hWnd, TVM_INSERTITEM, 0, (LPARAM)&tvis);
  3737. }
  3738. BOOL DeleteItem(HTREEITEM hItem)
  3739. {
  3740. ATLASSERT(::IsWindow(m_hWnd));
  3741. return (BOOL)::SendMessage(m_hWnd, TVM_DELETEITEM, 0, (LPARAM)hItem);
  3742. }
  3743. BOOL DeleteAllItems()
  3744. {
  3745. ATLASSERT(::IsWindow(m_hWnd));
  3746. return (BOOL)::SendMessage(m_hWnd, TVM_DELETEITEM, 0, (LPARAM)TVI_ROOT);
  3747. }
  3748. BOOL Expand(HTREEITEM hItem, UINT nCode = TVE_EXPAND)
  3749. {
  3750. ATLASSERT(::IsWindow(m_hWnd));
  3751. return (BOOL)::SendMessage(m_hWnd, TVM_EXPAND, nCode, (LPARAM)hItem);
  3752. }
  3753. HTREEITEM GetNextItem(HTREEITEM hItem, UINT nCode) const
  3754. {
  3755. ATLASSERT(::IsWindow(m_hWnd));
  3756. return (HTREEITEM)::SendMessage(m_hWnd, TVM_GETNEXTITEM, nCode, (LPARAM)hItem);
  3757. }
  3758. HTREEITEM GetChildItem(HTREEITEM hItem) const
  3759. {
  3760. ATLASSERT(::IsWindow(m_hWnd));
  3761. return (HTREEITEM)::SendMessage(m_hWnd, TVM_GETNEXTITEM, TVGN_CHILD, (LPARAM)hItem);
  3762. }
  3763. HTREEITEM GetNextSiblingItem(HTREEITEM hItem) const
  3764. {
  3765. ATLASSERT(::IsWindow(m_hWnd));
  3766. return (HTREEITEM)::SendMessage(m_hWnd, TVM_GETNEXTITEM, TVGN_NEXT, (LPARAM)hItem);
  3767. }
  3768. HTREEITEM GetPrevSiblingItem(HTREEITEM hItem) const
  3769. {
  3770. ATLASSERT(::IsWindow(m_hWnd));
  3771. return (HTREEITEM)::SendMessage(m_hWnd, TVM_GETNEXTITEM, TVGN_PREVIOUS, (LPARAM)hItem);
  3772. }
  3773. HTREEITEM GetParentItem(HTREEITEM hItem) const
  3774. {
  3775. ATLASSERT(::IsWindow(m_hWnd));
  3776. return (HTREEITEM)::SendMessage(m_hWnd, TVM_GETNEXTITEM, TVGN_PARENT, (LPARAM)hItem);
  3777. }
  3778. HTREEITEM GetFirstVisibleItem() const
  3779. {
  3780. ATLASSERT(::IsWindow(m_hWnd));
  3781. return (HTREEITEM)::SendMessage(m_hWnd, TVM_GETNEXTITEM, TVGN_FIRSTVISIBLE, 0L);
  3782. }
  3783. HTREEITEM GetNextVisibleItem(HTREEITEM hItem) const
  3784. {
  3785. ATLASSERT(::IsWindow(m_hWnd));
  3786. return (HTREEITEM)::SendMessage(m_hWnd, TVM_GETNEXTITEM, TVGN_NEXTVISIBLE, (LPARAM)hItem);
  3787. }
  3788. HTREEITEM GetPrevVisibleItem(HTREEITEM hItem) const
  3789. {
  3790. ATLASSERT(::IsWindow(m_hWnd));
  3791. return (HTREEITEM)::SendMessage(m_hWnd, TVM_GETNEXTITEM, TVGN_PREVIOUSVISIBLE, (LPARAM)hItem);
  3792. }
  3793. HTREEITEM GetSelectedItem() const
  3794. {
  3795. ATLASSERT(::IsWindow(m_hWnd));
  3796. return (HTREEITEM)::SendMessage(m_hWnd, TVM_GETNEXTITEM, TVGN_CARET, 0L);
  3797. }
  3798. HTREEITEM GetDropHilightItem() const
  3799. {
  3800. ATLASSERT(::IsWindow(m_hWnd));
  3801. return (HTREEITEM)::SendMessage(m_hWnd, TVM_GETNEXTITEM, TVGN_DROPHILITE, 0L);
  3802. }
  3803. HTREEITEM GetRootItem() const
  3804. {
  3805. ATLASSERT(::IsWindow(m_hWnd));
  3806. return (HTREEITEM)::SendMessage(m_hWnd, TVM_GETNEXTITEM, TVGN_ROOT, 0L);
  3807. }
  3808. #if !defined(_WIN32_WCE) && (_WIN32_IE >= 0x0400)
  3809. HTREEITEM GetLastVisibleItem() const
  3810. {
  3811. ATLASSERT(::IsWindow(m_hWnd));
  3812. return (HTREEITEM)::SendMessage(m_hWnd, TVM_GETNEXTITEM, TVGN_LASTVISIBLE, 0L);
  3813. }
  3814. #endif // !defined(_WIN32_WCE) && (_WIN32_IE >= 0x0400)
  3815. #if (_WIN32_IE >= 0x0600)
  3816. HTREEITEM GetNextSelectedItem() const
  3817. {
  3818. ATLASSERT(::IsWindow(m_hWnd));
  3819. return (HTREEITEM)::SendMessage(m_hWnd, TVM_GETNEXTITEM, TVGN_NEXTSELECTED, 0L);
  3820. }
  3821. #endif // (_WIN32_IE >= 0x0600)
  3822. BOOL Select(HTREEITEM hItem, UINT nCode)
  3823. {
  3824. ATLASSERT(::IsWindow(m_hWnd));
  3825. return (BOOL)::SendMessage(m_hWnd, TVM_SELECTITEM, nCode, (LPARAM)hItem);
  3826. }
  3827. BOOL SelectItem(HTREEITEM hItem)
  3828. {
  3829. ATLASSERT(::IsWindow(m_hWnd));
  3830. return (BOOL)::SendMessage(m_hWnd, TVM_SELECTITEM, TVGN_CARET, (LPARAM)hItem);
  3831. }
  3832. BOOL SelectDropTarget(HTREEITEM hItem)
  3833. {
  3834. ATLASSERT(::IsWindow(m_hWnd));
  3835. return (BOOL)::SendMessage(m_hWnd, TVM_SELECTITEM, TVGN_DROPHILITE, (LPARAM)hItem);
  3836. }
  3837. BOOL SelectSetFirstVisible(HTREEITEM hItem)
  3838. {
  3839. ATLASSERT(::IsWindow(m_hWnd));
  3840. return (BOOL)::SendMessage(m_hWnd, TVM_SELECTITEM, TVGN_FIRSTVISIBLE, (LPARAM)hItem);
  3841. }
  3842. CEdit EditLabel(HTREEITEM hItem)
  3843. {
  3844. ATLASSERT(::IsWindow(m_hWnd));
  3845. return CEdit((HWND)::SendMessage(m_hWnd, TVM_EDITLABEL, 0, (LPARAM)hItem));
  3846. }
  3847. BOOL EndEditLabelNow(BOOL bCancel)
  3848. {
  3849. ATLASSERT(::IsWindow(m_hWnd));
  3850. return (BOOL)::SendMessage(m_hWnd, TVM_ENDEDITLABELNOW, bCancel, 0L);
  3851. }
  3852. HTREEITEM HitTest(TVHITTESTINFO* pHitTestInfo) const
  3853. {
  3854. ATLASSERT(::IsWindow(m_hWnd));
  3855. return (HTREEITEM)::SendMessage(m_hWnd, TVM_HITTEST, 0, (LPARAM)pHitTestInfo);
  3856. }
  3857. HTREEITEM HitTest(POINT pt, UINT* pFlags) const
  3858. {
  3859. ATLASSERT(::IsWindow(m_hWnd));
  3860. TVHITTESTINFO hti = { 0 };
  3861. hti.pt = pt;
  3862. HTREEITEM hTreeItem = (HTREEITEM)::SendMessage(m_hWnd, TVM_HITTEST, 0, (LPARAM)&hti);
  3863. if (pFlags != NULL)
  3864. *pFlags = hti.flags;
  3865. return hTreeItem;
  3866. }
  3867. BOOL SortChildren(HTREEITEM hItem, BOOL bRecurse = FALSE)
  3868. {
  3869. ATLASSERT(::IsWindow(m_hWnd));
  3870. return (BOOL)::SendMessage(m_hWnd, TVM_SORTCHILDREN, (WPARAM)bRecurse, (LPARAM)hItem);
  3871. }
  3872. BOOL EnsureVisible(HTREEITEM hItem)
  3873. {
  3874. ATLASSERT(::IsWindow(m_hWnd));
  3875. return (BOOL)::SendMessage(m_hWnd, TVM_ENSUREVISIBLE, 0, (LPARAM)hItem);
  3876. }
  3877. BOOL SortChildrenCB(LPTVSORTCB pSort, BOOL bRecurse = FALSE)
  3878. {
  3879. ATLASSERT(::IsWindow(m_hWnd));
  3880. return (BOOL)::SendMessage(m_hWnd, TVM_SORTCHILDRENCB, (WPARAM)bRecurse, (LPARAM)pSort);
  3881. }
  3882. CImageList RemoveImageList(int nImageList)
  3883. {
  3884. ATLASSERT(::IsWindow(m_hWnd));
  3885. return CImageList((HIMAGELIST)::SendMessage(m_hWnd, TVM_SETIMAGELIST, (WPARAM)nImageList, NULL));
  3886. }
  3887. CImageList CreateDragImage(HTREEITEM hItem)
  3888. {
  3889. ATLASSERT(::IsWindow(m_hWnd));
  3890. return CImageList((HIMAGELIST)::SendMessage(m_hWnd, TVM_CREATEDRAGIMAGE, 0, (LPARAM)hItem));
  3891. }
  3892. #if (_WIN32_IE >= 0x0400) && !defined(_WIN32_WCE)
  3893. BOOL SetInsertMark(HTREEITEM hTreeItem, BOOL bAfter)
  3894. {
  3895. ATLASSERT(::IsWindow(m_hWnd));
  3896. return (BOOL)::SendMessage(m_hWnd, TVM_SETINSERTMARK, bAfter, (LPARAM)hTreeItem);
  3897. }
  3898. BOOL RemoveInsertMark()
  3899. {
  3900. ATLASSERT(::IsWindow(m_hWnd));
  3901. return (BOOL)::SendMessage(m_hWnd, TVM_SETINSERTMARK, 0, 0L);
  3902. }
  3903. #endif // (_WIN32_IE >= 0x0400) && !defined(_WIN32_WCE)
  3904. #if (_WIN32_WINNT >= 0x0501)
  3905. HTREEITEM MapAccIDToHTREEITEM(UINT uID) const
  3906. {
  3907. ATLASSERT(::IsWindow(m_hWnd));
  3908. return (HTREEITEM)::SendMessage(m_hWnd, TVM_MAPACCIDTOHTREEITEM, uID, 0L);
  3909. }
  3910. UINT MapHTREEITEMToAccID(HTREEITEM hTreeItem) const
  3911. {
  3912. ATLASSERT(::IsWindow(m_hWnd));
  3913. return (UINT)::SendMessage(m_hWnd, TVM_MAPHTREEITEMTOACCID, (WPARAM)hTreeItem, 0L);
  3914. }
  3915. #endif // (_WIN32_WINNT >= 0x0501)
  3916. #if (_WIN32_WINNT >= 0x0600)
  3917. void ShowInfoTip(HTREEITEM hItem)
  3918. {
  3919. ATLASSERT(::IsWindow(m_hWnd));
  3920. ::SendMessage(m_hWnd, TVM_SHOWINFOTIP, 0, (LPARAM)hItem);
  3921. }
  3922. #endif // (_WIN32_WINNT >= 0x0600)
  3923. };
  3924. typedef CTreeViewCtrlT<ATL::CWindow> CTreeViewCtrl;
  3925. ///////////////////////////////////////////////////////////////////////////////
  3926. // CTreeViewCtrlEx
  3927. // forward declaration
  3928. template <class TBase> class CTreeViewCtrlExT;
  3929. // Note: TBase here is for CTreeViewCtrlExT, and not for CTreeItemT itself
  3930. template <class TBase>
  3931. class CTreeItemT
  3932. {
  3933. public:
  3934. HTREEITEM m_hTreeItem;
  3935. CTreeViewCtrlExT<TBase>* m_pTreeView;
  3936. // Construction
  3937. CTreeItemT(HTREEITEM hTreeItem = NULL, CTreeViewCtrlExT<TBase>* pTreeView = NULL) : m_hTreeItem(hTreeItem), m_pTreeView(pTreeView)
  3938. { }
  3939. CTreeItemT(const CTreeItemT<TBase>& posSrc)
  3940. {
  3941. *this = posSrc;
  3942. }
  3943. operator HTREEITEM() { return m_hTreeItem; }
  3944. CTreeItemT<TBase>& operator =(const CTreeItemT<TBase>& itemSrc)
  3945. {
  3946. m_hTreeItem = itemSrc.m_hTreeItem;
  3947. m_pTreeView = itemSrc.m_pTreeView;
  3948. return *this;
  3949. }
  3950. // Attributes
  3951. CTreeViewCtrlExT<TBase>* GetTreeView() const { return m_pTreeView; }
  3952. BOOL operator !() const { return m_hTreeItem == NULL; }
  3953. BOOL IsNull() const { return m_hTreeItem == NULL; }
  3954. BOOL GetRect(LPRECT lpRect, BOOL bTextOnly) const;
  3955. BOOL GetText(LPTSTR lpstrText, int nLen) const;
  3956. #ifndef _ATL_NO_COM
  3957. BOOL GetText(BSTR& bstrText) const;
  3958. #endif // !_ATL_NO_COM
  3959. #if defined(_WTL_USE_CSTRING) || defined(__ATLSTR_H__)
  3960. BOOL GetText(_CSTRING_NS::CString& strText) const;
  3961. #endif // defined(_WTL_USE_CSTRING) || defined(__ATLSTR_H__)
  3962. BOOL SetText(LPCTSTR lpszItem);
  3963. BOOL GetImage(int& nImage, int& nSelectedImage) const;
  3964. BOOL SetImage(int nImage, int nSelectedImage);
  3965. UINT GetState(UINT nStateMask) const;
  3966. BOOL SetState(UINT nState, UINT nStateMask);
  3967. DWORD_PTR GetData() const;
  3968. BOOL SetData(DWORD_PTR dwData);
  3969. BOOL SetItem(UINT nMask, LPCTSTR lpszItem, int nImage, int nSelectedImage, UINT nState, UINT nStateMask, LPARAM lParam);
  3970. // Operations
  3971. CTreeItemT<TBase> InsertAfter(LPCTSTR lpstrItem, HTREEITEM hItemAfter, int nImageIndex)
  3972. {
  3973. return _Insert(lpstrItem, nImageIndex, hItemAfter);
  3974. }
  3975. CTreeItemT<TBase> AddHead(LPCTSTR lpstrItem, int nImageIndex)
  3976. {
  3977. return _Insert(lpstrItem, nImageIndex, TVI_FIRST);
  3978. }
  3979. CTreeItemT<TBase> AddTail(LPCTSTR lpstrItem, int nImageIndex)
  3980. {
  3981. return _Insert(lpstrItem, nImageIndex, TVI_LAST);
  3982. }
  3983. CTreeItemT<TBase> GetChild() const;
  3984. CTreeItemT<TBase> GetNext(UINT nCode) const;
  3985. CTreeItemT<TBase> GetNextSibling() const;
  3986. CTreeItemT<TBase> GetPrevSibling() const;
  3987. CTreeItemT<TBase> GetParent() const;
  3988. CTreeItemT<TBase> GetFirstVisible() const;
  3989. CTreeItemT<TBase> GetNextVisible() const;
  3990. CTreeItemT<TBase> GetPrevVisible() const;
  3991. CTreeItemT<TBase> GetSelected() const;
  3992. CTreeItemT<TBase> GetDropHilight() const;
  3993. CTreeItemT<TBase> GetRoot() const;
  3994. #if !defined(_WIN32_WCE) && (_WIN32_IE >= 0x0400)
  3995. CTreeItemT<TBase> GetLastVisible() const;
  3996. #endif // !defined(_WIN32_WCE) && (_WIN32_IE >= 0x0400)
  3997. #if (_WIN32_IE >= 0x0600)
  3998. CTreeItemT<TBase> GetNextSelected() const;
  3999. #endif // (_WIN32_IE >= 0x0600)
  4000. BOOL HasChildren() const;
  4001. BOOL Delete();
  4002. BOOL Expand(UINT nCode = TVE_EXPAND);
  4003. BOOL Select(UINT nCode);
  4004. BOOL Select();
  4005. BOOL SelectDropTarget();
  4006. BOOL SelectSetFirstVisible();
  4007. HWND EditLabel();
  4008. HIMAGELIST CreateDragImage();
  4009. BOOL SortChildren(BOOL bRecurse = FALSE);
  4010. BOOL EnsureVisible();
  4011. CTreeItemT<TBase> _Insert(LPCTSTR lpstrItem, int nImageIndex, HTREEITEM hItemAfter);
  4012. int GetImageIndex() const;
  4013. #if (_WIN32_IE >= 0x0400) && !defined(_WIN32_WCE)
  4014. BOOL SetInsertMark(BOOL bAfter);
  4015. #endif // (_WIN32_IE >= 0x0400) && !defined(_WIN32_WCE)
  4016. #if (_WIN32_WINNT >= 0x0501)
  4017. UINT MapHTREEITEMToAccID() const;
  4018. #endif // (_WIN32_WINNT >= 0x0501)
  4019. #if (_WIN32_WINNT >= 0x0600)
  4020. void ShowInfoTip();
  4021. BOOL GetPartRect(TVITEMPART partID, LPRECT lpRect) const;
  4022. #endif // (_WIN32_WINNT >= 0x0600)
  4023. };
  4024. typedef CTreeItemT<ATL::CWindow> CTreeItem;
  4025. template <class TBase>
  4026. class CTreeViewCtrlExT : public CTreeViewCtrlT< TBase >
  4027. {
  4028. public:
  4029. // Constructors
  4030. CTreeViewCtrlExT(HWND hWnd = NULL) : CTreeViewCtrlT< TBase >(hWnd)
  4031. { }
  4032. CTreeViewCtrlExT< TBase >& operator =(HWND hWnd)
  4033. {
  4034. m_hWnd = hWnd;
  4035. return *this;
  4036. }
  4037. // Operations (overides that return CTreeItem)
  4038. CTreeItemT<TBase> InsertItem(LPTVINSERTSTRUCT lpInsertStruct)
  4039. {
  4040. ATLASSERT(::IsWindow(m_hWnd));
  4041. HTREEITEM hTreeItem = (HTREEITEM)::SendMessage(m_hWnd, TVM_INSERTITEM, 0, (LPARAM)lpInsertStruct);
  4042. return CTreeItemT<TBase>(hTreeItem, this);
  4043. }
  4044. CTreeItemT<TBase> InsertItem(LPCTSTR lpszItem, int nImage,
  4045. int nSelectedImage, HTREEITEM hParent, HTREEITEM hInsertAfter)
  4046. {
  4047. ATLASSERT(::IsWindow(m_hWnd));
  4048. return InsertItem(TVIF_TEXT | TVIF_IMAGE | TVIF_SELECTEDIMAGE, lpszItem, nImage, nSelectedImage, 0, 0, 0, hParent, hInsertAfter);
  4049. }
  4050. CTreeItemT<TBase> InsertItem(LPCTSTR lpszItem, HTREEITEM hParent, HTREEITEM hInsertAfter)
  4051. {
  4052. ATLASSERT(::IsWindow(m_hWnd));
  4053. return InsertItem(TVIF_TEXT, lpszItem, 0, 0, 0, 0, 0, hParent, hInsertAfter);
  4054. }
  4055. CTreeItemT<TBase> GetNextItem(HTREEITEM hItem, UINT nCode) const
  4056. {
  4057. ATLASSERT(::IsWindow(m_hWnd));
  4058. HTREEITEM hTreeItem = (HTREEITEM)::SendMessage(m_hWnd, TVM_GETNEXTITEM, nCode, (LPARAM)hItem);
  4059. return CTreeItemT<TBase>(hTreeItem, (CTreeViewCtrlExT<TBase>*)this);
  4060. }
  4061. CTreeItemT<TBase> GetChildItem(HTREEITEM hItem) const
  4062. {
  4063. ATLASSERT(::IsWindow(m_hWnd));
  4064. HTREEITEM hTreeItem = (HTREEITEM)::SendMessage(m_hWnd, TVM_GETNEXTITEM, TVGN_CHILD, (LPARAM)hItem);
  4065. return CTreeItemT<TBase>(hTreeItem, (CTreeViewCtrlExT<TBase>*)this);
  4066. }
  4067. CTreeItemT<TBase> GetNextSiblingItem(HTREEITEM hItem) const
  4068. {
  4069. ATLASSERT(::IsWindow(m_hWnd));
  4070. HTREEITEM hTreeItem = (HTREEITEM)::SendMessage(m_hWnd, TVM_GETNEXTITEM, TVGN_NEXT, (LPARAM)hItem);
  4071. return CTreeItemT<TBase>(hTreeItem, (CTreeViewCtrlExT<TBase>*)this);
  4072. }
  4073. CTreeItemT<TBase> GetPrevSiblingItem(HTREEITEM hItem) const
  4074. {
  4075. ATLASSERT(::IsWindow(m_hWnd));
  4076. HTREEITEM hTreeItem = (HTREEITEM)::SendMessage(m_hWnd, TVM_GETNEXTITEM, TVGN_PREVIOUS, (LPARAM)hItem);
  4077. return CTreeItemT<TBase>(hTreeItem, (CTreeViewCtrlExT<TBase>*)this);
  4078. }
  4079. CTreeItemT<TBase> GetParentItem(HTREEITEM hItem) const
  4080. {
  4081. ATLASSERT(::IsWindow(m_hWnd));
  4082. HTREEITEM hTreeItem = (HTREEITEM)::SendMessage(m_hWnd, TVM_GETNEXTITEM, TVGN_PARENT, (LPARAM)hItem);
  4083. return CTreeItemT<TBase>(hTreeItem, (CTreeViewCtrlExT<TBase>*)this);
  4084. }
  4085. CTreeItemT<TBase> GetFirstVisibleItem() const
  4086. {
  4087. ATLASSERT(::IsWindow(m_hWnd));
  4088. HTREEITEM hTreeItem = (HTREEITEM)::SendMessage(m_hWnd, TVM_GETNEXTITEM, TVGN_FIRSTVISIBLE, 0L);
  4089. return CTreeItemT<TBase>(hTreeItem, (CTreeViewCtrlExT<TBase>*)this);
  4090. }
  4091. CTreeItemT<TBase> GetNextVisibleItem(HTREEITEM hItem) const
  4092. {
  4093. ATLASSERT(::IsWindow(m_hWnd));
  4094. HTREEITEM hTreeItem = (HTREEITEM)::SendMessage(m_hWnd, TVM_GETNEXTITEM, TVGN_NEXTVISIBLE, (LPARAM)hItem);
  4095. return CTreeItemT<TBase>(hTreeItem, (CTreeViewCtrlExT<TBase>*)this);
  4096. }
  4097. CTreeItemT<TBase> GetPrevVisibleItem(HTREEITEM hItem) const
  4098. {
  4099. ATLASSERT(::IsWindow(m_hWnd));
  4100. HTREEITEM hTreeItem = (HTREEITEM)::SendMessage(m_hWnd, TVM_GETNEXTITEM, TVGN_PREVIOUSVISIBLE, (LPARAM)hItem);
  4101. return CTreeItemT<TBase>(hTreeItem, (CTreeViewCtrlExT<TBase>*)this);
  4102. }
  4103. CTreeItemT<TBase> GetSelectedItem() const
  4104. {
  4105. ATLASSERT(::IsWindow(m_hWnd));
  4106. HTREEITEM hTreeItem = (HTREEITEM)::SendMessage(m_hWnd, TVM_GETNEXTITEM, TVGN_CARET, 0L);
  4107. return CTreeItemT<TBase>(hTreeItem, (CTreeViewCtrlExT<TBase>*)this);
  4108. }
  4109. CTreeItemT<TBase> GetDropHilightItem() const
  4110. {
  4111. ATLASSERT(::IsWindow(m_hWnd));
  4112. HTREEITEM hTreeItem = (HTREEITEM)::SendMessage(m_hWnd, TVM_GETNEXTITEM, TVGN_DROPHILITE, 0L);
  4113. return CTreeItemT<TBase>(hTreeItem, (CTreeViewCtrlExT<TBase>*)this);
  4114. }
  4115. CTreeItemT<TBase> GetRootItem() const
  4116. {
  4117. ATLASSERT(::IsWindow(m_hWnd));
  4118. HTREEITEM hTreeItem = (HTREEITEM)::SendMessage(m_hWnd, TVM_GETNEXTITEM, TVGN_ROOT, 0L);
  4119. return CTreeItemT<TBase>(hTreeItem, (CTreeViewCtrlExT<TBase>*)this);
  4120. }
  4121. #if !defined(_WIN32_WCE) && (_WIN32_IE >= 0x0400)
  4122. CTreeItemT<TBase> GetLastVisibleItem() const
  4123. {
  4124. ATLASSERT(::IsWindow(m_hWnd));
  4125. HTREEITEM hTreeItem = (HTREEITEM)::SendMessage(m_hWnd, TVM_GETNEXTITEM, TVGN_LASTVISIBLE, 0L);
  4126. return CTreeItemT<TBase>(hTreeItem, (CTreeViewCtrlExT<TBase>*)this);
  4127. }
  4128. #endif // !defined(_WIN32_WCE) && (_WIN32_IE >= 0x0400)
  4129. #if (_WIN32_IE >= 0x0600)
  4130. CTreeItemT<TBase> GetNextSelectedItem() const
  4131. {
  4132. ATLASSERT(::IsWindow(m_hWnd));
  4133. HTREEITEM hTreeItem = (HTREEITEM)::SendMessage(m_hWnd, TVM_GETNEXTITEM, TVGN_NEXTSELECTED, 0L);
  4134. return CTreeItemT<TBase>(hTreeItem, (CTreeViewCtrlExT<TBase>*)this);
  4135. }
  4136. #endif // (_WIN32_IE >= 0x0600)
  4137. CTreeItemT<TBase> HitTest(TVHITTESTINFO* pHitTestInfo) const
  4138. {
  4139. ATLASSERT(::IsWindow(m_hWnd));
  4140. HTREEITEM hTreeItem = (HTREEITEM)::SendMessage(m_hWnd, TVM_HITTEST, 0, (LPARAM)pHitTestInfo);
  4141. return CTreeItemT<TBase>(hTreeItem, (CTreeViewCtrlExT<TBase>*)this);
  4142. }
  4143. CTreeItemT<TBase> InsertItem(UINT nMask, LPCTSTR lpszItem, int nImage,
  4144. int nSelectedImage, UINT nState, UINT nStateMask, LPARAM lParam,
  4145. HTREEITEM hParent, HTREEITEM hInsertAfter)
  4146. {
  4147. ATLASSERT(::IsWindow(m_hWnd));
  4148. TVINSERTSTRUCT tvis = { 0 };
  4149. tvis.hParent = hParent;
  4150. tvis.hInsertAfter = hInsertAfter;
  4151. tvis.item.mask = nMask;
  4152. tvis.item.pszText = (LPTSTR) lpszItem;
  4153. tvis.item.iImage = nImage;
  4154. tvis.item.iSelectedImage = nSelectedImage;
  4155. tvis.item.state = nState;
  4156. tvis.item.stateMask = nStateMask;
  4157. tvis.item.lParam = lParam;
  4158. HTREEITEM hTreeItem = (HTREEITEM)::SendMessage(m_hWnd, TVM_INSERTITEM, 0, (LPARAM)&tvis);
  4159. return CTreeItemT<TBase>(hTreeItem, this);
  4160. }
  4161. CTreeItemT<TBase> HitTest(POINT pt, UINT* pFlags) const
  4162. {
  4163. ATLASSERT(::IsWindow(m_hWnd));
  4164. TVHITTESTINFO hti = { 0 };
  4165. hti.pt = pt;
  4166. HTREEITEM hTreeItem = (HTREEITEM)::SendMessage(m_hWnd, TVM_HITTEST, 0, (LPARAM)&hti);
  4167. if (pFlags != NULL)
  4168. *pFlags = hti.flags;
  4169. return CTreeItemT<TBase>(hTreeItem, (CTreeViewCtrlExT<TBase>*)this);
  4170. }
  4171. #if (_WIN32_WINNT >= 0x0501)
  4172. CTreeItemT<TBase> MapAccIDToHTREEITEM(UINT uID) const
  4173. {
  4174. ATLASSERT(::IsWindow(m_hWnd));
  4175. HTREEITEM hTreeItem = (HTREEITEM)::SendMessage(m_hWnd, TVM_MAPACCIDTOHTREEITEM, uID, 0L);
  4176. return CTreeItemT<TBase>(hTreeItem, (CTreeViewCtrlExT<TBase>*)this);
  4177. }
  4178. #endif // (_WIN32_WINNT >= 0x0501)
  4179. };
  4180. typedef CTreeViewCtrlExT<ATL::CWindow> CTreeViewCtrlEx;
  4181. // CTreeItem inline methods
  4182. template <class TBase>
  4183. inline BOOL CTreeItemT<TBase>::GetRect(LPRECT lpRect, BOOL bTextOnly) const
  4184. {
  4185. ATLASSERT(m_pTreeView != NULL);
  4186. return m_pTreeView->GetItemRect(m_hTreeItem,lpRect,bTextOnly);
  4187. }
  4188. template <class TBase>
  4189. inline CTreeItemT<TBase> CTreeItemT<TBase>::GetNext(UINT nCode) const
  4190. {
  4191. ATLASSERT(m_pTreeView != NULL);
  4192. return m_pTreeView->GetNextItem(m_hTreeItem,nCode);
  4193. }
  4194. template <class TBase>
  4195. inline CTreeItemT<TBase> CTreeItemT<TBase>::GetChild() const
  4196. {
  4197. ATLASSERT(m_pTreeView != NULL);
  4198. return m_pTreeView->GetChildItem(m_hTreeItem);
  4199. }
  4200. template <class TBase>
  4201. inline CTreeItemT<TBase> CTreeItemT<TBase>::GetNextSibling() const
  4202. {
  4203. ATLASSERT(m_pTreeView != NULL);
  4204. return m_pTreeView->GetNextSiblingItem(m_hTreeItem);
  4205. }
  4206. template <class TBase>
  4207. inline CTreeItemT<TBase> CTreeItemT<TBase>::GetPrevSibling() const
  4208. {
  4209. ATLASSERT(m_pTreeView != NULL);
  4210. return m_pTreeView->GetPrevSiblingItem(m_hTreeItem);
  4211. }
  4212. template <class TBase>
  4213. inline CTreeItemT<TBase> CTreeItemT<TBase>::GetParent() const
  4214. {
  4215. ATLASSERT(m_pTreeView != NULL);
  4216. return m_pTreeView->GetParentItem(m_hTreeItem);
  4217. }
  4218. template <class TBase>
  4219. inline CTreeItemT<TBase> CTreeItemT<TBase>::GetFirstVisible() const
  4220. {
  4221. ATLASSERT(m_pTreeView != NULL);
  4222. return m_pTreeView->GetFirstVisibleItem();
  4223. }
  4224. template <class TBase>
  4225. inline CTreeItemT<TBase> CTreeItemT<TBase>::GetNextVisible() const
  4226. {
  4227. ATLASSERT(m_pTreeView != NULL);
  4228. return m_pTreeView->GetNextVisibleItem(m_hTreeItem);
  4229. }
  4230. template <class TBase>
  4231. inline CTreeItemT<TBase> CTreeItemT<TBase>::GetPrevVisible() const
  4232. {
  4233. ATLASSERT(m_pTreeView != NULL);
  4234. return m_pTreeView->GetPrevVisibleItem(m_hTreeItem);
  4235. }
  4236. template <class TBase>
  4237. inline CTreeItemT<TBase> CTreeItemT<TBase>::GetSelected() const
  4238. {
  4239. ATLASSERT(m_pTreeView != NULL);
  4240. return m_pTreeView->GetSelectedItem();
  4241. }
  4242. template <class TBase>
  4243. inline CTreeItemT<TBase> CTreeItemT<TBase>::GetDropHilight() const
  4244. {
  4245. ATLASSERT(m_pTreeView != NULL);
  4246. return m_pTreeView->GetDropHilightItem();
  4247. }
  4248. template <class TBase>
  4249. inline CTreeItemT<TBase> CTreeItemT<TBase>::GetRoot() const
  4250. {
  4251. ATLASSERT(m_pTreeView != NULL);
  4252. return m_pTreeView->GetRootItem();
  4253. }
  4254. #if !defined(_WIN32_WCE) && (_WIN32_IE >= 0x0400)
  4255. template <class TBase>
  4256. inline CTreeItemT<TBase> CTreeItemT<TBase>::GetLastVisible() const
  4257. {
  4258. ATLASSERT(m_pTreeView != NULL);
  4259. return m_pTreeView->GetLastVisibleItem();
  4260. }
  4261. #endif // !defined(_WIN32_WCE) && (_WIN32_IE >= 0x0400)
  4262. #if (_WIN32_IE >= 0x0600)
  4263. template <class TBase>
  4264. inline CTreeItemT<TBase> CTreeItemT<TBase>::GetNextSelected() const
  4265. {
  4266. ATLASSERT(m_pTreeView != NULL);
  4267. return m_pTreeView->GetNextSelectedItem();
  4268. }
  4269. #endif // (_WIN32_IE >= 0x0600)
  4270. template <class TBase>
  4271. inline BOOL CTreeItemT<TBase>::GetText(LPTSTR lpstrText, int nLen) const
  4272. {
  4273. ATLASSERT(m_pTreeView != NULL);
  4274. return m_pTreeView->GetItemText(m_hTreeItem, lpstrText, nLen);
  4275. }
  4276. #ifndef _ATL_NO_COM
  4277. #ifdef _OLEAUTO_H_
  4278. template <class TBase>
  4279. inline BOOL CTreeItemT<TBase>::GetText(BSTR& bstrText) const
  4280. {
  4281. ATLASSERT(m_pTreeView != NULL);
  4282. return m_pTreeView->GetItemText(m_hTreeItem, bstrText);
  4283. }
  4284. #endif // _OLEAUTO_H_
  4285. #endif // !_ATL_NO_COM
  4286. #if defined(_WTL_USE_CSTRING) || defined(__ATLSTR_H__)
  4287. template <class TBase>
  4288. inline BOOL CTreeItemT<TBase>::GetText(_CSTRING_NS::CString& strText) const
  4289. {
  4290. ATLASSERT(m_pTreeView != NULL);
  4291. return m_pTreeView->GetItemText(m_hTreeItem, strText);
  4292. }
  4293. #endif // defined(_WTL_USE_CSTRING) || defined(__ATLSTR_H__)
  4294. template <class TBase>
  4295. inline BOOL CTreeItemT<TBase>::GetImage(int& nImage, int& nSelectedImage) const
  4296. {
  4297. ATLASSERT(m_pTreeView != NULL);
  4298. return m_pTreeView->GetItemImage(m_hTreeItem,nImage,nSelectedImage);
  4299. }
  4300. template <class TBase>
  4301. inline UINT CTreeItemT<TBase>::GetState(UINT nStateMask) const
  4302. {
  4303. ATLASSERT(m_pTreeView != NULL);
  4304. return m_pTreeView->GetItemState(m_hTreeItem,nStateMask);
  4305. }
  4306. template <class TBase>
  4307. inline DWORD_PTR CTreeItemT<TBase>::GetData() const
  4308. {
  4309. ATLASSERT(m_pTreeView != NULL);
  4310. return m_pTreeView->GetItemData(m_hTreeItem);
  4311. }
  4312. template <class TBase>
  4313. inline BOOL CTreeItemT<TBase>::SetItem(UINT nMask, LPCTSTR lpszItem, int nImage,
  4314. int nSelectedImage, UINT nState, UINT nStateMask, LPARAM lParam)
  4315. {
  4316. ATLASSERT(m_pTreeView != NULL);
  4317. return m_pTreeView->SetItem(m_hTreeItem, nMask, lpszItem, nImage, nSelectedImage, nState, nStateMask, lParam);
  4318. }
  4319. template <class TBase>
  4320. inline BOOL CTreeItemT<TBase>::SetText(LPCTSTR lpszItem)
  4321. {
  4322. ATLASSERT(m_pTreeView != NULL);
  4323. return m_pTreeView->SetItemText(m_hTreeItem,lpszItem);
  4324. }
  4325. template <class TBase>
  4326. inline BOOL CTreeItemT<TBase>::SetImage(int nImage, int nSelectedImage)
  4327. {
  4328. ATLASSERT(m_pTreeView != NULL);
  4329. return m_pTreeView->SetItemImage(m_hTreeItem,nImage,nSelectedImage);
  4330. }
  4331. template <class TBase>
  4332. inline BOOL CTreeItemT<TBase>::SetState(UINT nState, UINT nStateMask)
  4333. {
  4334. ATLASSERT(m_pTreeView != NULL);
  4335. return m_pTreeView->SetItemState(m_hTreeItem,nState,nStateMask);
  4336. }
  4337. template <class TBase>
  4338. inline BOOL CTreeItemT<TBase>::SetData(DWORD_PTR dwData)
  4339. {
  4340. ATLASSERT(m_pTreeView != NULL);
  4341. return m_pTreeView->SetItemData(m_hTreeItem,dwData);
  4342. }
  4343. template <class TBase>
  4344. inline BOOL CTreeItemT<TBase>::HasChildren() const
  4345. {
  4346. ATLASSERT(m_pTreeView != NULL);
  4347. return m_pTreeView->ItemHasChildren(m_hTreeItem);
  4348. }
  4349. template <class TBase>
  4350. inline BOOL CTreeItemT<TBase>::Delete()
  4351. {
  4352. ATLASSERT(m_pTreeView != NULL);
  4353. return m_pTreeView->DeleteItem(m_hTreeItem);
  4354. }
  4355. template <class TBase>
  4356. inline BOOL CTreeItemT<TBase>::Expand(UINT nCode /*= TVE_EXPAND*/)
  4357. {
  4358. ATLASSERT(m_pTreeView != NULL);
  4359. return m_pTreeView->Expand(m_hTreeItem,nCode);
  4360. }
  4361. template <class TBase>
  4362. inline BOOL CTreeItemT<TBase>::Select(UINT nCode)
  4363. {
  4364. ATLASSERT(m_pTreeView != NULL);
  4365. return m_pTreeView->Select(m_hTreeItem,nCode);
  4366. }
  4367. template <class TBase>
  4368. inline BOOL CTreeItemT<TBase>::Select()
  4369. {
  4370. ATLASSERT(m_pTreeView != NULL);
  4371. return m_pTreeView->SelectItem(m_hTreeItem);
  4372. }
  4373. template <class TBase>
  4374. inline BOOL CTreeItemT<TBase>::SelectDropTarget()
  4375. {
  4376. ATLASSERT(m_pTreeView != NULL);
  4377. return m_pTreeView->SelectDropTarget(m_hTreeItem);
  4378. }
  4379. template <class TBase>
  4380. inline BOOL CTreeItemT<TBase>::SelectSetFirstVisible()
  4381. {
  4382. ATLASSERT(m_pTreeView != NULL);
  4383. return m_pTreeView->SelectSetFirstVisible(m_hTreeItem);
  4384. }
  4385. template <class TBase>
  4386. inline HWND CTreeItemT<TBase>::EditLabel()
  4387. {
  4388. ATLASSERT(m_pTreeView != NULL);
  4389. return m_pTreeView->EditLabel(m_hTreeItem);
  4390. }
  4391. template <class TBase>
  4392. inline HIMAGELIST CTreeItemT<TBase>::CreateDragImage()
  4393. {
  4394. ATLASSERT(m_pTreeView != NULL);
  4395. return m_pTreeView->CreateDragImage(m_hTreeItem);
  4396. }
  4397. template <class TBase>
  4398. inline BOOL CTreeItemT<TBase>::SortChildren(BOOL bRecurse /*= FALSE*/)
  4399. {
  4400. ATLASSERT(m_pTreeView != NULL);
  4401. return m_pTreeView->SortChildren(m_hTreeItem, bRecurse);
  4402. }
  4403. template <class TBase>
  4404. inline BOOL CTreeItemT<TBase>::EnsureVisible()
  4405. {
  4406. ATLASSERT(m_pTreeView != NULL);
  4407. return m_pTreeView->EnsureVisible(m_hTreeItem);
  4408. }
  4409. template <class TBase>
  4410. inline CTreeItemT<TBase> CTreeItemT<TBase>::_Insert(LPCTSTR lpstrItem, int nImageIndex, HTREEITEM hItemAfter)
  4411. {
  4412. ATLASSERT(m_pTreeView != NULL);
  4413. TVINSERTSTRUCT ins = { 0 };
  4414. ins.hParent = m_hTreeItem;
  4415. ins.hInsertAfter = hItemAfter;
  4416. ins.item.mask = TVIF_TEXT;
  4417. ins.item.pszText = (LPTSTR)lpstrItem;
  4418. if(nImageIndex != -1)
  4419. {
  4420. ins.item.mask |= TVIF_IMAGE | TVIF_SELECTEDIMAGE;
  4421. ins.item.iImage = nImageIndex;
  4422. ins.item.iSelectedImage = nImageIndex;
  4423. }
  4424. return CTreeItemT<TBase>(m_pTreeView->InsertItem(&ins), m_pTreeView);
  4425. }
  4426. template <class TBase>
  4427. inline int CTreeItemT<TBase>::GetImageIndex() const
  4428. {
  4429. ATLASSERT(m_pTreeView != NULL);
  4430. TVITEM item = { 0 };
  4431. item.mask = TVIF_HANDLE | TVIF_IMAGE;
  4432. item.hItem = m_hTreeItem;
  4433. m_pTreeView->GetItem(&item);
  4434. return item.iImage;
  4435. }
  4436. #if (_WIN32_IE >= 0x0400) && !defined(_WIN32_WCE)
  4437. template <class TBase>
  4438. inline BOOL CTreeItemT<TBase>::SetInsertMark(BOOL bAfter)
  4439. {
  4440. ATLASSERT(m_pTreeView != NULL);
  4441. return m_pTreeView->SetInsertMark(m_hTreeItem, bAfter);
  4442. }
  4443. #endif // (_WIN32_IE >= 0x0400) && !defined(_WIN32_WCE)
  4444. #if (_WIN32_WINNT >= 0x0501)
  4445. template <class TBase>
  4446. inline UINT CTreeItemT<TBase>::MapHTREEITEMToAccID() const
  4447. {
  4448. ATLASSERT(m_pTreeView != NULL);
  4449. return m_pTreeView->MapHTREEITEMToAccID(m_hTreeItem);
  4450. }
  4451. #endif // (_WIN32_WINNT >= 0x0501)
  4452. #if (_WIN32_WINNT >= 0x0600)
  4453. template <class TBase>
  4454. inline void CTreeItemT<TBase>::ShowInfoTip()
  4455. {
  4456. ATLASSERT(m_pTreeView != NULL);
  4457. m_pTreeView->ShowInfoTip(m_hTreeItem);
  4458. }
  4459. template <class TBase>
  4460. inline BOOL CTreeItemT<TBase>::GetPartRect(TVITEMPART partID, LPRECT lpRect) const
  4461. {
  4462. ATLASSERT(m_pTreeView != NULL);
  4463. return m_pTreeView->GetItemPartRect(m_hTreeItem, partID, lpRect);
  4464. }
  4465. #endif // (_WIN32_WINNT >= 0x0600)
  4466. ///////////////////////////////////////////////////////////////////////////////
  4467. // CToolBarCtrl
  4468. template <class TBase>
  4469. class CToolBarCtrlT : public TBase
  4470. {
  4471. public:
  4472. // Construction
  4473. CToolBarCtrlT(HWND hWnd = NULL) : TBase(hWnd)
  4474. { }
  4475. CToolBarCtrlT< TBase >& operator =(HWND hWnd)
  4476. {
  4477. m_hWnd = hWnd;
  4478. return *this;
  4479. }
  4480. HWND Create(HWND hWndParent, ATL::_U_RECT rect = NULL, LPCTSTR szWindowName = NULL,
  4481. DWORD dwStyle = 0, DWORD dwExStyle = 0,
  4482. ATL::_U_MENUorID MenuOrID = 0U, LPVOID lpCreateParam = NULL)
  4483. {
  4484. return TBase::Create(GetWndClassName(), hWndParent, rect.m_lpRect, szWindowName, dwStyle, dwExStyle, MenuOrID.m_hMenu, lpCreateParam);
  4485. }
  4486. // Attributes
  4487. static LPCTSTR GetWndClassName()
  4488. {
  4489. return TOOLBARCLASSNAME;
  4490. }
  4491. BOOL IsButtonEnabled(int nID) const
  4492. {
  4493. ATLASSERT(::IsWindow(m_hWnd));
  4494. return (BOOL)::SendMessage(m_hWnd, TB_ISBUTTONENABLED, nID, 0L);
  4495. }
  4496. BOOL IsButtonChecked(int nID) const
  4497. {
  4498. ATLASSERT(::IsWindow(m_hWnd));
  4499. return (BOOL)::SendMessage(m_hWnd, TB_ISBUTTONCHECKED, nID, 0L);
  4500. }
  4501. BOOL IsButtonPressed(int nID) const
  4502. {
  4503. ATLASSERT(::IsWindow(m_hWnd));
  4504. return (BOOL)::SendMessage(m_hWnd, TB_ISBUTTONPRESSED, nID, 0L);
  4505. }
  4506. BOOL IsButtonHidden(int nID) const
  4507. {
  4508. ATLASSERT(::IsWindow(m_hWnd));
  4509. return(BOOL) ::SendMessage(m_hWnd, TB_ISBUTTONHIDDEN, nID, 0L);
  4510. }
  4511. BOOL IsButtonIndeterminate(int nID) const
  4512. {
  4513. ATLASSERT(::IsWindow(m_hWnd));
  4514. return (BOOL)::SendMessage(m_hWnd, TB_ISBUTTONINDETERMINATE, nID, 0L);
  4515. }
  4516. int GetState(int nID) const
  4517. {
  4518. ATLASSERT(::IsWindow(m_hWnd));
  4519. return (int)::SendMessage(m_hWnd, TB_GETSTATE, nID, 0L);
  4520. }
  4521. BOOL SetState(int nID, UINT nState)
  4522. {
  4523. ATLASSERT(::IsWindow(m_hWnd));
  4524. return (BOOL)::SendMessage(m_hWnd, TB_SETSTATE, nID, MAKELPARAM(nState, 0));
  4525. }
  4526. BOOL GetButton(int nIndex, LPTBBUTTON lpButton) const
  4527. {
  4528. ATLASSERT(::IsWindow(m_hWnd));
  4529. return (BOOL)::SendMessage(m_hWnd, TB_GETBUTTON, nIndex, (LPARAM)lpButton);
  4530. }
  4531. int GetButtonCount() const
  4532. {
  4533. ATLASSERT(::IsWindow(m_hWnd));
  4534. return (int)::SendMessage(m_hWnd, TB_BUTTONCOUNT, 0, 0L);
  4535. }
  4536. BOOL GetItemRect(int nIndex, LPRECT lpRect) const
  4537. {
  4538. ATLASSERT(::IsWindow(m_hWnd));
  4539. return (BOOL)::SendMessage(m_hWnd, TB_GETITEMRECT, nIndex, (LPARAM)lpRect);
  4540. }
  4541. void SetButtonStructSize(int nSize = sizeof(TBBUTTON))
  4542. {
  4543. ATLASSERT(::IsWindow(m_hWnd));
  4544. ::SendMessage(m_hWnd, TB_BUTTONSTRUCTSIZE, nSize, 0L);
  4545. }
  4546. BOOL SetButtonSize(SIZE size)
  4547. {
  4548. ATLASSERT(::IsWindow(m_hWnd));
  4549. return (BOOL)::SendMessage(m_hWnd, TB_SETBUTTONSIZE, 0, MAKELPARAM(size.cx, size.cy));
  4550. }
  4551. BOOL SetButtonSize(int cx, int cy)
  4552. {
  4553. ATLASSERT(::IsWindow(m_hWnd));
  4554. return (BOOL)::SendMessage(m_hWnd, TB_SETBUTTONSIZE, 0, MAKELPARAM(cx, cy));
  4555. }
  4556. BOOL SetBitmapSize(SIZE size)
  4557. {
  4558. ATLASSERT(::IsWindow(m_hWnd));
  4559. return (BOOL)::SendMessage(m_hWnd, TB_SETBITMAPSIZE, 0, MAKELPARAM(size.cx, size.cy));
  4560. }
  4561. BOOL SetBitmapSize(int cx, int cy)
  4562. {
  4563. ATLASSERT(::IsWindow(m_hWnd));
  4564. return (BOOL)::SendMessage(m_hWnd, TB_SETBITMAPSIZE, 0, MAKELPARAM(cx, cy));
  4565. }
  4566. #ifndef _WIN32_WCE
  4567. CToolTipCtrl GetToolTips() const
  4568. {
  4569. ATLASSERT(::IsWindow(m_hWnd));
  4570. return CToolTipCtrl((HWND)::SendMessage(m_hWnd, TB_GETTOOLTIPS, 0, 0L));
  4571. }
  4572. void SetToolTips(HWND hWndToolTip)
  4573. {
  4574. ATLASSERT(::IsWindow(m_hWnd));
  4575. ::SendMessage(m_hWnd, TB_SETTOOLTIPS, (WPARAM)hWndToolTip, 0L);
  4576. }
  4577. #endif // !_WIN32_WCE
  4578. void SetNotifyWnd(HWND hWnd)
  4579. {
  4580. ATLASSERT(::IsWindow(m_hWnd));
  4581. ::SendMessage(m_hWnd, TB_SETPARENT, (WPARAM)hWnd, 0L);
  4582. }
  4583. int GetRows() const
  4584. {
  4585. ATLASSERT(::IsWindow(m_hWnd));
  4586. return (int)::SendMessage(m_hWnd, TB_GETROWS, 0, 0L);
  4587. }
  4588. void SetRows(int nRows, BOOL bLarger, LPRECT lpRect)
  4589. {
  4590. ATLASSERT(::IsWindow(m_hWnd));
  4591. ::SendMessage(m_hWnd, TB_SETROWS, MAKELPARAM(nRows, bLarger), (LPARAM)lpRect);
  4592. }
  4593. BOOL SetCmdID(int nIndex, UINT nID)
  4594. {
  4595. ATLASSERT(::IsWindow(m_hWnd));
  4596. return (BOOL)::SendMessage(m_hWnd, TB_SETCMDID, nIndex, nID);
  4597. }
  4598. DWORD GetBitmapFlags() const
  4599. {
  4600. ATLASSERT(::IsWindow(m_hWnd));
  4601. return (DWORD)::SendMessage(m_hWnd, TB_GETBITMAPFLAGS, 0, 0L);
  4602. }
  4603. int GetBitmap(int nID) const
  4604. {
  4605. ATLASSERT(::IsWindow(m_hWnd));
  4606. return (int)::SendMessage(m_hWnd, TB_GETBITMAP, nID, 0L);
  4607. }
  4608. int GetButtonText(int nID, LPTSTR lpstrText) const
  4609. {
  4610. ATLASSERT(::IsWindow(m_hWnd));
  4611. return (int)::SendMessage(m_hWnd, TB_GETBUTTONTEXT, nID, (LPARAM)lpstrText);
  4612. }
  4613. // nIndex - IE5 or higher only
  4614. CImageList GetImageList(int nIndex = 0) const
  4615. {
  4616. ATLASSERT(::IsWindow(m_hWnd));
  4617. return CImageList((HIMAGELIST)::SendMessage(m_hWnd, TB_GETIMAGELIST, nIndex, 0L));
  4618. }
  4619. // nIndex - IE5 or higher only
  4620. CImageList SetImageList(HIMAGELIST hImageList, int nIndex = 0)
  4621. {
  4622. ATLASSERT(::IsWindow(m_hWnd));
  4623. return CImageList((HIMAGELIST)::SendMessage(m_hWnd, TB_SETIMAGELIST, nIndex, (LPARAM)hImageList));
  4624. }
  4625. // nIndex - IE5 or higher only
  4626. CImageList GetDisabledImageList(int nIndex = 0) const
  4627. {
  4628. ATLASSERT(::IsWindow(m_hWnd));
  4629. return CImageList((HIMAGELIST)::SendMessage(m_hWnd, TB_GETDISABLEDIMAGELIST, nIndex, 0L));
  4630. }
  4631. // nIndex - IE5 or higher only
  4632. CImageList SetDisabledImageList(HIMAGELIST hImageList, int nIndex = 0)
  4633. {
  4634. ATLASSERT(::IsWindow(m_hWnd));
  4635. return CImageList((HIMAGELIST)::SendMessage(m_hWnd, TB_SETDISABLEDIMAGELIST, nIndex, (LPARAM)hImageList));
  4636. }
  4637. #ifndef _WIN32_WCE
  4638. // nIndex - IE5 or higher only
  4639. CImageList GetHotImageList(int nIndex = 0) const
  4640. {
  4641. ATLASSERT(::IsWindow(m_hWnd));
  4642. return CImageList((HIMAGELIST)::SendMessage(m_hWnd, TB_GETHOTIMAGELIST, nIndex, 0L));
  4643. }
  4644. // nIndex - IE5 or higher only
  4645. CImageList SetHotImageList(HIMAGELIST hImageList, int nIndex = 0)
  4646. {
  4647. ATLASSERT(::IsWindow(m_hWnd));
  4648. return CImageList((HIMAGELIST)::SendMessage(m_hWnd, TB_SETHOTIMAGELIST, nIndex, (LPARAM)hImageList));
  4649. }
  4650. #endif // !_WIN32_WCE
  4651. DWORD GetStyle() const
  4652. {
  4653. ATLASSERT(::IsWindow(m_hWnd));
  4654. return (DWORD)::SendMessage(m_hWnd, TB_GETSTYLE, 0, 0L);
  4655. }
  4656. void SetStyle(DWORD dwStyle)
  4657. {
  4658. ATLASSERT(::IsWindow(m_hWnd));
  4659. ::SendMessage(m_hWnd, TB_SETSTYLE, 0, dwStyle);
  4660. }
  4661. DWORD GetButtonSize() const
  4662. {
  4663. ATLASSERT(::IsWindow(m_hWnd));
  4664. return (DWORD)::SendMessage(m_hWnd, TB_GETBUTTONSIZE, 0, 0L);
  4665. }
  4666. void GetButtonSize(SIZE& size) const
  4667. {
  4668. ATLASSERT(::IsWindow(m_hWnd));
  4669. DWORD dwRet = (DWORD)::SendMessage(m_hWnd, TB_GETBUTTONSIZE, 0, 0L);
  4670. size.cx = LOWORD(dwRet);
  4671. size.cy = HIWORD(dwRet);
  4672. }
  4673. BOOL GetRect(int nID, LPRECT lpRect) const
  4674. {
  4675. ATLASSERT(::IsWindow(m_hWnd));
  4676. return (BOOL)::SendMessage(m_hWnd, TB_GETRECT, nID, (LPARAM)lpRect);
  4677. }
  4678. int GetTextRows() const
  4679. {
  4680. ATLASSERT(::IsWindow(m_hWnd));
  4681. return (int)::SendMessage(m_hWnd, TB_GETTEXTROWS, 0, 0L);
  4682. }
  4683. BOOL SetButtonWidth(int cxMin, int cxMax)
  4684. {
  4685. ATLASSERT(::IsWindow(m_hWnd));
  4686. return (BOOL)::SendMessage(m_hWnd, TB_SETBUTTONWIDTH, 0, MAKELPARAM(cxMin, cxMax));
  4687. }
  4688. BOOL SetIndent(int nIndent)
  4689. {
  4690. ATLASSERT(::IsWindow(m_hWnd));
  4691. return (BOOL)::SendMessage(m_hWnd, TB_SETINDENT, nIndent, 0L);
  4692. }
  4693. BOOL SetMaxTextRows(int nMaxTextRows)
  4694. {
  4695. ATLASSERT(::IsWindow(m_hWnd));
  4696. return (BOOL)::SendMessage(m_hWnd, TB_SETMAXTEXTROWS, nMaxTextRows, 0L);
  4697. }
  4698. #if (_WIN32_IE >= 0x0400)
  4699. #ifndef _WIN32_WCE
  4700. BOOL GetAnchorHighlight() const
  4701. {
  4702. ATLASSERT(::IsWindow(m_hWnd));
  4703. return (BOOL)::SendMessage(m_hWnd, TB_GETANCHORHIGHLIGHT, 0, 0L);
  4704. }
  4705. BOOL SetAnchorHighlight(BOOL bEnable = TRUE)
  4706. {
  4707. ATLASSERT(::IsWindow(m_hWnd));
  4708. return (BOOL)::SendMessage(m_hWnd, TB_SETANCHORHIGHLIGHT, bEnable, 0L);
  4709. }
  4710. #endif // !_WIN32_WCE
  4711. int GetButtonInfo(int nID, LPTBBUTTONINFO lptbbi) const
  4712. {
  4713. ATLASSERT(::IsWindow(m_hWnd));
  4714. return (int)::SendMessage(m_hWnd, TB_GETBUTTONINFO, nID, (LPARAM)lptbbi);
  4715. }
  4716. BOOL SetButtonInfo(int nID, LPTBBUTTONINFO lptbbi)
  4717. {
  4718. ATLASSERT(::IsWindow(m_hWnd));
  4719. return (BOOL)::SendMessage(m_hWnd, TB_SETBUTTONINFO, nID, (LPARAM)lptbbi);
  4720. }
  4721. BOOL SetButtonInfo(int nID, DWORD dwMask, BYTE Style, BYTE State, LPCTSTR lpszItem,
  4722. int iImage, WORD cx, int iCommand, DWORD_PTR lParam)
  4723. {
  4724. ATLASSERT(::IsWindow(m_hWnd));
  4725. TBBUTTONINFO tbbi = { 0 };
  4726. tbbi.cbSize = sizeof(TBBUTTONINFO);
  4727. tbbi.dwMask = dwMask;
  4728. tbbi.idCommand = iCommand;
  4729. tbbi.iImage = iImage;
  4730. tbbi.fsState = State;
  4731. tbbi.fsStyle = Style;
  4732. tbbi.cx = cx;
  4733. tbbi.pszText = (LPTSTR) lpszItem;
  4734. tbbi.lParam = lParam;
  4735. return (BOOL)::SendMessage(m_hWnd, TB_SETBUTTONINFO, nID, (LPARAM)&tbbi);
  4736. }
  4737. #ifndef _WIN32_WCE
  4738. int GetHotItem() const
  4739. {
  4740. ATLASSERT(::IsWindow(m_hWnd));
  4741. return (int)::SendMessage(m_hWnd, TB_GETHOTITEM, 0, 0L);
  4742. }
  4743. int SetHotItem(int nItem)
  4744. {
  4745. ATLASSERT(::IsWindow(m_hWnd));
  4746. return (int)::SendMessage(m_hWnd, TB_SETHOTITEM, nItem, 0L);
  4747. }
  4748. #endif // !_WIN32_WCE
  4749. BOOL IsButtonHighlighted(int nButtonID) const
  4750. {
  4751. ATLASSERT(::IsWindow(m_hWnd));
  4752. return (BOOL)::SendMessage(m_hWnd, TB_ISBUTTONHIGHLIGHTED, nButtonID, 0L);
  4753. }
  4754. DWORD SetDrawTextFlags(DWORD dwMask, DWORD dwFlags)
  4755. {
  4756. ATLASSERT(::IsWindow(m_hWnd));
  4757. return (DWORD)::SendMessage(m_hWnd, TB_SETDRAWTEXTFLAGS, dwMask, dwFlags);
  4758. }
  4759. #ifndef _WIN32_WCE
  4760. BOOL GetColorScheme(LPCOLORSCHEME lpcs) const
  4761. {
  4762. ATLASSERT(::IsWindow(m_hWnd));
  4763. return (BOOL)::SendMessage(m_hWnd, TB_GETCOLORSCHEME, 0, (LPARAM)lpcs);
  4764. }
  4765. void SetColorScheme(LPCOLORSCHEME lpcs)
  4766. {
  4767. ATLASSERT(::IsWindow(m_hWnd));
  4768. ::SendMessage(m_hWnd, TB_SETCOLORSCHEME, 0, (LPARAM)lpcs);
  4769. }
  4770. DWORD GetExtendedStyle() const
  4771. {
  4772. ATLASSERT(::IsWindow(m_hWnd));
  4773. return (DWORD)::SendMessage(m_hWnd, TB_GETEXTENDEDSTYLE, 0, 0L);
  4774. }
  4775. DWORD SetExtendedStyle(DWORD dwStyle)
  4776. {
  4777. ATLASSERT(::IsWindow(m_hWnd));
  4778. return (DWORD)::SendMessage(m_hWnd, TB_SETEXTENDEDSTYLE, 0, dwStyle);
  4779. }
  4780. void GetInsertMark(LPTBINSERTMARK lptbim) const
  4781. {
  4782. ATLASSERT(::IsWindow(m_hWnd));
  4783. ::SendMessage(m_hWnd, TB_GETINSERTMARK, 0, (LPARAM)lptbim);
  4784. }
  4785. void SetInsertMark(LPTBINSERTMARK lptbim)
  4786. {
  4787. ATLASSERT(::IsWindow(m_hWnd));
  4788. ::SendMessage(m_hWnd, TB_SETINSERTMARK, 0, (LPARAM)lptbim);
  4789. }
  4790. COLORREF GetInsertMarkColor() const
  4791. {
  4792. ATLASSERT(::IsWindow(m_hWnd));
  4793. return (COLORREF)::SendMessage(m_hWnd, TB_GETINSERTMARKCOLOR, 0, 0L);
  4794. }
  4795. COLORREF SetInsertMarkColor(COLORREF clr)
  4796. {
  4797. ATLASSERT(::IsWindow(m_hWnd));
  4798. return (COLORREF)::SendMessage(m_hWnd, TB_SETINSERTMARKCOLOR, 0, (LPARAM)clr);
  4799. }
  4800. BOOL GetMaxSize(LPSIZE lpSize) const
  4801. {
  4802. ATLASSERT(::IsWindow(m_hWnd));
  4803. return (BOOL)::SendMessage(m_hWnd, TB_GETMAXSIZE, 0, (LPARAM)lpSize);
  4804. }
  4805. void GetPadding(LPSIZE lpSizePadding) const
  4806. {
  4807. ATLASSERT(::IsWindow(m_hWnd));
  4808. ATLASSERT(lpSizePadding != NULL);
  4809. DWORD dwRet = (DWORD)::SendMessage(m_hWnd, TB_GETPADDING, 0, 0L);
  4810. lpSizePadding->cx = GET_X_LPARAM(dwRet);
  4811. lpSizePadding->cy = GET_Y_LPARAM(dwRet);
  4812. }
  4813. void SetPadding(int cx, int cy, LPSIZE lpSizePadding = NULL)
  4814. {
  4815. ATLASSERT(::IsWindow(m_hWnd));
  4816. DWORD dwRet = (DWORD)::SendMessage(m_hWnd, TB_SETPADDING, 0, MAKELPARAM(cx, cy));
  4817. if(lpSizePadding != NULL)
  4818. {
  4819. lpSizePadding->cx = GET_X_LPARAM(dwRet);
  4820. lpSizePadding->cy = GET_Y_LPARAM(dwRet);
  4821. }
  4822. }
  4823. BOOL GetUnicodeFormat() const
  4824. {
  4825. ATLASSERT(::IsWindow(m_hWnd));
  4826. return (BOOL)::SendMessage(m_hWnd, TB_GETUNICODEFORMAT, 0, 0L);
  4827. }
  4828. BOOL SetUnicodeFormat(BOOL bUnicode = TRUE)
  4829. {
  4830. ATLASSERT(::IsWindow(m_hWnd));
  4831. return (BOOL)::SendMessage(m_hWnd, TB_SETUNICODEFORMAT, bUnicode, 0L);
  4832. }
  4833. #endif // !_WIN32_WCE
  4834. #endif // (_WIN32_IE >= 0x0400)
  4835. #if (_WIN32_IE >= 0x0500) && !defined(_WIN32_WCE)
  4836. int GetString(int nString, LPTSTR lpstrString, int cchMaxLen) const
  4837. {
  4838. ATLASSERT(::IsWindow(m_hWnd));
  4839. return (int)::SendMessage(m_hWnd, TB_GETSTRING, MAKEWPARAM(cchMaxLen, nString), (LPARAM)lpstrString);
  4840. }
  4841. int GetStringBSTR(int nString, BSTR& bstrString) const
  4842. {
  4843. USES_CONVERSION;
  4844. ATLASSERT(::IsWindow(m_hWnd));
  4845. ATLASSERT(bstrString == NULL);
  4846. int nLength = (int)(short)LOWORD(::SendMessage(m_hWnd, TB_GETSTRING, MAKEWPARAM(0, nString), NULL));
  4847. if(nLength != -1)
  4848. {
  4849. CTempBuffer<TCHAR, _WTL_STACK_ALLOC_THRESHOLD> buff;
  4850. LPTSTR lpstrText = buff.Allocate(nLength + 1);
  4851. if(lpstrText != NULL)
  4852. {
  4853. nLength = (int)::SendMessage(m_hWnd, TB_GETSTRING, MAKEWPARAM(nLength + 1, nString), (LPARAM)lpstrText);
  4854. if(nLength != -1)
  4855. bstrString = ::SysAllocString(T2OLE(lpstrText));
  4856. }
  4857. else
  4858. {
  4859. nLength = -1;
  4860. }
  4861. }
  4862. return nLength;
  4863. }
  4864. #if defined(_WTL_USE_CSTRING) || defined(__ATLSTR_H__)
  4865. int GetString(int nString, _CSTRING_NS::CString& str) const
  4866. {
  4867. ATLASSERT(::IsWindow(m_hWnd));
  4868. int nLength = (int)(short)LOWORD(::SendMessage(m_hWnd, TB_GETSTRING, MAKEWPARAM(0, nString), NULL));
  4869. if(nLength != -1)
  4870. {
  4871. LPTSTR lpstr = str.GetBufferSetLength(nLength + 1);
  4872. if(lpstr != NULL)
  4873. nLength = (int)::SendMessage(m_hWnd, TB_GETSTRING, MAKEWPARAM(nLength + 1, nString), (LPARAM)lpstr);
  4874. else
  4875. nLength = -1;
  4876. str.ReleaseBuffer();
  4877. }
  4878. return nLength;
  4879. }
  4880. #endif // defined(_WTL_USE_CSTRING) || defined(__ATLSTR_H__)
  4881. #endif // (_WIN32_IE >= 0x0500) && !defined(_WIN32_WCE)
  4882. #if (_WIN32_WINNT >= 0x0501)
  4883. void GetMetrics(LPTBMETRICS lptbm) const
  4884. {
  4885. ATLASSERT(::IsWindow(m_hWnd));
  4886. ::SendMessage(m_hWnd, TB_GETMETRICS, 0, (LPARAM)lptbm);
  4887. }
  4888. void SetMetrics(LPTBMETRICS lptbm)
  4889. {
  4890. ATLASSERT(::IsWindow(m_hWnd));
  4891. ::SendMessage(m_hWnd, TB_SETMETRICS, 0, (LPARAM)lptbm);
  4892. }
  4893. void SetWindowTheme(LPCWSTR lpstrTheme)
  4894. {
  4895. ATLASSERT(::IsWindow(m_hWnd));
  4896. ::SendMessage(m_hWnd, TB_SETWINDOWTHEME, 0, (LPARAM)lpstrTheme);
  4897. }
  4898. #endif // (_WIN32_WINNT >= 0x0501)
  4899. #if (_WIN32_WINNT >= 0x0600)
  4900. CImageList GetPressedImageList(int nIndex = 0) const
  4901. {
  4902. ATLASSERT(::IsWindow(m_hWnd));
  4903. return CImageList((HIMAGELIST)::SendMessage(m_hWnd, TB_GETPRESSEDIMAGELIST, nIndex, 0L));
  4904. }
  4905. CImageList SetPressedImageList(HIMAGELIST hImageList, int nIndex = 0)
  4906. {
  4907. ATLASSERT(::IsWindow(m_hWnd));
  4908. return CImageList((HIMAGELIST)::SendMessage(m_hWnd, TB_SETPRESSEDIMAGELIST, nIndex, (LPARAM)hImageList));
  4909. }
  4910. #endif // (_WIN32_WINNT >= 0x0600)
  4911. // Operations
  4912. BOOL EnableButton(int nID, BOOL bEnable = TRUE)
  4913. {
  4914. ATLASSERT(::IsWindow(m_hWnd));
  4915. return (BOOL)::SendMessage(m_hWnd, TB_ENABLEBUTTON, nID, MAKELPARAM(bEnable, 0));
  4916. }
  4917. BOOL CheckButton(int nID, BOOL bCheck = TRUE)
  4918. {
  4919. ATLASSERT(::IsWindow(m_hWnd));
  4920. return (BOOL)::SendMessage(m_hWnd, TB_CHECKBUTTON, nID, MAKELPARAM(bCheck, 0));
  4921. }
  4922. BOOL PressButton(int nID, BOOL bPress = TRUE)
  4923. {
  4924. ATLASSERT(::IsWindow(m_hWnd));
  4925. return (BOOL)::SendMessage(m_hWnd, TB_PRESSBUTTON, nID, MAKELPARAM(bPress, 0));
  4926. }
  4927. BOOL HideButton(int nID, BOOL bHide = TRUE)
  4928. {
  4929. ATLASSERT(::IsWindow(m_hWnd));
  4930. return (BOOL)::SendMessage(m_hWnd, TB_HIDEBUTTON, nID, MAKELPARAM(bHide, 0));
  4931. }
  4932. BOOL Indeterminate(int nID, BOOL bIndeterminate = TRUE)
  4933. {
  4934. ATLASSERT(::IsWindow(m_hWnd));
  4935. return (BOOL)::SendMessage(m_hWnd, TB_INDETERMINATE, nID, MAKELPARAM(bIndeterminate, 0));
  4936. }
  4937. int AddBitmap(int nNumButtons, UINT nBitmapID)
  4938. {
  4939. ATLASSERT(::IsWindow(m_hWnd));
  4940. TBADDBITMAP tbab = { 0 };
  4941. tbab.hInst = ModuleHelper::GetResourceInstance();
  4942. ATLASSERT(tbab.hInst != NULL);
  4943. tbab.nID = nBitmapID;
  4944. return (int)::SendMessage(m_hWnd, TB_ADDBITMAP, (WPARAM)nNumButtons, (LPARAM)&tbab);
  4945. }
  4946. int AddBitmap(int nNumButtons, HBITMAP hBitmap)
  4947. {
  4948. ATLASSERT(::IsWindow(m_hWnd));
  4949. TBADDBITMAP tbab = { 0 };
  4950. tbab.hInst = NULL;
  4951. tbab.nID = (UINT_PTR)hBitmap;
  4952. return (int)::SendMessage(m_hWnd, TB_ADDBITMAP, (WPARAM)nNumButtons, (LPARAM)&tbab);
  4953. }
  4954. BOOL AddButtons(int nNumButtons, LPTBBUTTON lpButtons)
  4955. {
  4956. ATLASSERT(::IsWindow(m_hWnd));
  4957. return (BOOL)::SendMessage(m_hWnd, TB_ADDBUTTONS, nNumButtons, (LPARAM)lpButtons);
  4958. }
  4959. BOOL InsertButton(int nIndex, LPTBBUTTON lpButton)
  4960. {
  4961. ATLASSERT(::IsWindow(m_hWnd));
  4962. return (BOOL)::SendMessage(m_hWnd, TB_INSERTBUTTON, nIndex, (LPARAM)lpButton);
  4963. }
  4964. BOOL InsertButton(int nIndex, int iCommand, BYTE Style, BYTE State, int iBitmap,
  4965. INT_PTR iString, DWORD_PTR lParam)
  4966. {
  4967. ATLASSERT(::IsWindow(m_hWnd));
  4968. TBBUTTON tbb = { 0 };
  4969. tbb.fsStyle = Style;
  4970. tbb.fsState = State;
  4971. tbb.idCommand = iCommand;
  4972. tbb.iBitmap = iBitmap;
  4973. tbb.iString = iString;
  4974. tbb.dwData = lParam;
  4975. return (BOOL)::SendMessage(m_hWnd, TB_INSERTBUTTON, nIndex, (LPARAM)&tbb);
  4976. }
  4977. BOOL InsertButton(int nIndex, int iCommand, BYTE Style, BYTE State, int iBitmap,
  4978. LPCTSTR lpszItem, DWORD_PTR lParam)
  4979. {
  4980. return InsertButton(nIndex, iCommand, Style, State, iBitmap, (INT_PTR)lpszItem, lParam);
  4981. }
  4982. BOOL AddButton(LPTBBUTTON lpButton)
  4983. {
  4984. return InsertButton(-1, lpButton);
  4985. }
  4986. BOOL AddButton(int iCommand, BYTE Style, BYTE State, int iBitmap, INT_PTR iString, DWORD_PTR lParam)
  4987. {
  4988. return InsertButton(-1, iCommand, Style, State, iBitmap, iString, lParam);
  4989. }
  4990. BOOL AddButton(int iCommand, BYTE Style, BYTE State, int iBitmap, LPCTSTR lpszItem, DWORD_PTR lParam)
  4991. {
  4992. return InsertButton(-1, iCommand, Style, State, iBitmap, lpszItem, lParam);
  4993. }
  4994. BOOL DeleteButton(int nIndex)
  4995. {
  4996. ATLASSERT(::IsWindow(m_hWnd));
  4997. return (BOOL)::SendMessage(m_hWnd, TB_DELETEBUTTON, nIndex, 0L);
  4998. }
  4999. UINT CommandToIndex(UINT nID) const
  5000. {
  5001. ATLASSERT(::IsWindow(m_hWnd));
  5002. return (UINT)::SendMessage(m_hWnd, TB_COMMANDTOINDEX, nID, 0L);
  5003. }
  5004. #ifndef _WIN32_WCE
  5005. void SaveState(HKEY hKeyRoot, LPCTSTR lpszSubKey, LPCTSTR lpszValueName)
  5006. {
  5007. ATLASSERT(::IsWindow(m_hWnd));
  5008. TBSAVEPARAMS tbs = { 0 };
  5009. tbs.hkr = hKeyRoot;
  5010. tbs.pszSubKey = lpszSubKey;
  5011. tbs.pszValueName = lpszValueName;
  5012. ::SendMessage(m_hWnd, TB_SAVERESTORE, (WPARAM)TRUE, (LPARAM)&tbs);
  5013. }
  5014. void RestoreState(HKEY hKeyRoot, LPCTSTR lpszSubKey, LPCTSTR lpszValueName)
  5015. {
  5016. ATLASSERT(::IsWindow(m_hWnd));
  5017. TBSAVEPARAMS tbs = { 0 };
  5018. tbs.hkr = hKeyRoot;
  5019. tbs.pszSubKey = lpszSubKey;
  5020. tbs.pszValueName = lpszValueName;
  5021. ::SendMessage(m_hWnd, TB_SAVERESTORE, (WPARAM)FALSE, (LPARAM)&tbs);
  5022. }
  5023. void Customize()
  5024. {
  5025. ATLASSERT(::IsWindow(m_hWnd));
  5026. ::SendMessage(m_hWnd, TB_CUSTOMIZE, 0, 0L);
  5027. }
  5028. #endif // !_WIN32_WCE
  5029. int AddString(UINT nStringID)
  5030. {
  5031. ATLASSERT(::IsWindow(m_hWnd));
  5032. return (int)::SendMessage(m_hWnd, TB_ADDSTRING, (WPARAM)ModuleHelper::GetResourceInstance(), (LPARAM)nStringID);
  5033. }
  5034. int AddStrings(LPCTSTR lpszStrings)
  5035. {
  5036. ATLASSERT(::IsWindow(m_hWnd));
  5037. return (int)::SendMessage(m_hWnd, TB_ADDSTRING, 0, (LPARAM)lpszStrings);
  5038. }
  5039. void AutoSize()
  5040. {
  5041. ATLASSERT(::IsWindow(m_hWnd));
  5042. ::SendMessage(m_hWnd, TB_AUTOSIZE, 0, 0L);
  5043. }
  5044. BOOL ChangeBitmap(int nID, int nBitmap)
  5045. {
  5046. ATLASSERT(::IsWindow(m_hWnd));
  5047. return (BOOL)::SendMessage(m_hWnd, TB_CHANGEBITMAP, nID, MAKELPARAM(nBitmap, 0));
  5048. }
  5049. int LoadImages(int nBitmapID)
  5050. {
  5051. ATLASSERT(::IsWindow(m_hWnd));
  5052. return (int)::SendMessage(m_hWnd, TB_LOADIMAGES, nBitmapID, (LPARAM)ModuleHelper::GetResourceInstance());
  5053. }
  5054. int LoadStdImages(int nBitmapID)
  5055. {
  5056. ATLASSERT(::IsWindow(m_hWnd));
  5057. return (int)::SendMessage(m_hWnd, TB_LOADIMAGES, nBitmapID, (LPARAM)HINST_COMMCTRL);
  5058. }
  5059. BOOL ReplaceBitmap(LPTBREPLACEBITMAP ptbrb)
  5060. {
  5061. ATLASSERT(::IsWindow(m_hWnd));
  5062. return (BOOL)::SendMessage(m_hWnd, TB_REPLACEBITMAP, 0, (LPARAM)ptbrb);
  5063. }
  5064. #if (_WIN32_IE >= 0x0400)
  5065. int HitTest(LPPOINT lpPoint) const
  5066. {
  5067. ATLASSERT(::IsWindow(m_hWnd));
  5068. return (int)::SendMessage(m_hWnd, TB_HITTEST, 0, (LPARAM)lpPoint);
  5069. }
  5070. #ifndef _WIN32_WCE
  5071. BOOL InsertMarkHitTest(LPPOINT lpPoint, LPTBINSERTMARK lptbim) const
  5072. {
  5073. ATLASSERT(::IsWindow(m_hWnd));
  5074. return (BOOL)::SendMessage(m_hWnd, TB_INSERTMARKHITTEST, (WPARAM)lpPoint, (LPARAM)lptbim);
  5075. }
  5076. BOOL InsertMarkHitTest(int x, int y, LPTBINSERTMARK lptbim) const
  5077. {
  5078. ATLASSERT(::IsWindow(m_hWnd));
  5079. POINT pt = { x, y };
  5080. return (BOOL)::SendMessage(m_hWnd, TB_INSERTMARKHITTEST, (WPARAM)&pt, (LPARAM)lptbim);
  5081. }
  5082. BOOL MapAccelerator(TCHAR chAccel, int& nID) const
  5083. {
  5084. ATLASSERT(::IsWindow(m_hWnd));
  5085. return (BOOL)::SendMessage(m_hWnd, TB_MAPACCELERATOR, (WPARAM)chAccel, (LPARAM)&nID);
  5086. }
  5087. BOOL MarkButton(int nID, BOOL bHighlight = TRUE)
  5088. {
  5089. ATLASSERT(::IsWindow(m_hWnd));
  5090. return (BOOL)::SendMessage(m_hWnd, TB_MARKBUTTON, nID, MAKELPARAM(bHighlight, 0));
  5091. }
  5092. BOOL MoveButton(int nOldPos, int nNewPos)
  5093. {
  5094. ATLASSERT(::IsWindow(m_hWnd));
  5095. return (BOOL)::SendMessage(m_hWnd, TB_MOVEBUTTON, nOldPos, nNewPos);
  5096. }
  5097. HRESULT GetObject(REFIID iid, LPVOID* ppvObject)
  5098. {
  5099. ATLASSERT(::IsWindow(m_hWnd));
  5100. return (HRESULT)::SendMessage(m_hWnd, TB_GETOBJECT, (WPARAM)&iid, (LPARAM)ppvObject);
  5101. }
  5102. #endif // !_WIN32_WCE
  5103. #endif // (_WIN32_IE >= 0x0400)
  5104. };
  5105. typedef CToolBarCtrlT<ATL::CWindow> CToolBarCtrl;
  5106. ///////////////////////////////////////////////////////////////////////////////
  5107. // CStatusBarCtrl
  5108. template <class TBase>
  5109. class CStatusBarCtrlT : public TBase
  5110. {
  5111. public:
  5112. // Constructors
  5113. CStatusBarCtrlT(HWND hWnd = NULL) : TBase(hWnd)
  5114. { }
  5115. CStatusBarCtrlT< TBase >& operator =(HWND hWnd)
  5116. {
  5117. m_hWnd = hWnd;
  5118. return *this;
  5119. }
  5120. HWND Create(HWND hWndParent, ATL::_U_RECT rect = NULL, LPCTSTR szWindowName = NULL,
  5121. DWORD dwStyle = 0, DWORD dwExStyle = 0,
  5122. ATL::_U_MENUorID MenuOrID = 0U, LPVOID lpCreateParam = NULL)
  5123. {
  5124. return TBase::Create(GetWndClassName(), hWndParent, rect.m_lpRect, szWindowName, dwStyle, dwExStyle, MenuOrID.m_hMenu, lpCreateParam);
  5125. }
  5126. // Methods
  5127. static LPCTSTR GetWndClassName()
  5128. {
  5129. return STATUSCLASSNAME;
  5130. }
  5131. int GetParts(int nParts, int* pParts) const
  5132. {
  5133. ATLASSERT(::IsWindow(m_hWnd));
  5134. return (int)::SendMessage(m_hWnd, SB_GETPARTS, nParts, (LPARAM)pParts);
  5135. }
  5136. BOOL SetParts(int nParts, int* pWidths)
  5137. {
  5138. ATLASSERT(::IsWindow(m_hWnd));
  5139. return (BOOL)::SendMessage(m_hWnd, SB_SETPARTS, nParts, (LPARAM)pWidths);
  5140. }
  5141. int GetTextLength(int nPane, int* pType = NULL) const
  5142. {
  5143. ATLASSERT(::IsWindow(m_hWnd));
  5144. ATLASSERT(nPane < 256);
  5145. DWORD dwRet = (DWORD)::SendMessage(m_hWnd, SB_GETTEXTLENGTH, (WPARAM)nPane, 0L);
  5146. if (pType != NULL)
  5147. *pType = (int)(short)HIWORD(dwRet);
  5148. return (int)(short)LOWORD(dwRet);
  5149. }
  5150. int GetText(int nPane, LPTSTR lpszText, int* pType = NULL) const
  5151. {
  5152. ATLASSERT(::IsWindow(m_hWnd));
  5153. ATLASSERT(nPane < 256);
  5154. DWORD dwRet = (DWORD)::SendMessage(m_hWnd, SB_GETTEXT, (WPARAM)nPane, (LPARAM)lpszText);
  5155. if(pType != NULL)
  5156. *pType = (int)(short)HIWORD(dwRet);
  5157. return (int)(short)LOWORD(dwRet);
  5158. }
  5159. #ifndef _ATL_NO_COM
  5160. BOOL GetTextBSTR(int nPane, BSTR& bstrText, int* pType = NULL) const
  5161. {
  5162. USES_CONVERSION;
  5163. ATLASSERT(::IsWindow(m_hWnd));
  5164. ATLASSERT(nPane < 256);
  5165. ATLASSERT(bstrText == NULL);
  5166. int nLength = (int)(short)LOWORD(::SendMessage(m_hWnd, SB_GETTEXTLENGTH, (WPARAM)nPane, 0L));
  5167. if(nLength == 0)
  5168. return FALSE;
  5169. CTempBuffer<TCHAR, _WTL_STACK_ALLOC_THRESHOLD> buff;
  5170. LPTSTR lpstrText = buff.Allocate(nLength + 1);
  5171. if(lpstrText == NULL)
  5172. return FALSE;
  5173. if(!GetText(nPane, lpstrText, pType))
  5174. return FALSE;
  5175. bstrText = ::SysAllocString(T2OLE(lpstrText));
  5176. return (bstrText != NULL) ? TRUE : FALSE;
  5177. }
  5178. #endif // !_ATL_NO_COM
  5179. #if defined(_WTL_USE_CSTRING) || defined(__ATLSTR_H__)
  5180. int GetText(int nPane, _CSTRING_NS::CString& strText, int* pType = NULL) const
  5181. {
  5182. ATLASSERT(::IsWindow(m_hWnd));
  5183. ATLASSERT(nPane < 256);
  5184. int nLength = (int)(short)LOWORD(::SendMessage(m_hWnd, SB_GETTEXTLENGTH, (WPARAM)nPane, 0L));
  5185. if(nLength == 0)
  5186. return 0;
  5187. LPTSTR lpstr = strText.GetBufferSetLength(nLength);
  5188. if(lpstr == NULL)
  5189. return 0;
  5190. return GetText(nPane, lpstr, pType);
  5191. }
  5192. #endif // defined(_WTL_USE_CSTRING) || defined(__ATLSTR_H__)
  5193. BOOL SetText(int nPane, LPCTSTR lpszText, int nType = 0)
  5194. {
  5195. ATLASSERT(::IsWindow(m_hWnd));
  5196. ATLASSERT(nPane < 256);
  5197. return (BOOL)::SendMessage(m_hWnd, SB_SETTEXT, (nPane | nType), (LPARAM)lpszText);
  5198. }
  5199. BOOL GetRect(int nPane, LPRECT lpRect) const
  5200. {
  5201. ATLASSERT(::IsWindow(m_hWnd));
  5202. ATLASSERT(nPane < 256);
  5203. return (BOOL)::SendMessage(m_hWnd, SB_GETRECT, nPane, (LPARAM)lpRect);
  5204. }
  5205. BOOL GetBorders(int* pBorders) const
  5206. {
  5207. ATLASSERT(::IsWindow(m_hWnd));
  5208. return (BOOL)::SendMessage(m_hWnd, SB_GETBORDERS, 0, (LPARAM)pBorders);
  5209. }
  5210. BOOL GetBorders(int& nHorz, int& nVert, int& nSpacing) const
  5211. {
  5212. ATLASSERT(::IsWindow(m_hWnd));
  5213. int borders[3] = { 0, 0, 0 };
  5214. BOOL bResult = (BOOL)::SendMessage(m_hWnd, SB_GETBORDERS, 0, (LPARAM)&borders);
  5215. if(bResult)
  5216. {
  5217. nHorz = borders[0];
  5218. nVert = borders[1];
  5219. nSpacing = borders[2];
  5220. }
  5221. return bResult;
  5222. }
  5223. void SetMinHeight(int nMin)
  5224. {
  5225. ATLASSERT(::IsWindow(m_hWnd));
  5226. ::SendMessage(m_hWnd, SB_SETMINHEIGHT, nMin, 0L);
  5227. }
  5228. BOOL SetSimple(BOOL bSimple = TRUE)
  5229. {
  5230. ATLASSERT(::IsWindow(m_hWnd));
  5231. return (BOOL)::SendMessage(m_hWnd, SB_SIMPLE, bSimple, 0L);
  5232. }
  5233. BOOL IsSimple() const
  5234. {
  5235. ATLASSERT(::IsWindow(m_hWnd));
  5236. return (BOOL)::SendMessage(m_hWnd, SB_ISSIMPLE, 0, 0L);
  5237. }
  5238. #if (_WIN32_IE >= 0x0400) && !defined(_WIN32_WCE)
  5239. BOOL GetUnicodeFormat() const
  5240. {
  5241. ATLASSERT(::IsWindow(m_hWnd));
  5242. return (BOOL)::SendMessage(m_hWnd, SB_GETUNICODEFORMAT, 0, 0L);
  5243. }
  5244. BOOL SetUnicodeFormat(BOOL bUnicode = TRUE)
  5245. {
  5246. ATLASSERT(::IsWindow(m_hWnd));
  5247. return (BOOL)::SendMessage(m_hWnd, SB_SETUNICODEFORMAT, bUnicode, 0L);
  5248. }
  5249. void GetTipText(int nPane, LPTSTR lpstrText, int nSize) const
  5250. {
  5251. ATLASSERT(::IsWindow(m_hWnd));
  5252. ATLASSERT(nPane < 256);
  5253. ::SendMessage(m_hWnd, SB_GETTIPTEXT, MAKEWPARAM(nPane, nSize), (LPARAM)lpstrText);
  5254. }
  5255. void SetTipText(int nPane, LPCTSTR lpstrText)
  5256. {
  5257. ATLASSERT(::IsWindow(m_hWnd));
  5258. ATLASSERT(nPane < 256);
  5259. ::SendMessage(m_hWnd, SB_SETTIPTEXT, nPane, (LPARAM)lpstrText);
  5260. }
  5261. #endif // (_WIN32_IE >= 0x0400) && !defined(_WIN32_WCE)
  5262. #if ((_WIN32_IE >= 0x0400) && !defined(_WIN32_WCE)) || (defined(_WIN32_WCE) && (_WIN32_WCE >= 0x0500))
  5263. COLORREF SetBkColor(COLORREF clrBk)
  5264. {
  5265. ATLASSERT(::IsWindow(m_hWnd));
  5266. return (COLORREF)::SendMessage(m_hWnd, SB_SETBKCOLOR, 0, (LPARAM)clrBk);
  5267. }
  5268. HICON GetIcon(int nPane) const
  5269. {
  5270. ATLASSERT(::IsWindow(m_hWnd));
  5271. ATLASSERT(nPane < 256);
  5272. return (HICON)::SendMessage(m_hWnd, SB_GETICON, nPane, 0L);
  5273. }
  5274. BOOL SetIcon(int nPane, HICON hIcon)
  5275. {
  5276. ATLASSERT(::IsWindow(m_hWnd));
  5277. ATLASSERT(nPane < 256);
  5278. return (BOOL)::SendMessage(m_hWnd, SB_SETICON, nPane, (LPARAM)hIcon);
  5279. }
  5280. #endif // ((_WIN32_IE >= 0x0400) && !defined(_WIN32_WCE)) || (defined(_WIN32_WCE) && (_WIN32_WCE >= 0x0500))
  5281. };
  5282. typedef CStatusBarCtrlT<ATL::CWindow> CStatusBarCtrl;
  5283. ///////////////////////////////////////////////////////////////////////////////
  5284. // CTabCtrl
  5285. template <class TBase>
  5286. class CTabCtrlT : public TBase
  5287. {
  5288. public:
  5289. // Constructors
  5290. CTabCtrlT(HWND hWnd = NULL) : TBase(hWnd)
  5291. { }
  5292. CTabCtrlT< TBase >& operator =(HWND hWnd)
  5293. {
  5294. m_hWnd = hWnd;
  5295. return *this;
  5296. }
  5297. HWND Create(HWND hWndParent, ATL::_U_RECT rect = NULL, LPCTSTR szWindowName = NULL,
  5298. DWORD dwStyle = 0, DWORD dwExStyle = 0,
  5299. ATL::_U_MENUorID MenuOrID = 0U, LPVOID lpCreateParam = NULL)
  5300. {
  5301. return TBase::Create(GetWndClassName(), hWndParent, rect.m_lpRect, szWindowName, dwStyle, dwExStyle, MenuOrID.m_hMenu, lpCreateParam);
  5302. }
  5303. // Attributes
  5304. static LPCTSTR GetWndClassName()
  5305. {
  5306. return WC_TABCONTROL;
  5307. }
  5308. CImageList GetImageList() const
  5309. {
  5310. ATLASSERT(::IsWindow(m_hWnd));
  5311. return CImageList((HIMAGELIST)::SendMessage(m_hWnd, TCM_GETIMAGELIST, 0, 0L));
  5312. }
  5313. CImageList SetImageList(HIMAGELIST hImageList)
  5314. {
  5315. ATLASSERT(::IsWindow(m_hWnd));
  5316. return CImageList((HIMAGELIST)::SendMessage(m_hWnd, TCM_SETIMAGELIST, 0, (LPARAM)hImageList));
  5317. }
  5318. int GetItemCount() const
  5319. {
  5320. ATLASSERT(::IsWindow(m_hWnd));
  5321. return (int)::SendMessage(m_hWnd, TCM_GETITEMCOUNT, 0, 0L);
  5322. }
  5323. BOOL GetItem(int nItem, LPTCITEM pTabCtrlItem) const
  5324. {
  5325. ATLASSERT(::IsWindow(m_hWnd));
  5326. return (BOOL)::SendMessage(m_hWnd, TCM_GETITEM, nItem, (LPARAM)pTabCtrlItem);
  5327. }
  5328. BOOL SetItem(int nItem, LPTCITEM pTabCtrlItem)
  5329. {
  5330. ATLASSERT(::IsWindow(m_hWnd));
  5331. return (BOOL)::SendMessage(m_hWnd, TCM_SETITEM, nItem, (LPARAM)pTabCtrlItem);
  5332. }
  5333. int SetItem(int nItem, UINT mask, LPCTSTR lpszItem, DWORD dwState, DWORD dwStateMask, int iImage, LPARAM lParam)
  5334. {
  5335. ATLASSERT(::IsWindow(m_hWnd));
  5336. TCITEM tci = { 0 };
  5337. tci.mask = mask;
  5338. tci.pszText = (LPTSTR) lpszItem;
  5339. tci.dwState = dwState;
  5340. tci.dwStateMask = dwStateMask;
  5341. tci.iImage = iImage;
  5342. tci.lParam = lParam;
  5343. return (int)::SendMessage(m_hWnd, TCM_SETITEM, nItem, (LPARAM)&tci);
  5344. }
  5345. BOOL GetItemRect(int nItem, LPRECT lpRect) const
  5346. {
  5347. ATLASSERT(::IsWindow(m_hWnd));
  5348. return (BOOL)::SendMessage(m_hWnd, TCM_GETITEMRECT, nItem, (LPARAM)lpRect);
  5349. }
  5350. int GetCurSel() const
  5351. {
  5352. ATLASSERT(::IsWindow(m_hWnd));
  5353. return (int)::SendMessage(m_hWnd, TCM_GETCURSEL, 0, 0L);
  5354. }
  5355. int SetCurSel(int nItem)
  5356. {
  5357. ATLASSERT(::IsWindow(m_hWnd));
  5358. return (int)::SendMessage(m_hWnd, TCM_SETCURSEL, nItem, 0L);
  5359. }
  5360. SIZE SetItemSize(SIZE size)
  5361. {
  5362. ATLASSERT(::IsWindow(m_hWnd));
  5363. DWORD dwSize = (DWORD)::SendMessage(m_hWnd, TCM_SETITEMSIZE, 0, MAKELPARAM(size.cx, size.cy));
  5364. SIZE sizeRet = { GET_X_LPARAM(dwSize), GET_Y_LPARAM(dwSize) };
  5365. return sizeRet;
  5366. }
  5367. void SetItemSize(int cx, int cy)
  5368. {
  5369. ATLASSERT(::IsWindow(m_hWnd));
  5370. ::SendMessage(m_hWnd, TCM_SETITEMSIZE, 0, MAKELPARAM(cx, cy));
  5371. }
  5372. void SetPadding(SIZE size)
  5373. {
  5374. ATLASSERT(::IsWindow(m_hWnd));
  5375. ::SendMessage(m_hWnd, TCM_SETPADDING, 0, MAKELPARAM(size.cx, size.cy));
  5376. }
  5377. int GetRowCount() const
  5378. {
  5379. ATLASSERT(::IsWindow(m_hWnd));
  5380. return (int)::SendMessage(m_hWnd, TCM_GETROWCOUNT, 0, 0L);
  5381. }
  5382. #ifndef _WIN32_WCE
  5383. CToolTipCtrl GetTooltips() const
  5384. {
  5385. ATLASSERT(::IsWindow(m_hWnd));
  5386. return CToolTipCtrl((HWND)::SendMessage(m_hWnd, TCM_GETTOOLTIPS, 0, 0L));
  5387. }
  5388. void SetTooltips(HWND hWndToolTip)
  5389. {
  5390. ATLASSERT(::IsWindow(m_hWnd));
  5391. ::SendMessage(m_hWnd, TCM_SETTOOLTIPS, (WPARAM)hWndToolTip, 0L);
  5392. }
  5393. #endif // !_WIN32_WCE
  5394. int GetCurFocus() const
  5395. {
  5396. ATLASSERT(::IsWindow(m_hWnd));
  5397. return (int)::SendMessage(m_hWnd, TCM_GETCURFOCUS, 0, 0L);
  5398. }
  5399. void SetCurFocus(int nItem)
  5400. {
  5401. ATLASSERT(::IsWindow(m_hWnd));
  5402. ::SendMessage(m_hWnd, TCM_SETCURFOCUS, nItem, 0L);
  5403. }
  5404. BOOL SetItemExtra(int cbExtra)
  5405. {
  5406. ATLASSERT(::IsWindow(m_hWnd));
  5407. ATLASSERT(GetItemCount() == 0); // must be empty
  5408. return (BOOL)::SendMessage(m_hWnd, TCM_SETITEMEXTRA, cbExtra, 0L);
  5409. }
  5410. int SetMinTabWidth(int nWidth = -1)
  5411. {
  5412. ATLASSERT(::IsWindow(m_hWnd));
  5413. return (int)::SendMessage(m_hWnd, TCM_SETMINTABWIDTH, 0, nWidth);
  5414. }
  5415. #if (_WIN32_IE >= 0x0400)
  5416. DWORD GetExtendedStyle() const
  5417. {
  5418. ATLASSERT(::IsWindow(m_hWnd));
  5419. return (DWORD)::SendMessage(m_hWnd, TCM_GETEXTENDEDSTYLE, 0, 0L);
  5420. }
  5421. DWORD SetExtendedStyle(DWORD dwExMask, DWORD dwExStyle)
  5422. {
  5423. ATLASSERT(::IsWindow(m_hWnd));
  5424. return (DWORD)::SendMessage(m_hWnd, TCM_SETEXTENDEDSTYLE, dwExMask, dwExStyle);
  5425. }
  5426. #ifndef _WIN32_WCE
  5427. BOOL GetUnicodeFormat() const
  5428. {
  5429. ATLASSERT(::IsWindow(m_hWnd));
  5430. return (BOOL)::SendMessage(m_hWnd, TCM_GETUNICODEFORMAT, 0, 0L);
  5431. }
  5432. BOOL SetUnicodeFormat(BOOL bUnicode = TRUE)
  5433. {
  5434. ATLASSERT(::IsWindow(m_hWnd));
  5435. return (BOOL)::SendMessage(m_hWnd, TCM_SETUNICODEFORMAT, bUnicode, 0L);
  5436. }
  5437. #endif // !_WIN32_WCE
  5438. #endif // (_WIN32_IE >= 0x0400)
  5439. // Operations
  5440. int InsertItem(int nItem, LPTCITEM pTabCtrlItem)
  5441. {
  5442. ATLASSERT(::IsWindow(m_hWnd));
  5443. return (int)::SendMessage(m_hWnd, TCM_INSERTITEM, nItem, (LPARAM)pTabCtrlItem);
  5444. }
  5445. int InsertItem(int nItem, UINT mask, LPCTSTR lpszItem, int iImage, LPARAM lParam)
  5446. {
  5447. ATLASSERT(::IsWindow(m_hWnd));
  5448. TCITEM tci = { 0 };
  5449. tci.mask = mask;
  5450. tci.pszText = (LPTSTR) lpszItem;
  5451. tci.iImage = iImage;
  5452. tci.lParam = lParam;
  5453. return (int)::SendMessage(m_hWnd, TCM_INSERTITEM, nItem, (LPARAM)&tci);
  5454. }
  5455. int InsertItem(int nItem, LPCTSTR lpszItem)
  5456. {
  5457. ATLASSERT(::IsWindow(m_hWnd));
  5458. TCITEM tci = { 0 };
  5459. tci.mask = TCIF_TEXT;
  5460. tci.pszText = (LPTSTR) lpszItem;
  5461. return (int)::SendMessage(m_hWnd, TCM_INSERTITEM, nItem, (LPARAM)&tci);
  5462. }
  5463. int AddItem(LPTCITEM pTabCtrlItem)
  5464. {
  5465. return InsertItem(GetItemCount(), pTabCtrlItem);
  5466. }
  5467. int AddItem(UINT mask, LPCTSTR lpszItem, int iImage, LPARAM lParam)
  5468. {
  5469. return InsertItem(GetItemCount(), mask, lpszItem, iImage, lParam);
  5470. }
  5471. int AddItem(LPCTSTR lpszItem)
  5472. {
  5473. return InsertItem(GetItemCount(), lpszItem);
  5474. }
  5475. BOOL DeleteItem(int nItem)
  5476. {
  5477. ATLASSERT(::IsWindow(m_hWnd));
  5478. return (BOOL)::SendMessage(m_hWnd, TCM_DELETEITEM, nItem, 0L);
  5479. }
  5480. BOOL DeleteAllItems()
  5481. {
  5482. ATLASSERT(::IsWindow(m_hWnd));
  5483. return (BOOL)::SendMessage(m_hWnd, TCM_DELETEALLITEMS, 0, 0L);
  5484. }
  5485. void AdjustRect(BOOL bLarger, LPRECT lpRect)
  5486. {
  5487. ATLASSERT(::IsWindow(m_hWnd));
  5488. ::SendMessage(m_hWnd, TCM_ADJUSTRECT, bLarger, (LPARAM)lpRect);
  5489. }
  5490. void RemoveImage(int nImage)
  5491. {
  5492. ATLASSERT(::IsWindow(m_hWnd));
  5493. ::SendMessage(m_hWnd, TCM_REMOVEIMAGE, nImage, 0L);
  5494. }
  5495. int HitTest(TC_HITTESTINFO* pHitTestInfo) const
  5496. {
  5497. ATLASSERT(::IsWindow(m_hWnd));
  5498. return (int)::SendMessage(m_hWnd, TCM_HITTEST, 0, (LPARAM)pHitTestInfo);
  5499. }
  5500. void DeselectAll(BOOL bExcludeFocus = TRUE)
  5501. {
  5502. ATLASSERT(::IsWindow(m_hWnd));
  5503. ::SendMessage(m_hWnd, TCM_DESELECTALL, bExcludeFocus, 0L);
  5504. }
  5505. #if (_WIN32_IE >= 0x0400)
  5506. BOOL HighlightItem(int nIndex, BOOL bHighlight = TRUE)
  5507. {
  5508. ATLASSERT(::IsWindow(m_hWnd));
  5509. return (BOOL)::SendMessage(m_hWnd, TCM_HIGHLIGHTITEM, nIndex, MAKELPARAM(bHighlight, 0));
  5510. }
  5511. #endif // (_WIN32_IE >= 0x0400)
  5512. };
  5513. typedef CTabCtrlT<ATL::CWindow> CTabCtrl;
  5514. ///////////////////////////////////////////////////////////////////////////////
  5515. // CTrackBarCtrl
  5516. template <class TBase>
  5517. class CTrackBarCtrlT : public TBase
  5518. {
  5519. public:
  5520. // Constructors
  5521. CTrackBarCtrlT(HWND hWnd = NULL) : TBase(hWnd)
  5522. { }
  5523. CTrackBarCtrlT< TBase >& operator =(HWND hWnd)
  5524. {
  5525. m_hWnd = hWnd;
  5526. return *this;
  5527. }
  5528. HWND Create(HWND hWndParent, ATL::_U_RECT rect = NULL, LPCTSTR szWindowName = NULL,
  5529. DWORD dwStyle = 0, DWORD dwExStyle = 0,
  5530. ATL::_U_MENUorID MenuOrID = 0U, LPVOID lpCreateParam = NULL)
  5531. {
  5532. return TBase::Create(GetWndClassName(), hWndParent, rect.m_lpRect, szWindowName, dwStyle, dwExStyle, MenuOrID.m_hMenu, lpCreateParam);
  5533. }
  5534. // Attributes
  5535. static LPCTSTR GetWndClassName()
  5536. {
  5537. return TRACKBAR_CLASS;
  5538. }
  5539. int GetLineSize() const
  5540. {
  5541. ATLASSERT(::IsWindow(m_hWnd));
  5542. return (int)::SendMessage(m_hWnd, TBM_GETLINESIZE, 0, 0L);
  5543. }
  5544. int SetLineSize(int nSize)
  5545. {
  5546. ATLASSERT(::IsWindow(m_hWnd));
  5547. return (int)::SendMessage(m_hWnd, TBM_SETLINESIZE, 0, nSize);
  5548. }
  5549. int GetPageSize() const
  5550. {
  5551. ATLASSERT(::IsWindow(m_hWnd));
  5552. return (int)::SendMessage(m_hWnd, TBM_GETPAGESIZE, 0, 0L);
  5553. }
  5554. int SetPageSize(int nSize)
  5555. {
  5556. ATLASSERT(::IsWindow(m_hWnd));
  5557. return (int)::SendMessage(m_hWnd, TBM_SETPAGESIZE, 0, nSize);
  5558. }
  5559. int GetRangeMin() const
  5560. {
  5561. ATLASSERT(::IsWindow(m_hWnd));
  5562. return (int)::SendMessage(m_hWnd, TBM_GETRANGEMIN, 0, 0L);
  5563. }
  5564. void SetRangeMin(int nMin, BOOL bRedraw = FALSE)
  5565. {
  5566. ATLASSERT(::IsWindow(m_hWnd));
  5567. ::SendMessage(m_hWnd, TBM_SETRANGEMIN, bRedraw, nMin);
  5568. }
  5569. int GetRangeMax() const
  5570. {
  5571. ATLASSERT(::IsWindow(m_hWnd));
  5572. return (int)::SendMessage(m_hWnd, TBM_GETRANGEMAX, 0, 0L);
  5573. }
  5574. void SetRangeMax(int nMax, BOOL bRedraw = FALSE)
  5575. {
  5576. ATLASSERT(::IsWindow(m_hWnd));
  5577. ::SendMessage(m_hWnd, TBM_SETRANGEMAX, bRedraw, nMax);
  5578. }
  5579. void GetRange(int& nMin, int& nMax) const
  5580. {
  5581. nMin = GetRangeMin();
  5582. nMax = GetRangeMax();
  5583. }
  5584. void SetRange(int nMin, int nMax, BOOL bRedraw = TRUE)
  5585. {
  5586. ATLASSERT(::IsWindow(m_hWnd));
  5587. ::SendMessage(m_hWnd, TBM_SETRANGE, bRedraw, MAKELPARAM(nMin, nMax));
  5588. }
  5589. int GetSelStart() const
  5590. {
  5591. ATLASSERT(::IsWindow(m_hWnd));
  5592. return (int)::SendMessage(m_hWnd, TBM_GETSELSTART, 0, 0L);
  5593. }
  5594. void SetSelStart(int nMin)
  5595. {
  5596. ATLASSERT(::IsWindow(m_hWnd));
  5597. ::SendMessage(m_hWnd, TBM_SETSELSTART, 0, (LPARAM)nMin);
  5598. }
  5599. int GetSelEnd() const
  5600. {
  5601. ATLASSERT(::IsWindow(m_hWnd));
  5602. return (int)::SendMessage(m_hWnd, TBM_GETSELEND, 0, 0L);
  5603. }
  5604. void SetSelEnd(int nMax)
  5605. {
  5606. ATLASSERT(::IsWindow(m_hWnd));
  5607. ::SendMessage(m_hWnd, TBM_SETSELEND, 0, (LPARAM)nMax);
  5608. }
  5609. void GetSelection(int& nMin, int& nMax) const
  5610. {
  5611. nMin = GetSelStart();
  5612. nMax = GetSelEnd();
  5613. }
  5614. void SetSelection(int nMin, int nMax)
  5615. {
  5616. SetSelStart(nMin);
  5617. SetSelEnd(nMax);
  5618. }
  5619. void GetChannelRect(LPRECT lprc) const
  5620. {
  5621. ATLASSERT(::IsWindow(m_hWnd));
  5622. ::SendMessage(m_hWnd, TBM_GETCHANNELRECT, 0, (LPARAM)lprc);
  5623. }
  5624. void GetThumbRect(LPRECT lprc) const
  5625. {
  5626. ATLASSERT(::IsWindow(m_hWnd));
  5627. ::SendMessage(m_hWnd, TBM_GETTHUMBRECT, 0, (LPARAM)lprc);
  5628. }
  5629. int GetPos() const
  5630. {
  5631. ATLASSERT(::IsWindow(m_hWnd));
  5632. return (int)::SendMessage(m_hWnd, TBM_GETPOS, 0, 0L);
  5633. }
  5634. void SetPos(int nPos)
  5635. {
  5636. ATLASSERT(::IsWindow(m_hWnd));
  5637. ::SendMessage(m_hWnd, TBM_SETPOS, TRUE, nPos);
  5638. }
  5639. UINT GetNumTics() const
  5640. {
  5641. ATLASSERT(::IsWindow(m_hWnd));
  5642. return (UINT)::SendMessage(m_hWnd, TBM_GETNUMTICS, 0, 0L);
  5643. }
  5644. DWORD* GetTicArray() const
  5645. {
  5646. ATLASSERT(::IsWindow(m_hWnd));
  5647. return (DWORD*)::SendMessage(m_hWnd, TBM_GETPTICS, 0, 0L);
  5648. }
  5649. int GetTic(int nTic) const
  5650. {
  5651. ATLASSERT(::IsWindow(m_hWnd));
  5652. return (int)::SendMessage(m_hWnd, TBM_GETTIC, nTic, 0L);
  5653. }
  5654. BOOL SetTic(int nTic)
  5655. {
  5656. ATLASSERT(::IsWindow(m_hWnd));
  5657. return (BOOL)::SendMessage(m_hWnd, TBM_SETTIC, 0, nTic);
  5658. }
  5659. int GetTicPos(int nTic) const
  5660. {
  5661. ATLASSERT(::IsWindow(m_hWnd));
  5662. return (int)::SendMessage(m_hWnd, TBM_GETTICPOS, nTic, 0L);
  5663. }
  5664. void SetTicFreq(int nFreq)
  5665. {
  5666. ATLASSERT(::IsWindow(m_hWnd));
  5667. ::SendMessage(m_hWnd, TBM_SETTICFREQ, nFreq, 0L);
  5668. }
  5669. int GetThumbLength() const
  5670. {
  5671. ATLASSERT(::IsWindow(m_hWnd));
  5672. return (int)::SendMessage(m_hWnd, TBM_GETTHUMBLENGTH, 0, 0L);
  5673. }
  5674. void SetThumbLength(int nLength)
  5675. {
  5676. ATLASSERT(::IsWindow(m_hWnd));
  5677. ::SendMessage(m_hWnd, TBM_SETTHUMBLENGTH, nLength, 0L);
  5678. }
  5679. void SetSel(int nStart, int nEnd, BOOL bRedraw = TRUE)
  5680. {
  5681. ATLASSERT(::IsWindow(m_hWnd));
  5682. ATLASSERT((GetStyle() & TBS_ENABLESELRANGE) != 0);
  5683. ::SendMessage(m_hWnd, TBM_SETSEL, bRedraw, MAKELPARAM(nStart, nEnd));
  5684. }
  5685. ATL::CWindow GetBuddy(BOOL bLeft = TRUE) const
  5686. {
  5687. ATLASSERT(::IsWindow(m_hWnd));
  5688. return ATL::CWindow((HWND)::SendMessage(m_hWnd, TBM_GETBUDDY, bLeft, 0L));
  5689. }
  5690. ATL::CWindow SetBuddy(HWND hWndBuddy, BOOL bLeft = TRUE)
  5691. {
  5692. ATLASSERT(::IsWindow(m_hWnd));
  5693. return ATL::CWindow((HWND)::SendMessage(m_hWnd, TBM_SETBUDDY, bLeft, (LPARAM)hWndBuddy));
  5694. }
  5695. #ifndef _WIN32_WCE
  5696. CToolTipCtrl GetToolTips() const
  5697. {
  5698. ATLASSERT(::IsWindow(m_hWnd));
  5699. return CToolTipCtrl((HWND)::SendMessage(m_hWnd, TBM_GETTOOLTIPS, 0, 0L));
  5700. }
  5701. void SetToolTips(HWND hWndTT)
  5702. {
  5703. ATLASSERT(::IsWindow(m_hWnd));
  5704. ::SendMessage(m_hWnd, TBM_SETTOOLTIPS, (WPARAM)hWndTT, 0L);
  5705. }
  5706. int SetTipSide(int nSide)
  5707. {
  5708. ATLASSERT(::IsWindow(m_hWnd));
  5709. return (int)::SendMessage(m_hWnd, TBM_SETTIPSIDE, nSide, 0L);
  5710. }
  5711. #endif // !_WIN32_WCE
  5712. #if (_WIN32_IE >= 0x0400) && !defined(_WIN32_WCE)
  5713. BOOL GetUnicodeFormat() const
  5714. {
  5715. ATLASSERT(::IsWindow(m_hWnd));
  5716. return (BOOL)::SendMessage(m_hWnd, TBM_GETUNICODEFORMAT, 0, 0L);
  5717. }
  5718. BOOL SetUnicodeFormat(BOOL bUnicode = TRUE)
  5719. {
  5720. ATLASSERT(::IsWindow(m_hWnd));
  5721. return (BOOL)::SendMessage(m_hWnd, TBM_SETUNICODEFORMAT, bUnicode, 0L);
  5722. }
  5723. #endif // (_WIN32_IE >= 0x0400) && !defined(_WIN32_WCE)
  5724. // Operations
  5725. void ClearSel(BOOL bRedraw = FALSE)
  5726. {
  5727. ATLASSERT(::IsWindow(m_hWnd));
  5728. ::SendMessage(m_hWnd, TBM_CLEARSEL, bRedraw, 0L);
  5729. }
  5730. void VerifyPos()
  5731. {
  5732. ATLASSERT(::IsWindow(m_hWnd));
  5733. ::SendMessage(m_hWnd, TBM_SETPOS, FALSE, 0L);
  5734. }
  5735. void ClearTics(BOOL bRedraw = FALSE)
  5736. {
  5737. ATLASSERT(::IsWindow(m_hWnd));
  5738. ::SendMessage(m_hWnd, TBM_CLEARTICS, bRedraw, 0L);
  5739. }
  5740. };
  5741. typedef CTrackBarCtrlT<ATL::CWindow> CTrackBarCtrl;
  5742. ///////////////////////////////////////////////////////////////////////////////
  5743. // CUpDownCtrl
  5744. template <class TBase>
  5745. class CUpDownCtrlT : public TBase
  5746. {
  5747. public:
  5748. // Constructors
  5749. CUpDownCtrlT(HWND hWnd = NULL) : TBase(hWnd)
  5750. { }
  5751. CUpDownCtrlT< TBase >& operator =(HWND hWnd)
  5752. {
  5753. m_hWnd = hWnd;
  5754. return *this;
  5755. }
  5756. HWND Create(HWND hWndParent, ATL::_U_RECT rect = NULL, LPCTSTR szWindowName = NULL,
  5757. DWORD dwStyle = 0, DWORD dwExStyle = 0,
  5758. ATL::_U_MENUorID MenuOrID = 0U, LPVOID lpCreateParam = NULL)
  5759. {
  5760. return TBase::Create(GetWndClassName(), hWndParent, rect.m_lpRect, szWindowName, dwStyle, dwExStyle, MenuOrID.m_hMenu, lpCreateParam);
  5761. }
  5762. // Attributes
  5763. static LPCTSTR GetWndClassName()
  5764. {
  5765. return UPDOWN_CLASS;
  5766. }
  5767. UINT GetAccel(int nAccel, UDACCEL* pAccel) const
  5768. {
  5769. ATLASSERT(::IsWindow(m_hWnd));
  5770. return (UINT)LOWORD(::SendMessage(m_hWnd, UDM_GETACCEL, nAccel, (LPARAM)pAccel));
  5771. }
  5772. BOOL SetAccel(int nAccel, UDACCEL* pAccel)
  5773. {
  5774. ATLASSERT(::IsWindow(m_hWnd));
  5775. return (BOOL)LOWORD(::SendMessage(m_hWnd, UDM_SETACCEL, nAccel, (LPARAM)pAccel));
  5776. }
  5777. UINT GetBase() const
  5778. {
  5779. ATLASSERT(::IsWindow(m_hWnd));
  5780. return (UINT)LOWORD(::SendMessage(m_hWnd, UDM_GETBASE, 0, 0L));
  5781. }
  5782. int SetBase(int nBase)
  5783. {
  5784. ATLASSERT(::IsWindow(m_hWnd));
  5785. return (int)::SendMessage(m_hWnd, UDM_SETBASE, nBase, 0L);
  5786. }
  5787. ATL::CWindow GetBuddy() const
  5788. {
  5789. ATLASSERT(::IsWindow(m_hWnd));
  5790. return ATL::CWindow((HWND)::SendMessage(m_hWnd, UDM_GETBUDDY, 0, 0L));
  5791. }
  5792. ATL::CWindow SetBuddy(HWND hWndBuddy)
  5793. {
  5794. ATLASSERT(::IsWindow(m_hWnd));
  5795. return ATL::CWindow((HWND)::SendMessage(m_hWnd, UDM_SETBUDDY, (WPARAM)hWndBuddy, 0L));
  5796. }
  5797. int GetPos(LPBOOL lpbError = NULL) const
  5798. {
  5799. ATLASSERT(::IsWindow(m_hWnd));
  5800. DWORD dwRet = (DWORD)::SendMessage(m_hWnd, UDM_GETPOS, 0, 0L);
  5801. // Note: Seems that Windows always sets error to TRUE if
  5802. // UDS_SETBUDDYINT style is not used
  5803. if(lpbError != NULL)
  5804. *lpbError = (HIWORD(dwRet) != 0) ? TRUE : FALSE;
  5805. return (int)(short)LOWORD(dwRet);
  5806. }
  5807. int SetPos(int nPos)
  5808. {
  5809. ATLASSERT(::IsWindow(m_hWnd));
  5810. return (int)(short)LOWORD(::SendMessage(m_hWnd, UDM_SETPOS, 0, MAKELPARAM(nPos, 0)));
  5811. }
  5812. DWORD GetRange() const
  5813. {
  5814. ATLASSERT(::IsWindow(m_hWnd));
  5815. return (DWORD)::SendMessage(m_hWnd, UDM_GETRANGE, 0, 0L);
  5816. }
  5817. void GetRange(int& nLower, int& nUpper) const
  5818. {
  5819. ATLASSERT(::IsWindow(m_hWnd));
  5820. DWORD dwRet = (DWORD)::SendMessage(m_hWnd, UDM_GETRANGE, 0, 0L);
  5821. nLower = (int)(short)HIWORD(dwRet);
  5822. nUpper = (int)(short)LOWORD(dwRet);
  5823. }
  5824. void SetRange(int nLower, int nUpper)
  5825. {
  5826. ATLASSERT(::IsWindow(m_hWnd));
  5827. ::SendMessage(m_hWnd, UDM_SETRANGE, 0, MAKELPARAM(nUpper, nLower));
  5828. }
  5829. #if (_WIN32_IE >= 0x0400)
  5830. void SetRange32(int nLower, int nUpper)
  5831. {
  5832. ATLASSERT(::IsWindow(m_hWnd));
  5833. ::SendMessage(m_hWnd, UDM_SETRANGE32, nLower, nUpper);
  5834. }
  5835. void GetRange32(int& nLower, int& nUpper) const
  5836. {
  5837. ATLASSERT(::IsWindow(m_hWnd));
  5838. ::SendMessage(m_hWnd, UDM_GETRANGE32, (WPARAM)&nLower, (LPARAM)&nUpper);
  5839. }
  5840. #ifndef _WIN32_WCE
  5841. BOOL GetUnicodeFormat() const
  5842. {
  5843. ATLASSERT(::IsWindow(m_hWnd));
  5844. return (BOOL)::SendMessage(m_hWnd, UDM_GETUNICODEFORMAT, 0, 0L);
  5845. }
  5846. BOOL SetUnicodeFormat(BOOL bUnicode = TRUE)
  5847. {
  5848. ATLASSERT(::IsWindow(m_hWnd));
  5849. return (BOOL)::SendMessage(m_hWnd, UDM_SETUNICODEFORMAT, bUnicode, 0L);
  5850. }
  5851. #endif // !_WIN32_WCE
  5852. #endif // (_WIN32_IE >= 0x0400)
  5853. #if (_WIN32_IE >= 0x0500) && !defined(_WIN32_WCE)
  5854. int GetPos32(LPBOOL lpbError = NULL) const
  5855. {
  5856. ATLASSERT(::IsWindow(m_hWnd));
  5857. // Note: Seems that Windows always sets error to TRUE if
  5858. // UDS_SETBUDDYINT style is not used
  5859. return (int)::SendMessage(m_hWnd, UDM_GETPOS32, 0, (LPARAM)lpbError);
  5860. }
  5861. int SetPos32(int nPos)
  5862. {
  5863. ATLASSERT(::IsWindow(m_hWnd));
  5864. return (int)::SendMessage(m_hWnd, UDM_SETPOS32, 0, (LPARAM)nPos);
  5865. }
  5866. #endif // (_WIN32_IE >= 0x0500) && !defined(_WIN32_WCE)
  5867. };
  5868. typedef CUpDownCtrlT<ATL::CWindow> CUpDownCtrl;
  5869. ///////////////////////////////////////////////////////////////////////////////
  5870. // CProgressBarCtrl
  5871. template <class TBase>
  5872. class CProgressBarCtrlT : public TBase
  5873. {
  5874. public:
  5875. // Constructors
  5876. CProgressBarCtrlT(HWND hWnd = NULL) : TBase(hWnd)
  5877. { }
  5878. CProgressBarCtrlT< TBase >& operator =(HWND hWnd)
  5879. {
  5880. m_hWnd = hWnd;
  5881. return *this;
  5882. }
  5883. HWND Create(HWND hWndParent, ATL::_U_RECT rect = NULL, LPCTSTR szWindowName = NULL,
  5884. DWORD dwStyle = 0, DWORD dwExStyle = 0,
  5885. ATL::_U_MENUorID MenuOrID = 0U, LPVOID lpCreateParam = NULL)
  5886. {
  5887. return TBase::Create(GetWndClassName(), hWndParent, rect.m_lpRect, szWindowName, dwStyle, dwExStyle, MenuOrID.m_hMenu, lpCreateParam);
  5888. }
  5889. // Attributes
  5890. static LPCTSTR GetWndClassName()
  5891. {
  5892. return PROGRESS_CLASS;
  5893. }
  5894. DWORD SetRange(int nLower, int nUpper)
  5895. {
  5896. ATLASSERT(::IsWindow(m_hWnd));
  5897. return (DWORD)::SendMessage(m_hWnd, PBM_SETRANGE, 0, MAKELPARAM(nLower, nUpper));
  5898. }
  5899. int SetPos(int nPos)
  5900. {
  5901. ATLASSERT(::IsWindow(m_hWnd));
  5902. return (int)(short)LOWORD(::SendMessage(m_hWnd, PBM_SETPOS, nPos, 0L));
  5903. }
  5904. int OffsetPos(int nPos)
  5905. {
  5906. ATLASSERT(::IsWindow(m_hWnd));
  5907. return (int)(short)LOWORD(::SendMessage(m_hWnd, PBM_DELTAPOS, nPos, 0L));
  5908. }
  5909. int SetStep(int nStep)
  5910. {
  5911. ATLASSERT(::IsWindow(m_hWnd));
  5912. return (int)(short)LOWORD(::SendMessage(m_hWnd, PBM_SETSTEP, nStep, 0L));
  5913. }
  5914. UINT GetPos() const
  5915. {
  5916. ATLASSERT(::IsWindow(m_hWnd));
  5917. return (UINT)::SendMessage(m_hWnd, PBM_GETPOS, 0, 0L);
  5918. }
  5919. void GetRange(PPBRANGE pPBRange) const
  5920. {
  5921. ATLASSERT(::IsWindow(m_hWnd));
  5922. ATLASSERT(pPBRange != NULL);
  5923. ::SendMessage(m_hWnd, PBM_GETRANGE, TRUE, (LPARAM)pPBRange);
  5924. }
  5925. void GetRange(int& nLower, int& nUpper) const
  5926. {
  5927. ATLASSERT(::IsWindow(m_hWnd));
  5928. PBRANGE range = { 0 };
  5929. ::SendMessage(m_hWnd, PBM_GETRANGE, TRUE, (LPARAM)&range);
  5930. nLower = range.iLow;
  5931. nUpper = range.iHigh;
  5932. }
  5933. int GetRangeLimit(BOOL bLowLimit) const
  5934. {
  5935. ATLASSERT(::IsWindow(m_hWnd));
  5936. return (int)::SendMessage(m_hWnd, PBM_GETRANGE, bLowLimit, (LPARAM)NULL);
  5937. }
  5938. DWORD SetRange32(int nMin, int nMax)
  5939. {
  5940. ATLASSERT(::IsWindow(m_hWnd));
  5941. return (DWORD)::SendMessage(m_hWnd, PBM_SETRANGE32, nMin, nMax);
  5942. }
  5943. #if (_WIN32_IE >= 0x0400) && !defined(_WIN32_WCE)
  5944. COLORREF SetBarColor(COLORREF clr)
  5945. {
  5946. ATLASSERT(::IsWindow(m_hWnd));
  5947. return (COLORREF)::SendMessage(m_hWnd, PBM_SETBARCOLOR, 0, (LPARAM)clr);
  5948. }
  5949. COLORREF SetBkColor(COLORREF clr)
  5950. {
  5951. ATLASSERT(::IsWindow(m_hWnd));
  5952. return (COLORREF)::SendMessage(m_hWnd, PBM_SETBKCOLOR, 0, (LPARAM)clr);
  5953. }
  5954. #endif // (_WIN32_IE >= 0x0400) && !defined(_WIN32_WCE)
  5955. #if (_WIN32_WINNT >= 0x0501) && defined(PBM_SETMARQUEE)
  5956. BOOL SetMarquee(BOOL bMarquee, UINT uUpdateTime = 0U)
  5957. {
  5958. ATLASSERT(::IsWindow(m_hWnd));
  5959. return (BOOL)::SendMessage(m_hWnd, PBM_SETMARQUEE, (WPARAM)bMarquee, (LPARAM)uUpdateTime);
  5960. }
  5961. #endif // (_WIN32_WINNT >= 0x0501) && defined(PBM_SETMARQUEE)
  5962. #if (_WIN32_WINNT >= 0x0600)
  5963. int GetStep() const
  5964. {
  5965. ATLASSERT(::IsWindow(m_hWnd));
  5966. return (int)::SendMessage(m_hWnd, PBM_GETSTEP, 0, 0L);
  5967. }
  5968. COLORREF GetBkColor() const
  5969. {
  5970. ATLASSERT(::IsWindow(m_hWnd));
  5971. return (COLORREF)::SendMessage(m_hWnd, PBM_GETBKCOLOR, 0, 0L);
  5972. }
  5973. COLORREF GetBarColor() const
  5974. {
  5975. ATLASSERT(::IsWindow(m_hWnd));
  5976. return (COLORREF)::SendMessage(m_hWnd, PBM_GETBARCOLOR, 0, 0L);
  5977. }
  5978. int GetState() const
  5979. {
  5980. ATLASSERT(::IsWindow(m_hWnd));
  5981. return (int)::SendMessage(m_hWnd, PBM_GETSTATE, 0, 0L);
  5982. }
  5983. int SetState(int nState)
  5984. {
  5985. ATLASSERT(::IsWindow(m_hWnd));
  5986. return (int)::SendMessage(m_hWnd, PBM_SETSTATE, nState, 0L);
  5987. }
  5988. #endif // (_WIN32_WINNT >= 0x0600)
  5989. // Operations
  5990. int StepIt()
  5991. {
  5992. ATLASSERT(::IsWindow(m_hWnd));
  5993. return (int)(short)LOWORD(::SendMessage(m_hWnd, PBM_STEPIT, 0, 0L));
  5994. }
  5995. };
  5996. typedef CProgressBarCtrlT<ATL::CWindow> CProgressBarCtrl;
  5997. ///////////////////////////////////////////////////////////////////////////////
  5998. // CHotKeyCtrl
  5999. #ifndef _WIN32_WCE
  6000. template <class TBase>
  6001. class CHotKeyCtrlT : public TBase
  6002. {
  6003. public:
  6004. // Constructors
  6005. CHotKeyCtrlT(HWND hWnd = NULL) : TBase(hWnd)
  6006. { }
  6007. CHotKeyCtrlT< TBase >& operator =(HWND hWnd)
  6008. {
  6009. m_hWnd = hWnd;
  6010. return *this;
  6011. }
  6012. HWND Create(HWND hWndParent, ATL::_U_RECT rect = NULL, LPCTSTR szWindowName = NULL,
  6013. DWORD dwStyle = 0, DWORD dwExStyle = 0,
  6014. ATL::_U_MENUorID MenuOrID = 0U, LPVOID lpCreateParam = NULL)
  6015. {
  6016. return TBase::Create(GetWndClassName(), hWndParent, rect.m_lpRect, szWindowName, dwStyle, dwExStyle, MenuOrID.m_hMenu, lpCreateParam);
  6017. }
  6018. // Attributes
  6019. static LPCTSTR GetWndClassName()
  6020. {
  6021. return HOTKEY_CLASS;
  6022. }
  6023. DWORD GetHotKey() const
  6024. {
  6025. ATLASSERT(::IsWindow(m_hWnd));
  6026. return (DWORD)::SendMessage(m_hWnd, HKM_GETHOTKEY, 0, 0L);
  6027. }
  6028. void GetHotKey(WORD &wVirtualKeyCode, WORD &wModifiers) const
  6029. {
  6030. ATLASSERT(::IsWindow(m_hWnd));
  6031. DWORD dw = (DWORD)::SendMessage(m_hWnd, HKM_GETHOTKEY, 0, 0L);
  6032. wVirtualKeyCode = LOBYTE(LOWORD(dw));
  6033. wModifiers = HIBYTE(LOWORD(dw));
  6034. }
  6035. void SetHotKey(WORD wVirtualKeyCode, WORD wModifiers)
  6036. {
  6037. ATLASSERT(::IsWindow(m_hWnd));
  6038. ::SendMessage(m_hWnd, HKM_SETHOTKEY, MAKEWORD(wVirtualKeyCode, wModifiers), 0L);
  6039. }
  6040. void SetRules(WORD wInvalidComb, WORD wModifiers)
  6041. {
  6042. ATLASSERT(::IsWindow(m_hWnd));
  6043. ::SendMessage(m_hWnd, HKM_SETRULES, wInvalidComb, MAKELPARAM(wModifiers, 0));
  6044. }
  6045. };
  6046. typedef CHotKeyCtrlT<ATL::CWindow> CHotKeyCtrl;
  6047. #endif // !_WIN32_WCE
  6048. ///////////////////////////////////////////////////////////////////////////////
  6049. // CAnimateCtrl
  6050. #ifndef _WIN32_WCE
  6051. template <class TBase>
  6052. class CAnimateCtrlT : public TBase
  6053. {
  6054. public:
  6055. // Constructors
  6056. CAnimateCtrlT(HWND hWnd = NULL) : TBase(hWnd)
  6057. { }
  6058. CAnimateCtrlT< TBase >& operator =(HWND hWnd)
  6059. {
  6060. m_hWnd = hWnd;
  6061. return *this;
  6062. }
  6063. HWND Create(HWND hWndParent, ATL::_U_RECT rect = NULL, LPCTSTR szWindowName = NULL,
  6064. DWORD dwStyle = 0, DWORD dwExStyle = 0,
  6065. ATL::_U_MENUorID MenuOrID = 0U, LPVOID lpCreateParam = NULL)
  6066. {
  6067. return TBase::Create(GetWndClassName(), hWndParent, rect.m_lpRect, szWindowName, dwStyle, dwExStyle, MenuOrID.m_hMenu, lpCreateParam);
  6068. }
  6069. // Attributes
  6070. static LPCTSTR GetWndClassName()
  6071. {
  6072. return ANIMATE_CLASS;
  6073. }
  6074. // Operations
  6075. BOOL Open(ATL::_U_STRINGorID FileName)
  6076. {
  6077. ATLASSERT(::IsWindow(m_hWnd));
  6078. return (BOOL)::SendMessage(m_hWnd, ACM_OPEN, 0, (LPARAM)FileName.m_lpstr);
  6079. }
  6080. BOOL Play(UINT nFrom, UINT nTo, UINT nRep)
  6081. {
  6082. ATLASSERT(::IsWindow(m_hWnd));
  6083. return (BOOL)::SendMessage(m_hWnd, ACM_PLAY, nRep, MAKELPARAM(nFrom, nTo));
  6084. }
  6085. BOOL Stop()
  6086. {
  6087. ATLASSERT(::IsWindow(m_hWnd));
  6088. return (BOOL)::SendMessage(m_hWnd, ACM_STOP, 0, 0L);
  6089. }
  6090. BOOL Close()
  6091. {
  6092. ATLASSERT(::IsWindow(m_hWnd));
  6093. return (BOOL)::SendMessage(m_hWnd, ACM_OPEN, 0, 0L);
  6094. }
  6095. BOOL Seek(UINT nTo)
  6096. {
  6097. ATLASSERT(::IsWindow(m_hWnd));
  6098. return (BOOL)::SendMessage(m_hWnd, ACM_PLAY, 0, MAKELPARAM(nTo, nTo));
  6099. }
  6100. // Vista only
  6101. BOOL IsPlaying() const
  6102. {
  6103. #ifndef ACM_ISPLAYING
  6104. const UINT ACM_ISPLAYING = (WM_USER+104);
  6105. #endif
  6106. ATLASSERT(::IsWindow(m_hWnd));
  6107. return (BOOL)::SendMessage(m_hWnd, ACM_ISPLAYING, 0, 0L);
  6108. }
  6109. };
  6110. typedef CAnimateCtrlT<ATL::CWindow> CAnimateCtrl;
  6111. #endif // !_WIN32_WCE
  6112. ///////////////////////////////////////////////////////////////////////////////
  6113. // CRichEditCtrl
  6114. #ifndef _WIN32_WCE
  6115. #ifdef _UNICODE
  6116. #if (_RICHEDIT_VER == 0x0100)
  6117. #undef RICHEDIT_CLASS
  6118. #define RICHEDIT_CLASS L"RICHEDIT"
  6119. #endif // (_RICHEDIT_VER == 0x0100)
  6120. #endif // _UNICODE
  6121. template <class TBase>
  6122. class CRichEditCtrlT : public TBase
  6123. {
  6124. public:
  6125. // Constructors
  6126. CRichEditCtrlT(HWND hWnd = NULL) : TBase(hWnd)
  6127. { }
  6128. CRichEditCtrlT< TBase >& operator =(HWND hWnd)
  6129. {
  6130. m_hWnd = hWnd;
  6131. return *this;
  6132. }
  6133. HWND Create(HWND hWndParent, ATL::_U_RECT rect = NULL, LPCTSTR szWindowName = NULL,
  6134. DWORD dwStyle = 0, DWORD dwExStyle = 0,
  6135. ATL::_U_MENUorID MenuOrID = 0U, LPVOID lpCreateParam = NULL)
  6136. {
  6137. return TBase::Create(GetWndClassName(), hWndParent, rect.m_lpRect, szWindowName, dwStyle, dwExStyle, MenuOrID.m_hMenu, lpCreateParam);
  6138. }
  6139. // Attributes
  6140. static LPCTSTR GetWndClassName()
  6141. {
  6142. return RICHEDIT_CLASS;
  6143. }
  6144. static LPCTSTR GetLibraryName()
  6145. {
  6146. #if (_RICHEDIT_VER >= 0x0200)
  6147. return _T("RICHED20.DLL");
  6148. #else
  6149. return _T("RICHED32.DLL");
  6150. #endif
  6151. }
  6152. int GetLineCount() const
  6153. {
  6154. ATLASSERT(::IsWindow(m_hWnd));
  6155. return (int)::SendMessage(m_hWnd, EM_GETLINECOUNT, 0, 0L);
  6156. }
  6157. BOOL GetModify() const
  6158. {
  6159. ATLASSERT(::IsWindow(m_hWnd));
  6160. return (BOOL)::SendMessage(m_hWnd, EM_GETMODIFY, 0, 0L);
  6161. }
  6162. void SetModify(BOOL bModified = TRUE)
  6163. {
  6164. ATLASSERT(::IsWindow(m_hWnd));
  6165. ::SendMessage(m_hWnd, EM_SETMODIFY, bModified, 0L);
  6166. }
  6167. void GetRect(LPRECT lpRect) const
  6168. {
  6169. ATLASSERT(::IsWindow(m_hWnd));
  6170. ::SendMessage(m_hWnd, EM_GETRECT, 0, (LPARAM)lpRect);
  6171. }
  6172. DWORD GetOptions() const
  6173. {
  6174. ATLASSERT(::IsWindow(m_hWnd));
  6175. return (DWORD)::SendMessage(m_hWnd, EM_GETOPTIONS, 0, 0L);
  6176. }
  6177. DWORD SetOptions(WORD wOperation, DWORD dwOptions)
  6178. {
  6179. ATLASSERT(::IsWindow(m_hWnd));
  6180. return (DWORD)::SendMessage(m_hWnd, EM_SETOPTIONS, wOperation, dwOptions);
  6181. }
  6182. // NOTE: first word in lpszBuffer must contain the size of the buffer!
  6183. int GetLine(int nIndex, LPTSTR lpszBuffer) const
  6184. {
  6185. ATLASSERT(::IsWindow(m_hWnd));
  6186. return (int)::SendMessage(m_hWnd, EM_GETLINE, nIndex, (LPARAM)lpszBuffer);
  6187. }
  6188. int GetLine(int nIndex, LPTSTR lpszBuffer, int nMaxLength) const
  6189. {
  6190. ATLASSERT(::IsWindow(m_hWnd));
  6191. *(LPWORD)lpszBuffer = (WORD)nMaxLength;
  6192. return (int)::SendMessage(m_hWnd, EM_GETLINE, nIndex, (LPARAM)lpszBuffer);
  6193. }
  6194. BOOL CanUndo() const
  6195. {
  6196. ATLASSERT(::IsWindow(m_hWnd));
  6197. return (BOOL)::SendMessage(m_hWnd, EM_CANUNDO, 0, 0L);
  6198. }
  6199. BOOL CanPaste(UINT nFormat = 0) const
  6200. {
  6201. ATLASSERT(::IsWindow(m_hWnd));
  6202. return (BOOL)::SendMessage(m_hWnd, EM_CANPASTE, nFormat, 0L);
  6203. }
  6204. void GetSel(LONG& nStartChar, LONG& nEndChar) const
  6205. {
  6206. ATLASSERT(::IsWindow(m_hWnd));
  6207. CHARRANGE cr = { 0, 0 };
  6208. ::SendMessage(m_hWnd, EM_EXGETSEL, 0, (LPARAM)&cr);
  6209. nStartChar = cr.cpMin;
  6210. nEndChar = cr.cpMax;
  6211. }
  6212. void GetSel(CHARRANGE &cr) const
  6213. {
  6214. ATLASSERT(::IsWindow(m_hWnd));
  6215. ::SendMessage(m_hWnd, EM_EXGETSEL, 0, (LPARAM)&cr);
  6216. }
  6217. int SetSel(LONG nStartChar, LONG nEndChar)
  6218. {
  6219. ATLASSERT(::IsWindow(m_hWnd));
  6220. CHARRANGE cr = { nStartChar, nEndChar };
  6221. return (int)::SendMessage(m_hWnd, EM_EXSETSEL, 0, (LPARAM)&cr);
  6222. }
  6223. int SetSel(CHARRANGE &cr)
  6224. {
  6225. ATLASSERT(::IsWindow(m_hWnd));
  6226. return (int)::SendMessage(m_hWnd, EM_EXSETSEL, 0, (LPARAM)&cr);
  6227. }
  6228. int SetSelAll()
  6229. {
  6230. return SetSel(0, -1);
  6231. }
  6232. int SetSelNone()
  6233. {
  6234. return SetSel(-1, 0);
  6235. }
  6236. DWORD GetDefaultCharFormat(CHARFORMAT& cf) const
  6237. {
  6238. ATLASSERT(::IsWindow(m_hWnd));
  6239. cf.cbSize = sizeof(CHARFORMAT);
  6240. return (DWORD)::SendMessage(m_hWnd, EM_GETCHARFORMAT, 0, (LPARAM)&cf);
  6241. }
  6242. DWORD GetSelectionCharFormat(CHARFORMAT& cf) const
  6243. {
  6244. ATLASSERT(::IsWindow(m_hWnd));
  6245. cf.cbSize = sizeof(CHARFORMAT);
  6246. return (DWORD)::SendMessage(m_hWnd, EM_GETCHARFORMAT, 1, (LPARAM)&cf);
  6247. }
  6248. DWORD GetEventMask() const
  6249. {
  6250. ATLASSERT(::IsWindow(m_hWnd));
  6251. return (DWORD)::SendMessage(m_hWnd, EM_GETEVENTMASK, 0, 0L);
  6252. }
  6253. LONG GetLimitText() const
  6254. {
  6255. ATLASSERT(::IsWindow(m_hWnd));
  6256. return (LONG)::SendMessage(m_hWnd, EM_GETLIMITTEXT, 0, 0L);
  6257. }
  6258. DWORD GetParaFormat(PARAFORMAT& pf) const
  6259. {
  6260. ATLASSERT(::IsWindow(m_hWnd));
  6261. pf.cbSize = sizeof(PARAFORMAT);
  6262. return (DWORD)::SendMessage(m_hWnd, EM_GETPARAFORMAT, 0, (LPARAM)&pf);
  6263. }
  6264. #if (_RICHEDIT_VER >= 0x0200)
  6265. LONG GetSelText(LPTSTR lpstrBuff) const
  6266. {
  6267. ATLASSERT(::IsWindow(m_hWnd));
  6268. return (LONG)::SendMessage(m_hWnd, EM_GETSELTEXT, 0, (LPARAM)lpstrBuff);
  6269. }
  6270. #else // !(_RICHEDIT_VER >= 0x0200)
  6271. // RichEdit 1.0 EM_GETSELTEXT is ANSI only
  6272. LONG GetSelText(LPSTR lpstrBuff) const
  6273. {
  6274. ATLASSERT(::IsWindow(m_hWnd));
  6275. return (LONG)::SendMessage(m_hWnd, EM_GETSELTEXT, 0, (LPARAM)lpstrBuff);
  6276. }
  6277. #endif // !(_RICHEDIT_VER >= 0x0200)
  6278. #ifndef _ATL_NO_COM
  6279. BOOL GetSelTextBSTR(BSTR& bstrText) const
  6280. {
  6281. USES_CONVERSION;
  6282. ATLASSERT(::IsWindow(m_hWnd));
  6283. ATLASSERT(bstrText == NULL);
  6284. CHARRANGE cr = { 0, 0 };
  6285. ::SendMessage(m_hWnd, EM_EXGETSEL, 0, (LPARAM)&cr);
  6286. #if (_RICHEDIT_VER >= 0x0200)
  6287. CTempBuffer<TCHAR, _WTL_STACK_ALLOC_THRESHOLD> buff;
  6288. LPTSTR lpstrText = buff.Allocate(cr.cpMax - cr.cpMin + 1);
  6289. if(lpstrText == NULL)
  6290. return FALSE;
  6291. if(::SendMessage(m_hWnd, EM_GETSELTEXT, 0, (LPARAM)lpstrText) == 0)
  6292. return FALSE;
  6293. bstrText = ::SysAllocString(T2W(lpstrText));
  6294. #else // !(_RICHEDIT_VER >= 0x0200)
  6295. CTempBuffer<char, _WTL_STACK_ALLOC_THRESHOLD> buff;
  6296. LPSTR lpstrText = buff.Allocate(cr.cpMax - cr.cpMin + 1);
  6297. if(lpstrText == NULL)
  6298. return FALSE;
  6299. if(::SendMessage(m_hWnd, EM_GETSELTEXT, 0, (LPARAM)lpstrText) == 0)
  6300. return FALSE;
  6301. bstrText = ::SysAllocString(A2W(lpstrText));
  6302. #endif // !(_RICHEDIT_VER >= 0x0200)
  6303. return (bstrText != NULL) ? TRUE : FALSE;
  6304. }
  6305. #endif // !_ATL_NO_COM
  6306. #if defined(_WTL_USE_CSTRING) || defined(__ATLSTR_H__)
  6307. LONG GetSelText(_CSTRING_NS::CString& strText) const
  6308. {
  6309. ATLASSERT(::IsWindow(m_hWnd));
  6310. CHARRANGE cr = { 0, 0 };
  6311. ::SendMessage(m_hWnd, EM_EXGETSEL, 0, (LPARAM)&cr);
  6312. #if (_RICHEDIT_VER >= 0x0200)
  6313. LONG lLen = 0;
  6314. LPTSTR lpstrText = strText.GetBufferSetLength(cr.cpMax - cr.cpMin);
  6315. if(lpstrText != NULL)
  6316. {
  6317. lLen = (LONG)::SendMessage(m_hWnd, EM_GETSELTEXT, 0, (LPARAM)lpstrText);
  6318. strText.ReleaseBuffer();
  6319. }
  6320. #else // !(_RICHEDIT_VER >= 0x0200)
  6321. CTempBuffer<char, _WTL_STACK_ALLOC_THRESHOLD> buff;
  6322. LPSTR lpstrText = buff.Allocate(cr.cpMax - cr.cpMin + 1);
  6323. if(lpstrText == NULL)
  6324. return 0;
  6325. LONG lLen = (LONG)::SendMessage(m_hWnd, EM_GETSELTEXT, 0, (LPARAM)lpstrText);
  6326. if(lLen == 0)
  6327. return 0;
  6328. USES_CONVERSION;
  6329. strText = A2T(lpstrText);
  6330. #endif // !(_RICHEDIT_VER >= 0x0200)
  6331. return lLen;
  6332. }
  6333. #endif // defined(_WTL_USE_CSTRING) || defined(__ATLSTR_H__)
  6334. WORD GetSelectionType() const
  6335. {
  6336. ATLASSERT(::IsWindow(m_hWnd));
  6337. return (WORD)::SendMessage(m_hWnd, EM_SELECTIONTYPE, 0, 0L);
  6338. }
  6339. COLORREF SetBackgroundColor(COLORREF cr)
  6340. {
  6341. ATLASSERT(::IsWindow(m_hWnd));
  6342. return (COLORREF)::SendMessage(m_hWnd, EM_SETBKGNDCOLOR, 0, cr);
  6343. }
  6344. COLORREF SetBackgroundColor() // sets to system background
  6345. {
  6346. ATLASSERT(::IsWindow(m_hWnd));
  6347. return (COLORREF)::SendMessage(m_hWnd, EM_SETBKGNDCOLOR, 1, 0);
  6348. }
  6349. BOOL SetCharFormat(CHARFORMAT& cf, WORD wFlags)
  6350. {
  6351. ATLASSERT(::IsWindow(m_hWnd));
  6352. cf.cbSize = sizeof(CHARFORMAT);
  6353. return (BOOL)::SendMessage(m_hWnd, EM_SETCHARFORMAT, (WPARAM)wFlags, (LPARAM)&cf);
  6354. }
  6355. BOOL SetDefaultCharFormat(CHARFORMAT& cf)
  6356. {
  6357. ATLASSERT(::IsWindow(m_hWnd));
  6358. cf.cbSize = sizeof(CHARFORMAT);
  6359. return (BOOL)::SendMessage(m_hWnd, EM_SETCHARFORMAT, 0, (LPARAM)&cf);
  6360. }
  6361. BOOL SetSelectionCharFormat(CHARFORMAT& cf)
  6362. {
  6363. ATLASSERT(::IsWindow(m_hWnd));
  6364. cf.cbSize = sizeof(CHARFORMAT);
  6365. return (BOOL)::SendMessage(m_hWnd, EM_SETCHARFORMAT, SCF_SELECTION, (LPARAM)&cf);
  6366. }
  6367. BOOL SetWordCharFormat(CHARFORMAT& cf)
  6368. {
  6369. ATLASSERT(::IsWindow(m_hWnd));
  6370. cf.cbSize = sizeof(CHARFORMAT);
  6371. return (BOOL)::SendMessage(m_hWnd, EM_SETCHARFORMAT, SCF_SELECTION | SCF_WORD, (LPARAM)&cf);
  6372. }
  6373. DWORD SetEventMask(DWORD dwEventMask)
  6374. {
  6375. ATLASSERT(::IsWindow(m_hWnd));
  6376. return (DWORD)::SendMessage(m_hWnd, EM_SETEVENTMASK, 0, dwEventMask);
  6377. }
  6378. BOOL SetParaFormat(PARAFORMAT& pf)
  6379. {
  6380. ATLASSERT(::IsWindow(m_hWnd));
  6381. pf.cbSize = sizeof(PARAFORMAT);
  6382. return (BOOL)::SendMessage(m_hWnd, EM_SETPARAFORMAT, 0, (LPARAM)&pf);
  6383. }
  6384. BOOL SetTargetDevice(HDC hDC, int cxLineWidth)
  6385. {
  6386. ATLASSERT(::IsWindow(m_hWnd));
  6387. return (BOOL)::SendMessage(m_hWnd, EM_SETTARGETDEVICE, (WPARAM)hDC, cxLineWidth);
  6388. }
  6389. int GetTextLength() const
  6390. {
  6391. ATLASSERT(::IsWindow(m_hWnd));
  6392. return (int)::SendMessage(m_hWnd, WM_GETTEXTLENGTH, 0, 0L);
  6393. }
  6394. BOOL SetReadOnly(BOOL bReadOnly = TRUE)
  6395. {
  6396. ATLASSERT(::IsWindow(m_hWnd));
  6397. return (BOOL)::SendMessage(m_hWnd, EM_SETREADONLY, bReadOnly, 0L);
  6398. }
  6399. int GetFirstVisibleLine() const
  6400. {
  6401. ATLASSERT(::IsWindow(m_hWnd));
  6402. return (int)::SendMessage(m_hWnd, EM_GETFIRSTVISIBLELINE, 0, 0L);
  6403. }
  6404. EDITWORDBREAKPROCEX GetWordBreakProcEx() const
  6405. {
  6406. ATLASSERT(::IsWindow(m_hWnd));
  6407. return (EDITWORDBREAKPROCEX)::SendMessage(m_hWnd, EM_GETWORDBREAKPROCEX, 0, 0L);
  6408. }
  6409. EDITWORDBREAKPROCEX SetWordBreakProcEx(EDITWORDBREAKPROCEX pfnEditWordBreakProcEx)
  6410. {
  6411. ATLASSERT(::IsWindow(m_hWnd));
  6412. return (EDITWORDBREAKPROCEX)::SendMessage(m_hWnd, EM_SETWORDBREAKPROCEX, 0, (LPARAM)pfnEditWordBreakProcEx);
  6413. }
  6414. int GetTextRange(TEXTRANGE* pTextRange) const
  6415. {
  6416. ATLASSERT(::IsWindow(m_hWnd));
  6417. return (int)::SendMessage(m_hWnd, EM_GETTEXTRANGE, 0, (LPARAM)pTextRange);
  6418. }
  6419. #if (_RICHEDIT_VER >= 0x0200)
  6420. int GetTextRange(LONG nStartChar, LONG nEndChar, LPTSTR lpstrText) const
  6421. {
  6422. ATLASSERT(::IsWindow(m_hWnd));
  6423. TEXTRANGE tr = { 0 };
  6424. tr.chrg.cpMin = nStartChar;
  6425. tr.chrg.cpMax = nEndChar;
  6426. tr.lpstrText = lpstrText;
  6427. return (int)::SendMessage(m_hWnd, EM_GETTEXTRANGE, 0, (LPARAM)&tr);
  6428. }
  6429. #else // !(_RICHEDIT_VER >= 0x0200)
  6430. int GetTextRange(LONG nStartChar, LONG nEndChar, LPSTR lpstrText) const
  6431. {
  6432. ATLASSERT(::IsWindow(m_hWnd));
  6433. TEXTRANGE tr = { 0 };
  6434. tr.chrg.cpMin = nStartChar;
  6435. tr.chrg.cpMax = nEndChar;
  6436. tr.lpstrText = lpstrText;
  6437. return (int)::SendMessage(m_hWnd, EM_GETTEXTRANGE, 0, (LPARAM)&tr);
  6438. }
  6439. #endif // !(_RICHEDIT_VER >= 0x0200)
  6440. #if (_RICHEDIT_VER >= 0x0200)
  6441. DWORD GetDefaultCharFormat(CHARFORMAT2& cf) const
  6442. {
  6443. ATLASSERT(::IsWindow(m_hWnd));
  6444. cf.cbSize = sizeof(CHARFORMAT2);
  6445. return (DWORD)::SendMessage(m_hWnd, EM_GETCHARFORMAT, 0, (LPARAM)&cf);
  6446. }
  6447. BOOL SetCharFormat(CHARFORMAT2& cf, WORD wFlags)
  6448. {
  6449. ATLASSERT(::IsWindow(m_hWnd));
  6450. cf.cbSize = sizeof(CHARFORMAT2);
  6451. return (BOOL)::SendMessage(m_hWnd, EM_SETCHARFORMAT, (WPARAM)wFlags, (LPARAM)&cf);
  6452. }
  6453. BOOL SetDefaultCharFormat(CHARFORMAT2& cf)
  6454. {
  6455. ATLASSERT(::IsWindow(m_hWnd));
  6456. cf.cbSize = sizeof(CHARFORMAT2);
  6457. return (BOOL)::SendMessage(m_hWnd, EM_SETCHARFORMAT, 0, (LPARAM)&cf);
  6458. }
  6459. DWORD GetSelectionCharFormat(CHARFORMAT2& cf) const
  6460. {
  6461. ATLASSERT(::IsWindow(m_hWnd));
  6462. cf.cbSize = sizeof(CHARFORMAT2);
  6463. return (DWORD)::SendMessage(m_hWnd, EM_GETCHARFORMAT, 1, (LPARAM)&cf);
  6464. }
  6465. BOOL SetSelectionCharFormat(CHARFORMAT2& cf)
  6466. {
  6467. ATLASSERT(::IsWindow(m_hWnd));
  6468. cf.cbSize = sizeof(CHARFORMAT2);
  6469. return (BOOL)::SendMessage(m_hWnd, EM_SETCHARFORMAT, SCF_SELECTION, (LPARAM)&cf);
  6470. }
  6471. BOOL SetWordCharFormat(CHARFORMAT2& cf)
  6472. {
  6473. ATLASSERT(::IsWindow(m_hWnd));
  6474. cf.cbSize = sizeof(CHARFORMAT2);
  6475. return (BOOL)::SendMessage(m_hWnd, EM_SETCHARFORMAT, SCF_SELECTION | SCF_WORD, (LPARAM)&cf);
  6476. }
  6477. DWORD GetParaFormat(PARAFORMAT2& pf) const
  6478. {
  6479. ATLASSERT(::IsWindow(m_hWnd));
  6480. pf.cbSize = sizeof(PARAFORMAT2);
  6481. return (DWORD)::SendMessage(m_hWnd, EM_GETPARAFORMAT, 0, (LPARAM)&pf);
  6482. }
  6483. BOOL SetParaFormat(PARAFORMAT2& pf)
  6484. {
  6485. ATLASSERT(::IsWindow(m_hWnd));
  6486. pf.cbSize = sizeof(PARAFORMAT2);
  6487. return (BOOL)::SendMessage(m_hWnd, EM_SETPARAFORMAT, 0, (LPARAM)&pf);
  6488. }
  6489. TEXTMODE GetTextMode() const
  6490. {
  6491. ATLASSERT(::IsWindow(m_hWnd));
  6492. return (TEXTMODE)::SendMessage(m_hWnd, EM_GETTEXTMODE, 0, 0L);
  6493. }
  6494. BOOL SetTextMode(TEXTMODE enumTextMode)
  6495. {
  6496. ATLASSERT(::IsWindow(m_hWnd));
  6497. return !(BOOL)::SendMessage(m_hWnd, EM_SETTEXTMODE, enumTextMode, 0L);
  6498. }
  6499. UNDONAMEID GetUndoName() const
  6500. {
  6501. ATLASSERT(::IsWindow(m_hWnd));
  6502. return (UNDONAMEID)::SendMessage(m_hWnd, EM_GETUNDONAME, 0, 0L);
  6503. }
  6504. UNDONAMEID GetRedoName() const
  6505. {
  6506. ATLASSERT(::IsWindow(m_hWnd));
  6507. return (UNDONAMEID)::SendMessage(m_hWnd, EM_GETREDONAME, 0, 0L);
  6508. }
  6509. BOOL CanRedo() const
  6510. {
  6511. ATLASSERT(::IsWindow(m_hWnd));
  6512. return (BOOL)::SendMessage(m_hWnd, EM_CANREDO, 0, 0L);
  6513. }
  6514. BOOL GetAutoURLDetect() const
  6515. {
  6516. ATLASSERT(::IsWindow(m_hWnd));
  6517. return (BOOL)::SendMessage(m_hWnd, EM_GETAUTOURLDETECT, 0, 0L);
  6518. }
  6519. BOOL SetAutoURLDetect(BOOL bAutoDetect = TRUE)
  6520. {
  6521. ATLASSERT(::IsWindow(m_hWnd));
  6522. return !(BOOL)::SendMessage(m_hWnd, EM_AUTOURLDETECT, bAutoDetect, 0L);
  6523. }
  6524. // this method is deprecated, please use SetAutoURLDetect
  6525. BOOL EnableAutoURLDetect(BOOL bEnable = TRUE) { return SetAutoURLDetect(bEnable); }
  6526. UINT SetUndoLimit(UINT uUndoLimit)
  6527. {
  6528. ATLASSERT(::IsWindow(m_hWnd));
  6529. return (UINT)::SendMessage(m_hWnd, EM_SETUNDOLIMIT, uUndoLimit, 0L);
  6530. }
  6531. void SetPalette(HPALETTE hPalette)
  6532. {
  6533. ATLASSERT(::IsWindow(m_hWnd));
  6534. ::SendMessage(m_hWnd, EM_SETPALETTE, (WPARAM)hPalette, 0L);
  6535. }
  6536. int GetTextEx(GETTEXTEX* pGetTextEx, LPTSTR lpstrText) const
  6537. {
  6538. ATLASSERT(::IsWindow(m_hWnd));
  6539. return (int)::SendMessage(m_hWnd, EM_GETTEXTEX, (WPARAM)pGetTextEx, (LPARAM)lpstrText);
  6540. }
  6541. int GetTextEx(LPTSTR lpstrText, int nTextLen, DWORD dwFlags = GT_DEFAULT, UINT uCodePage = CP_ACP, LPCSTR lpDefaultChar = NULL, LPBOOL lpUsedDefChar = NULL) const
  6542. {
  6543. ATLASSERT(::IsWindow(m_hWnd));
  6544. GETTEXTEX gte = { 0 };
  6545. gte.cb = nTextLen * sizeof(TCHAR);
  6546. gte.codepage = uCodePage;
  6547. gte.flags = dwFlags;
  6548. gte.lpDefaultChar = lpDefaultChar;
  6549. gte.lpUsedDefChar = lpUsedDefChar;
  6550. return (int)::SendMessage(m_hWnd, EM_GETTEXTEX, (WPARAM)&gte, (LPARAM)lpstrText);
  6551. }
  6552. int GetTextLengthEx(GETTEXTLENGTHEX* pGetTextLengthEx) const
  6553. {
  6554. ATLASSERT(::IsWindow(m_hWnd));
  6555. return (int)::SendMessage(m_hWnd, EM_GETTEXTLENGTHEX, (WPARAM)pGetTextLengthEx, 0L);
  6556. }
  6557. int GetTextLengthEx(DWORD dwFlags = GTL_DEFAULT, UINT uCodePage = CP_ACP) const
  6558. {
  6559. ATLASSERT(::IsWindow(m_hWnd));
  6560. GETTEXTLENGTHEX gtle = { 0 };
  6561. gtle.codepage = uCodePage;
  6562. gtle.flags = dwFlags;
  6563. return (int)::SendMessage(m_hWnd, EM_GETTEXTLENGTHEX, (WPARAM)&gtle, 0L);
  6564. }
  6565. #endif // (_RICHEDIT_VER >= 0x0200)
  6566. #if (_RICHEDIT_VER >= 0x0300)
  6567. int SetTextEx(SETTEXTEX* pSetTextEx, LPCTSTR lpstrText)
  6568. {
  6569. ATLASSERT(::IsWindow(m_hWnd));
  6570. return (int)::SendMessage(m_hWnd, EM_SETTEXTEX, (WPARAM)pSetTextEx, (LPARAM)lpstrText);
  6571. }
  6572. int SetTextEx(LPCTSTR lpstrText, DWORD dwFlags = ST_DEFAULT, UINT uCodePage = CP_ACP)
  6573. {
  6574. ATLASSERT(::IsWindow(m_hWnd));
  6575. SETTEXTEX ste = { 0 };
  6576. ste.flags = dwFlags;
  6577. ste.codepage = uCodePage;
  6578. return (int)::SendMessage(m_hWnd, EM_SETTEXTEX, (WPARAM)&ste, (LPARAM)lpstrText);
  6579. }
  6580. int GetEditStyle() const
  6581. {
  6582. ATLASSERT(::IsWindow(m_hWnd));
  6583. return (int)::SendMessage(m_hWnd, EM_GETEDITSTYLE, 0, 0L);
  6584. }
  6585. int SetEditStyle(int nStyle, int nMask = -1)
  6586. {
  6587. ATLASSERT(::IsWindow(m_hWnd));
  6588. if(nMask == -1)
  6589. nMask = nStyle; // set everything specified
  6590. return (int)::SendMessage(m_hWnd, EM_SETEDITSTYLE, nStyle, nMask);
  6591. }
  6592. BOOL SetFontSize(int nFontSizeDelta)
  6593. {
  6594. ATLASSERT(::IsWindow(m_hWnd));
  6595. ATLASSERT(nFontSizeDelta >= -1637 && nFontSizeDelta <= 1638);
  6596. return (BOOL)::SendMessage(m_hWnd, EM_SETFONTSIZE, nFontSizeDelta, 0L);
  6597. }
  6598. void GetScrollPos(LPPOINT lpPoint) const
  6599. {
  6600. ATLASSERT(::IsWindow(m_hWnd));
  6601. ATLASSERT(lpPoint != NULL);
  6602. ::SendMessage(m_hWnd, EM_GETSCROLLPOS, 0, (LPARAM)lpPoint);
  6603. }
  6604. void SetScrollPos(LPPOINT lpPoint)
  6605. {
  6606. ATLASSERT(::IsWindow(m_hWnd));
  6607. ATLASSERT(lpPoint != NULL);
  6608. ::SendMessage(m_hWnd, EM_SETSCROLLPOS, 0, (LPARAM)lpPoint);
  6609. }
  6610. BOOL GetZoom(int& nNum, int& nDen) const
  6611. {
  6612. ATLASSERT(::IsWindow(m_hWnd));
  6613. return (BOOL)::SendMessage(m_hWnd, EM_GETZOOM, (WPARAM)&nNum, (LPARAM)&nDen);
  6614. }
  6615. BOOL SetZoom(int nNum, int nDen)
  6616. {
  6617. ATLASSERT(::IsWindow(m_hWnd));
  6618. ATLASSERT(nNum >= 0 && nNum <= 64);
  6619. ATLASSERT(nDen >= 0 && nDen <= 64);
  6620. return (BOOL)::SendMessage(m_hWnd, EM_SETZOOM, nNum, nDen);
  6621. }
  6622. BOOL SetZoomOff()
  6623. {
  6624. ATLASSERT(::IsWindow(m_hWnd));
  6625. return (BOOL)::SendMessage(m_hWnd, EM_SETZOOM, 0, 0L);
  6626. }
  6627. #endif // (_RICHEDIT_VER >= 0x0300)
  6628. // Operations
  6629. void LimitText(LONG nChars = 0)
  6630. {
  6631. ATLASSERT(::IsWindow(m_hWnd));
  6632. ::SendMessage(m_hWnd, EM_EXLIMITTEXT, 0, nChars);
  6633. }
  6634. int LineFromChar(LONG nIndex) const
  6635. {
  6636. ATLASSERT(::IsWindow(m_hWnd));
  6637. return (int)::SendMessage(m_hWnd, EM_EXLINEFROMCHAR, 0, nIndex);
  6638. }
  6639. POINT PosFromChar(LONG nChar) const
  6640. {
  6641. ATLASSERT(::IsWindow(m_hWnd));
  6642. POINT point = { 0, 0 };
  6643. ::SendMessage(m_hWnd, EM_POSFROMCHAR, (WPARAM)&point, nChar);
  6644. return point;
  6645. }
  6646. int CharFromPos(POINT pt) const
  6647. {
  6648. ATLASSERT(::IsWindow(m_hWnd));
  6649. POINTL ptl = { pt.x, pt.y };
  6650. return (int)::SendMessage(m_hWnd, EM_CHARFROMPOS, 0, (LPARAM)&ptl);
  6651. }
  6652. void EmptyUndoBuffer()
  6653. {
  6654. ATLASSERT(::IsWindow(m_hWnd));
  6655. ::SendMessage(m_hWnd, EM_EMPTYUNDOBUFFER, 0, 0L);
  6656. }
  6657. int LineIndex(int nLine = -1) const
  6658. {
  6659. ATLASSERT(::IsWindow(m_hWnd));
  6660. return (int)::SendMessage(m_hWnd, EM_LINEINDEX, nLine, 0L);
  6661. }
  6662. int LineLength(int nLine = -1) const
  6663. {
  6664. ATLASSERT(::IsWindow(m_hWnd));
  6665. return (int)::SendMessage(m_hWnd, EM_LINELENGTH, nLine, 0L);
  6666. }
  6667. BOOL LineScroll(int nLines, int nChars = 0)
  6668. {
  6669. ATLASSERT(::IsWindow(m_hWnd));
  6670. return (BOOL)::SendMessage(m_hWnd, EM_LINESCROLL, nChars, nLines);
  6671. }
  6672. void ReplaceSel(LPCTSTR lpszNewText, BOOL bCanUndo = FALSE)
  6673. {
  6674. ATLASSERT(::IsWindow(m_hWnd));
  6675. ::SendMessage(m_hWnd, EM_REPLACESEL, (WPARAM) bCanUndo, (LPARAM)lpszNewText);
  6676. }
  6677. void SetRect(LPCRECT lpRect)
  6678. {
  6679. ATLASSERT(::IsWindow(m_hWnd));
  6680. ::SendMessage(m_hWnd, EM_SETRECT, 0, (LPARAM)lpRect);
  6681. }
  6682. BOOL DisplayBand(LPRECT pDisplayRect)
  6683. {
  6684. ATLASSERT(::IsWindow(m_hWnd));
  6685. return (BOOL)::SendMessage(m_hWnd, EM_DISPLAYBAND, 0, (LPARAM)pDisplayRect);
  6686. }
  6687. LONG FindText(DWORD dwFlags, FINDTEXT& ft) const
  6688. {
  6689. ATLASSERT(::IsWindow(m_hWnd));
  6690. #if (_RICHEDIT_VER >= 0x0200) && defined(_UNICODE)
  6691. return (LONG)::SendMessage(m_hWnd, EM_FINDTEXTW, dwFlags, (LPARAM)&ft);
  6692. #else
  6693. return (LONG)::SendMessage(m_hWnd, EM_FINDTEXT, dwFlags, (LPARAM)&ft);
  6694. #endif
  6695. }
  6696. LONG FindText(DWORD dwFlags, FINDTEXTEX& ft) const
  6697. {
  6698. ATLASSERT(::IsWindow(m_hWnd));
  6699. #if (_RICHEDIT_VER >= 0x0200) && defined(_UNICODE)
  6700. return (LONG)::SendMessage(m_hWnd, EM_FINDTEXTEXW, dwFlags, (LPARAM)&ft);
  6701. #else
  6702. return (LONG)::SendMessage(m_hWnd, EM_FINDTEXTEX, dwFlags, (LPARAM)&ft);
  6703. #endif
  6704. }
  6705. LONG FormatRange(FORMATRANGE& fr, BOOL bDisplay = TRUE)
  6706. {
  6707. ATLASSERT(::IsWindow(m_hWnd));
  6708. return (LONG)::SendMessage(m_hWnd, EM_FORMATRANGE, bDisplay, (LPARAM)&fr);
  6709. }
  6710. LONG FormatRange(FORMATRANGE* pFormatRange, BOOL bDisplay = TRUE)
  6711. {
  6712. ATLASSERT(::IsWindow(m_hWnd));
  6713. return (LONG)::SendMessage(m_hWnd, EM_FORMATRANGE, bDisplay, (LPARAM)pFormatRange);
  6714. }
  6715. void HideSelection(BOOL bHide = TRUE, BOOL bChangeStyle = FALSE)
  6716. {
  6717. ATLASSERT(::IsWindow(m_hWnd));
  6718. ::SendMessage(m_hWnd, EM_HIDESELECTION, bHide, bChangeStyle);
  6719. }
  6720. void PasteSpecial(UINT uClipFormat, DWORD dwAspect = 0, HMETAFILE hMF = 0)
  6721. {
  6722. ATLASSERT(::IsWindow(m_hWnd));
  6723. REPASTESPECIAL reps = { dwAspect, (DWORD_PTR)hMF };
  6724. ::SendMessage(m_hWnd, EM_PASTESPECIAL, uClipFormat, (LPARAM)&reps);
  6725. }
  6726. void RequestResize()
  6727. {
  6728. ATLASSERT(::IsWindow(m_hWnd));
  6729. ::SendMessage(m_hWnd, EM_REQUESTRESIZE, 0, 0L);
  6730. }
  6731. LONG StreamIn(UINT uFormat, EDITSTREAM& es)
  6732. {
  6733. ATLASSERT(::IsWindow(m_hWnd));
  6734. return (LONG)::SendMessage(m_hWnd, EM_STREAMIN, uFormat, (LPARAM)&es);
  6735. }
  6736. LONG StreamOut(UINT uFormat, EDITSTREAM& es)
  6737. {
  6738. ATLASSERT(::IsWindow(m_hWnd));
  6739. return (LONG)::SendMessage(m_hWnd, EM_STREAMOUT, uFormat, (LPARAM)&es);
  6740. }
  6741. DWORD FindWordBreak(int nCode, LONG nStartChar)
  6742. {
  6743. ATLASSERT(::IsWindow(m_hWnd));
  6744. return (DWORD)::SendMessage(m_hWnd, EM_FINDWORDBREAK, nCode, nStartChar);
  6745. }
  6746. // Additional operations
  6747. void ScrollCaret()
  6748. {
  6749. ATLASSERT(::IsWindow(m_hWnd));
  6750. ::SendMessage(m_hWnd, EM_SCROLLCARET, 0, 0L);
  6751. }
  6752. int InsertText(long nInsertAfterChar, LPCTSTR lpstrText, BOOL bCanUndo = FALSE)
  6753. {
  6754. int nRet = SetSel(nInsertAfterChar, nInsertAfterChar);
  6755. ReplaceSel(lpstrText, bCanUndo);
  6756. return nRet;
  6757. }
  6758. int AppendText(LPCTSTR lpstrText, BOOL bCanUndo = FALSE)
  6759. {
  6760. return InsertText(GetWindowTextLength(), lpstrText, bCanUndo);
  6761. }
  6762. // Clipboard operations
  6763. BOOL Undo()
  6764. {
  6765. ATLASSERT(::IsWindow(m_hWnd));
  6766. return (BOOL)::SendMessage(m_hWnd, EM_UNDO, 0, 0L);
  6767. }
  6768. void Clear()
  6769. {
  6770. ATLASSERT(::IsWindow(m_hWnd));
  6771. ::SendMessage(m_hWnd, WM_CLEAR, 0, 0L);
  6772. }
  6773. void Copy()
  6774. {
  6775. ATLASSERT(::IsWindow(m_hWnd));
  6776. ::SendMessage(m_hWnd, WM_COPY, 0, 0L);
  6777. }
  6778. void Cut()
  6779. {
  6780. ATLASSERT(::IsWindow(m_hWnd));
  6781. ::SendMessage(m_hWnd, WM_CUT, 0, 0L);
  6782. }
  6783. void Paste()
  6784. {
  6785. ATLASSERT(::IsWindow(m_hWnd));
  6786. ::SendMessage(m_hWnd, WM_PASTE, 0, 0L);
  6787. }
  6788. // OLE support
  6789. IRichEditOle* GetOleInterface() const
  6790. {
  6791. ATLASSERT(::IsWindow(m_hWnd));
  6792. IRichEditOle *pRichEditOle = NULL;
  6793. ::SendMessage(m_hWnd, EM_GETOLEINTERFACE, 0, (LPARAM)&pRichEditOle);
  6794. return pRichEditOle;
  6795. }
  6796. BOOL SetOleCallback(IRichEditOleCallback* pCallback)
  6797. {
  6798. ATLASSERT(::IsWindow(m_hWnd));
  6799. return (BOOL)::SendMessage(m_hWnd, EM_SETOLECALLBACK, 0, (LPARAM)pCallback);
  6800. }
  6801. #if (_RICHEDIT_VER >= 0x0200)
  6802. BOOL Redo()
  6803. {
  6804. ATLASSERT(::IsWindow(m_hWnd));
  6805. return (BOOL)::SendMessage(m_hWnd, EM_REDO, 0, 0L);
  6806. }
  6807. void StopGroupTyping()
  6808. {
  6809. ATLASSERT(::IsWindow(m_hWnd));
  6810. ::SendMessage(m_hWnd, EM_STOPGROUPTYPING, 0, 0L);
  6811. }
  6812. void ShowScrollBar(int nBarType, BOOL bVisible = TRUE)
  6813. {
  6814. ATLASSERT(::IsWindow(m_hWnd));
  6815. ::SendMessage(m_hWnd, EM_SHOWSCROLLBAR, nBarType, bVisible);
  6816. }
  6817. #endif // (_RICHEDIT_VER >= 0x0200)
  6818. #if (_RICHEDIT_VER >= 0x0300)
  6819. BOOL SetTabStops(int nTabStops, LPINT rgTabStops)
  6820. {
  6821. ATLASSERT(::IsWindow(m_hWnd));
  6822. return (BOOL)::SendMessage(m_hWnd, EM_SETTABSTOPS, nTabStops, (LPARAM)rgTabStops);
  6823. }
  6824. BOOL SetTabStops()
  6825. {
  6826. ATLASSERT(::IsWindow(m_hWnd));
  6827. return (BOOL)::SendMessage(m_hWnd, EM_SETTABSTOPS, 0, 0L);
  6828. }
  6829. BOOL SetTabStops(const int& cxEachStop) // takes an 'int'
  6830. {
  6831. ATLASSERT(::IsWindow(m_hWnd));
  6832. return (BOOL)::SendMessage(m_hWnd, EM_SETTABSTOPS, 1, (LPARAM)(LPINT)&cxEachStop);
  6833. }
  6834. #endif // (_RICHEDIT_VER >= 0x0300)
  6835. };
  6836. typedef CRichEditCtrlT<ATL::CWindow> CRichEditCtrl;
  6837. #endif // !_WIN32_WCE
  6838. ///////////////////////////////////////////////////////////////////////////////
  6839. // CRichEditCommands - message handlers for standard EDIT commands
  6840. #ifndef _WIN32_WCE
  6841. // Chain to CRichEditCommands message map. Your class must also derive from CRichEditCtrl.
  6842. // Example:
  6843. // class CMyRichEdit : public CWindowImpl<CMyRichEdit, CRichEditCtrl>,
  6844. // public CRichEditCommands<CMyRichEdit>
  6845. // {
  6846. // public:
  6847. // BEGIN_MSG_MAP(CMyRichEdit)
  6848. // // your handlers...
  6849. // CHAIN_MSG_MAP_ALT(CRichEditCommands<CMyRichEdit>, 1)
  6850. // END_MSG_MAP()
  6851. // // other stuff...
  6852. // };
  6853. template <class T>
  6854. class CRichEditCommands : public CEditCommands< T >
  6855. {
  6856. public:
  6857. BEGIN_MSG_MAP(CRichEditCommands< T >)
  6858. ALT_MSG_MAP(1)
  6859. COMMAND_ID_HANDLER(ID_EDIT_CLEAR, CEditCommands< T >::OnEditClear)
  6860. COMMAND_ID_HANDLER(ID_EDIT_CLEAR_ALL, CEditCommands< T >::OnEditClearAll)
  6861. COMMAND_ID_HANDLER(ID_EDIT_COPY, CEditCommands< T >::OnEditCopy)
  6862. COMMAND_ID_HANDLER(ID_EDIT_CUT, CEditCommands< T >::OnEditCut)
  6863. COMMAND_ID_HANDLER(ID_EDIT_PASTE, CEditCommands< T >::OnEditPaste)
  6864. COMMAND_ID_HANDLER(ID_EDIT_SELECT_ALL, CEditCommands< T >::OnEditSelectAll)
  6865. COMMAND_ID_HANDLER(ID_EDIT_UNDO, CEditCommands< T >::OnEditUndo)
  6866. #if (_RICHEDIT_VER >= 0x0200)
  6867. COMMAND_ID_HANDLER(ID_EDIT_REDO, OnEditRedo)
  6868. #endif // (_RICHEDIT_VER >= 0x0200)
  6869. END_MSG_MAP()
  6870. #if (_RICHEDIT_VER >= 0x0200)
  6871. LRESULT OnEditRedo(WORD /*wNotifyCode*/, WORD /*wID*/, HWND /*hWndCtl*/, BOOL& /*bHandled*/)
  6872. {
  6873. T* pT = static_cast<T*>(this);
  6874. pT->Redo();
  6875. return 0;
  6876. }
  6877. #endif // (_RICHEDIT_VER >= 0x0200)
  6878. // State (update UI) helpers
  6879. BOOL CanCut() const
  6880. { return HasSelection(); }
  6881. BOOL CanCopy() const
  6882. { return HasSelection(); }
  6883. BOOL CanClear() const
  6884. { return HasSelection(); }
  6885. // Implementation
  6886. BOOL HasSelection() const
  6887. {
  6888. const T* pT = static_cast<const T*>(this);
  6889. return (pT->GetSelectionType() != SEL_EMPTY);
  6890. }
  6891. };
  6892. #endif // _WIN32_WCE
  6893. ///////////////////////////////////////////////////////////////////////////////
  6894. // CDragListBox
  6895. #ifndef _WIN32_WCE
  6896. template <class TBase>
  6897. class CDragListBoxT : public CListBoxT< TBase >
  6898. {
  6899. public:
  6900. // Constructors
  6901. CDragListBoxT(HWND hWnd = NULL) : CListBoxT< TBase >(hWnd)
  6902. { }
  6903. CDragListBoxT< TBase >& operator =(HWND hWnd)
  6904. {
  6905. m_hWnd = hWnd;
  6906. return *this;
  6907. }
  6908. HWND Create(HWND hWndParent, ATL::_U_RECT rect = NULL, LPCTSTR szWindowName = NULL,
  6909. DWORD dwStyle = 0, DWORD dwExStyle = 0,
  6910. ATL::_U_MENUorID MenuOrID = 0U, LPVOID lpCreateParam = NULL)
  6911. {
  6912. HWND hWnd = TBase::Create(GetWndClassName(), hWndParent, rect.m_lpRect, szWindowName, dwStyle, dwExStyle, MenuOrID.m_hMenu, lpCreateParam);
  6913. if(hWnd != NULL)
  6914. MakeDragList();
  6915. return hWnd;
  6916. }
  6917. // Operations
  6918. BOOL MakeDragList()
  6919. {
  6920. ATLASSERT(::IsWindow(m_hWnd));
  6921. ATLASSERT((GetStyle() & (LBS_MULTIPLESEL | LBS_EXTENDEDSEL)) == 0);
  6922. return ::MakeDragList(m_hWnd);
  6923. }
  6924. int LBItemFromPt(POINT pt, BOOL bAutoScroll = TRUE)
  6925. {
  6926. ATLASSERT(::IsWindow(m_hWnd));
  6927. return ::LBItemFromPt(m_hWnd, pt, bAutoScroll);
  6928. }
  6929. void DrawInsert(int nItem)
  6930. {
  6931. ATLASSERT(::IsWindow(m_hWnd));
  6932. ::DrawInsert(GetParent(), m_hWnd, nItem);
  6933. }
  6934. static UINT GetDragListMessage()
  6935. {
  6936. static UINT uDragListMessage = 0;
  6937. if(uDragListMessage == 0)
  6938. {
  6939. CStaticDataInitCriticalSectionLock lock;
  6940. if(FAILED(lock.Lock()))
  6941. {
  6942. ATLTRACE2(atlTraceUI, 0, _T("ERROR : Unable to lock critical section in CDragListBox::GetDragListMessage.\n"));
  6943. ATLASSERT(FALSE);
  6944. return 0;
  6945. }
  6946. if(uDragListMessage == 0)
  6947. uDragListMessage = ::RegisterWindowMessage(DRAGLISTMSGSTRING);
  6948. lock.Unlock();
  6949. }
  6950. ATLASSERT(uDragListMessage != 0);
  6951. return uDragListMessage;
  6952. }
  6953. };
  6954. typedef CDragListBoxT<ATL::CWindow> CDragListBox;
  6955. template <class T>
  6956. class CDragListNotifyImpl
  6957. {
  6958. public:
  6959. BEGIN_MSG_MAP(CDragListNotifyImpl< T >)
  6960. MESSAGE_HANDLER(CDragListBox::GetDragListMessage(), OnDragListNotify)
  6961. END_MSG_MAP()
  6962. LRESULT OnDragListNotify(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL& bHandled)
  6963. {
  6964. uMsg; // avoid level 4 warning
  6965. ATLASSERT(uMsg == CDragListBox::GetDragListMessage());
  6966. T* pT = static_cast<T*>(this);
  6967. LPDRAGLISTINFO lpDragListInfo = (LPDRAGLISTINFO)lParam;
  6968. LRESULT lRet = 0;
  6969. switch(lpDragListInfo->uNotification)
  6970. {
  6971. case DL_BEGINDRAG:
  6972. lRet = (LPARAM)pT->OnBeginDrag((int)wParam, lpDragListInfo->hWnd, lpDragListInfo->ptCursor);
  6973. break;
  6974. case DL_CANCELDRAG:
  6975. pT->OnCancelDrag((int)wParam, lpDragListInfo->hWnd, lpDragListInfo->ptCursor);
  6976. break;
  6977. case DL_DRAGGING:
  6978. lRet = (LPARAM)pT->OnDragging((int)wParam, lpDragListInfo->hWnd, lpDragListInfo->ptCursor);
  6979. break;
  6980. case DL_DROPPED:
  6981. pT->OnDropped((int)wParam, lpDragListInfo->hWnd, lpDragListInfo->ptCursor);
  6982. break;
  6983. default:
  6984. ATLTRACE2(atlTraceUI, 0, _T("Unknown DragListBox notification\n"));
  6985. bHandled = FALSE; // don't handle it
  6986. break;
  6987. }
  6988. return lRet;
  6989. }
  6990. // Overrideables
  6991. BOOL OnBeginDrag(int /*nCtlID*/, HWND /*hWndDragList*/, POINT /*ptCursor*/)
  6992. {
  6993. return TRUE; // allow dragging
  6994. }
  6995. void OnCancelDrag(int /*nCtlID*/, HWND /*hWndDragList*/, POINT /*ptCursor*/)
  6996. {
  6997. // nothing to do
  6998. }
  6999. int OnDragging(int /*nCtlID*/, HWND /*hWndDragList*/, POINT /*ptCursor*/)
  7000. {
  7001. return 0; // don't change cursor
  7002. }
  7003. void OnDropped(int /*nCtlID*/, HWND /*hWndDragList*/, POINT /*ptCursor*/)
  7004. {
  7005. // nothing to do
  7006. }
  7007. };
  7008. #endif // _WIN32_WCE
  7009. ///////////////////////////////////////////////////////////////////////////////
  7010. // CReBarCtrl
  7011. template <class TBase>
  7012. class CReBarCtrlT : public TBase
  7013. {
  7014. public:
  7015. // Constructors
  7016. CReBarCtrlT(HWND hWnd = NULL) : TBase(hWnd)
  7017. { }
  7018. CReBarCtrlT< TBase >& operator =(HWND hWnd)
  7019. {
  7020. m_hWnd = hWnd;
  7021. return *this;
  7022. }
  7023. HWND Create(HWND hWndParent, ATL::_U_RECT rect = NULL, LPCTSTR szWindowName = NULL,
  7024. DWORD dwStyle = 0, DWORD dwExStyle = 0,
  7025. ATL::_U_MENUorID MenuOrID = 0U, LPVOID lpCreateParam = NULL)
  7026. {
  7027. return TBase::Create(GetWndClassName(), hWndParent, rect.m_lpRect, szWindowName, dwStyle, dwExStyle, MenuOrID.m_hMenu, lpCreateParam);
  7028. }
  7029. // Attributes
  7030. static LPCTSTR GetWndClassName()
  7031. {
  7032. return REBARCLASSNAME;
  7033. }
  7034. UINT GetBandCount() const
  7035. {
  7036. ATLASSERT(::IsWindow(m_hWnd));
  7037. return (UINT)::SendMessage(m_hWnd, RB_GETBANDCOUNT, 0, 0L);
  7038. }
  7039. BOOL GetBandInfo(int nBand, LPREBARBANDINFO lprbbi) const
  7040. {
  7041. ATLASSERT(::IsWindow(m_hWnd));
  7042. return (BOOL)::SendMessage(m_hWnd, RB_GETBANDINFO, nBand, (LPARAM)lprbbi);
  7043. }
  7044. BOOL SetBandInfo(int nBand, LPREBARBANDINFO lprbbi)
  7045. {
  7046. ATLASSERT(::IsWindow(m_hWnd));
  7047. return (BOOL)::SendMessage(m_hWnd, RB_SETBANDINFO, nBand, (LPARAM)lprbbi);
  7048. }
  7049. BOOL GetBarInfo(LPREBARINFO lprbi) const
  7050. {
  7051. ATLASSERT(::IsWindow(m_hWnd));
  7052. return (BOOL)::SendMessage(m_hWnd, RB_GETBARINFO, 0, (LPARAM)lprbi);
  7053. }
  7054. BOOL SetBarInfo(LPREBARINFO lprbi)
  7055. {
  7056. ATLASSERT(::IsWindow(m_hWnd));
  7057. return (BOOL)::SendMessage(m_hWnd, RB_SETBARINFO, 0, (LPARAM)lprbi);
  7058. }
  7059. CImageList GetImageList() const
  7060. {
  7061. ATLASSERT(::IsWindow(m_hWnd));
  7062. REBARINFO rbi = { 0 };
  7063. rbi.cbSize = sizeof(REBARINFO);
  7064. rbi.fMask = RBIM_IMAGELIST;
  7065. BOOL bRet = (BOOL)::SendMessage(m_hWnd, RB_GETBARINFO, 0, (LPARAM)&rbi);
  7066. return CImageList((bRet != FALSE) ? rbi.himl : NULL);
  7067. }
  7068. BOOL SetImageList(HIMAGELIST hImageList)
  7069. {
  7070. ATLASSERT(::IsWindow(m_hWnd));
  7071. REBARINFO rbi = { 0 };
  7072. rbi.cbSize = sizeof(REBARINFO);
  7073. rbi.fMask = RBIM_IMAGELIST;
  7074. rbi.himl = hImageList;
  7075. return (BOOL)::SendMessage(m_hWnd, RB_SETBARINFO, 0, (LPARAM)&rbi);
  7076. }
  7077. UINT GetRowCount() const
  7078. {
  7079. ATLASSERT(::IsWindow(m_hWnd));
  7080. return (UINT)::SendMessage(m_hWnd, RB_GETROWCOUNT, 0, 0L);
  7081. }
  7082. UINT GetRowHeight(int nBand) const
  7083. {
  7084. ATLASSERT(::IsWindow(m_hWnd));
  7085. return (UINT)::SendMessage(m_hWnd, RB_GETROWHEIGHT, nBand, 0L);
  7086. }
  7087. #if (_WIN32_IE >= 0x0400)
  7088. COLORREF GetTextColor() const
  7089. {
  7090. ATLASSERT(::IsWindow(m_hWnd));
  7091. return (COLORREF)::SendMessage(m_hWnd, RB_GETTEXTCOLOR, 0, 0L);
  7092. }
  7093. COLORREF SetTextColor(COLORREF clr)
  7094. {
  7095. ATLASSERT(::IsWindow(m_hWnd));
  7096. return (COLORREF)::SendMessage(m_hWnd, RB_SETTEXTCOLOR, 0, (LPARAM)clr);
  7097. }
  7098. COLORREF GetBkColor() const
  7099. {
  7100. ATLASSERT(::IsWindow(m_hWnd));
  7101. return (COLORREF)::SendMessage(m_hWnd, RB_GETBKCOLOR, 0, 0L);
  7102. }
  7103. COLORREF SetBkColor(COLORREF clr)
  7104. {
  7105. ATLASSERT(::IsWindow(m_hWnd));
  7106. return (COLORREF)::SendMessage(m_hWnd, RB_SETBKCOLOR, 0, (LPARAM)clr);
  7107. }
  7108. UINT GetBarHeight() const
  7109. {
  7110. ATLASSERT(::IsWindow(m_hWnd));
  7111. return (UINT)::SendMessage(m_hWnd, RB_GETBARHEIGHT, 0, 0L);
  7112. }
  7113. BOOL GetRect(int nBand, LPRECT lpRect) const
  7114. {
  7115. ATLASSERT(::IsWindow(m_hWnd));
  7116. return (BOOL)::SendMessage(m_hWnd, RB_GETRECT, nBand, (LPARAM)lpRect);
  7117. }
  7118. #ifndef _WIN32_WCE
  7119. CToolTipCtrl GetToolTips() const
  7120. {
  7121. ATLASSERT(::IsWindow(m_hWnd));
  7122. return CToolTipCtrl((HWND)::SendMessage(m_hWnd, RB_GETTOOLTIPS, 0, 0L));
  7123. }
  7124. void SetToolTips(HWND hwndToolTip)
  7125. {
  7126. ATLASSERT(::IsWindow(m_hWnd));
  7127. ::SendMessage(m_hWnd, RB_SETTOOLTIPS, (WPARAM)hwndToolTip, 0L);
  7128. }
  7129. #endif // !_WIN32_WCE
  7130. void GetBandBorders(int nBand, LPRECT lpRect) const
  7131. {
  7132. ATLASSERT(::IsWindow(m_hWnd));
  7133. ATLASSERT(lpRect != NULL);
  7134. ::SendMessage(m_hWnd, RB_GETBANDBORDERS, nBand, (LPARAM)lpRect);
  7135. }
  7136. #ifndef _WIN32_WCE
  7137. BOOL GetColorScheme(LPCOLORSCHEME lpColorScheme) const
  7138. {
  7139. ATLASSERT(::IsWindow(m_hWnd));
  7140. ATLASSERT(lpColorScheme != NULL);
  7141. return (BOOL)::SendMessage(m_hWnd, RB_GETCOLORSCHEME, 0, (LPARAM)lpColorScheme);
  7142. }
  7143. void SetColorScheme(LPCOLORSCHEME lpColorScheme)
  7144. {
  7145. ATLASSERT(::IsWindow(m_hWnd));
  7146. ATLASSERT(lpColorScheme != NULL);
  7147. ::SendMessage(m_hWnd, RB_SETCOLORSCHEME, 0, (LPARAM)lpColorScheme);
  7148. }
  7149. HPALETTE GetPalette() const
  7150. {
  7151. ATLASSERT(::IsWindow(m_hWnd));
  7152. return (HPALETTE)::SendMessage(m_hWnd, RB_GETPALETTE, 0, 0L);
  7153. }
  7154. HPALETTE SetPalette(HPALETTE hPalette)
  7155. {
  7156. ATLASSERT(::IsWindow(m_hWnd));
  7157. return (HPALETTE)::SendMessage(m_hWnd, RB_SETPALETTE, 0, (LPARAM)hPalette);
  7158. }
  7159. BOOL GetUnicodeFormat() const
  7160. {
  7161. ATLASSERT(::IsWindow(m_hWnd));
  7162. return (BOOL)::SendMessage(m_hWnd, RB_GETUNICODEFORMAT, 0, 0L);
  7163. }
  7164. BOOL SetUnicodeFormat(BOOL bUnicode = TRUE)
  7165. {
  7166. ATLASSERT(::IsWindow(m_hWnd));
  7167. return (BOOL)::SendMessage(m_hWnd, RB_SETUNICODEFORMAT, bUnicode, 0L);
  7168. }
  7169. #endif // !_WIN32_WCE
  7170. #endif // (_WIN32_IE >= 0x0400)
  7171. #if (_WIN32_WINNT >= 0x0501)
  7172. // requires uxtheme.h to be included to use MARGINS struct
  7173. #ifndef _UXTHEME_H_
  7174. typedef struct _MARGINS* PMARGINS;
  7175. #endif // !_UXTHEME_H_
  7176. void GetBandMargins(PMARGINS pMargins) const
  7177. {
  7178. ATLASSERT(::IsWindow(m_hWnd));
  7179. ::SendMessage(m_hWnd, RB_GETBANDMARGINS, 0, (LPARAM)pMargins);
  7180. }
  7181. void SetWindowTheme(LPCWSTR lpstrTheme)
  7182. {
  7183. ATLASSERT(::IsWindow(m_hWnd));
  7184. ::SendMessage(m_hWnd, RB_SETWINDOWTHEME, 0, (LPARAM)lpstrTheme);
  7185. }
  7186. #endif // (_WIN32_WINNT >= 0x0501)
  7187. #if (_WIN32_IE >= 0x0600)
  7188. DWORD GetExtendedStyle() const
  7189. {
  7190. ATLASSERT(::IsWindow(m_hWnd));
  7191. return (DWORD)::SendMessage(m_hWnd, RB_GETEXTENDEDSTYLE, 0, 0L);
  7192. }
  7193. DWORD SetExtendedStyle(DWORD dwStyle, DWORD dwMask)
  7194. {
  7195. ATLASSERT(::IsWindow(m_hWnd));
  7196. return (DWORD)::SendMessage(m_hWnd, RB_SETEXTENDEDSTYLE, dwMask, dwStyle);
  7197. }
  7198. #endif // (_WIN32_IE >= 0x0600)
  7199. // Operations
  7200. BOOL InsertBand(int nBand, LPREBARBANDINFO lprbbi)
  7201. {
  7202. ATLASSERT(::IsWindow(m_hWnd));
  7203. return (BOOL)::SendMessage(m_hWnd, RB_INSERTBAND, nBand, (LPARAM)lprbbi);
  7204. }
  7205. BOOL AddBand(LPREBARBANDINFO lprbbi)
  7206. {
  7207. return InsertBand(-1, lprbbi);
  7208. }
  7209. BOOL DeleteBand(int nBand)
  7210. {
  7211. ATLASSERT(::IsWindow(m_hWnd));
  7212. return (BOOL)::SendMessage(m_hWnd, RB_DELETEBAND, nBand, 0L);
  7213. }
  7214. ATL::CWindow SetNotifyWnd(HWND hWnd)
  7215. {
  7216. ATLASSERT(::IsWindow(m_hWnd));
  7217. return ATL::CWindow((HWND)::SendMessage(m_hWnd, RB_SETPARENT, (WPARAM)hWnd, 0L));
  7218. }
  7219. #if (_WIN32_IE >= 0x0400)
  7220. void BeginDrag(int nBand, DWORD dwPos)
  7221. {
  7222. ATLASSERT(::IsWindow(m_hWnd));
  7223. ::SendMessage(m_hWnd, RB_BEGINDRAG, nBand, dwPos);
  7224. }
  7225. void BeginDrag(int nBand, int xPos, int yPos)
  7226. {
  7227. ATLASSERT(::IsWindow(m_hWnd));
  7228. ::SendMessage(m_hWnd, RB_BEGINDRAG, nBand, MAKELPARAM(xPos, yPos));
  7229. }
  7230. void EndDrag()
  7231. {
  7232. ATLASSERT(::IsWindow(m_hWnd));
  7233. ::SendMessage(m_hWnd, RB_ENDDRAG, 0, 0L);
  7234. }
  7235. void DragMove(DWORD dwPos)
  7236. {
  7237. ATLASSERT(::IsWindow(m_hWnd));
  7238. ::SendMessage(m_hWnd, RB_DRAGMOVE, 0, dwPos);
  7239. }
  7240. void DragMove(int xPos, int yPos)
  7241. {
  7242. ATLASSERT(::IsWindow(m_hWnd));
  7243. ::SendMessage(m_hWnd, RB_DRAGMOVE, 0, MAKELPARAM(xPos, yPos));
  7244. }
  7245. #ifndef _WIN32_WCE
  7246. void GetDropTarget(IDropTarget** ppDropTarget) const
  7247. {
  7248. ATLASSERT(::IsWindow(m_hWnd));
  7249. ::SendMessage(m_hWnd, RB_GETDROPTARGET, 0, (LPARAM)ppDropTarget);
  7250. }
  7251. #endif // !_WIN32_WCE
  7252. void MaximizeBand(int nBand, BOOL bIdeal = FALSE)
  7253. {
  7254. ATLASSERT(::IsWindow(m_hWnd));
  7255. ::SendMessage(m_hWnd, RB_MAXIMIZEBAND, nBand, bIdeal);
  7256. }
  7257. void MinimizeBand(int nBand)
  7258. {
  7259. ATLASSERT(::IsWindow(m_hWnd));
  7260. ::SendMessage(m_hWnd, RB_MINIMIZEBAND, nBand, 0L);
  7261. }
  7262. BOOL SizeToRect(LPRECT lpRect)
  7263. {
  7264. ATLASSERT(::IsWindow(m_hWnd));
  7265. return (BOOL)::SendMessage(m_hWnd, RB_SIZETORECT, 0, (LPARAM)lpRect);
  7266. }
  7267. int IdToIndex(UINT uBandID) const
  7268. {
  7269. ATLASSERT(::IsWindow(m_hWnd));
  7270. return (int)::SendMessage(m_hWnd, RB_IDTOINDEX, uBandID, 0L);
  7271. }
  7272. int HitTest(LPRBHITTESTINFO lprbht) const
  7273. {
  7274. ATLASSERT(::IsWindow(m_hWnd));
  7275. return (int)::SendMessage(m_hWnd, RB_HITTEST, 0, (LPARAM)lprbht);
  7276. }
  7277. BOOL ShowBand(int nBand, BOOL bShow)
  7278. {
  7279. ATLASSERT(::IsWindow(m_hWnd));
  7280. return (BOOL)::SendMessage(m_hWnd, RB_SHOWBAND, nBand, bShow);
  7281. }
  7282. #ifndef _WIN32_WCE
  7283. BOOL MoveBand(int nBand, int nNewPos)
  7284. {
  7285. ATLASSERT(::IsWindow(m_hWnd));
  7286. ATLASSERT(nNewPos >= 0 && nNewPos <= ((int)GetBandCount() - 1));
  7287. return (BOOL)::SendMessage(m_hWnd, RB_MOVEBAND, nBand, nNewPos);
  7288. }
  7289. #endif // !_WIN32_WCE
  7290. #endif // (_WIN32_IE >= 0x0400)
  7291. #if (_WIN32_IE >= 0x0500) && !defined(_WIN32_WCE)
  7292. void PushChevron(int nBand, LPARAM lAppValue)
  7293. {
  7294. ATLASSERT(::IsWindow(m_hWnd));
  7295. ::SendMessage(m_hWnd, RB_PUSHCHEVRON, nBand, lAppValue);
  7296. }
  7297. #endif // (_WIN32_IE >= 0x0500) && !defined(_WIN32_WCE)
  7298. // Extra operations
  7299. #if (_WIN32_IE >= 0x0400)
  7300. void LockBands(bool bLock)
  7301. {
  7302. int nBandCount = GetBandCount();
  7303. for(int i =0; i < nBandCount; i++)
  7304. {
  7305. REBARBANDINFO rbbi = { RunTimeHelper::SizeOf_REBARBANDINFO() };
  7306. rbbi.fMask = RBBIM_STYLE;
  7307. BOOL bRet = GetBandInfo(i, &rbbi);
  7308. ATLASSERT(bRet);
  7309. if((rbbi.fStyle & RBBS_GRIPPERALWAYS) == 0)
  7310. {
  7311. rbbi.fStyle |= RBBS_GRIPPERALWAYS;
  7312. bRet = SetBandInfo(i, &rbbi);
  7313. ATLASSERT(bRet);
  7314. rbbi.fStyle &= ~RBBS_GRIPPERALWAYS;
  7315. }
  7316. if(bLock)
  7317. rbbi.fStyle |= RBBS_NOGRIPPER;
  7318. else
  7319. rbbi.fStyle &= ~RBBS_NOGRIPPER;
  7320. bRet = SetBandInfo(i, &rbbi);
  7321. ATLASSERT(bRet);
  7322. }
  7323. }
  7324. #endif // (_WIN32_IE >= 0x0400)
  7325. #if (_WIN32_WINNT >= 0x0600)
  7326. BOOL SetBandWidth(int nBand, int cxWidth)
  7327. {
  7328. ATLASSERT(::IsWindow(m_hWnd));
  7329. return (BOOL)::SendMessage(m_hWnd, RB_SETBANDWIDTH, nBand, cxWidth);
  7330. }
  7331. #endif // (_WIN32_WINNT >= 0x0600)
  7332. };
  7333. typedef CReBarCtrlT<ATL::CWindow> CReBarCtrl;
  7334. ///////////////////////////////////////////////////////////////////////////////
  7335. // CComboBoxEx
  7336. #ifndef _WIN32_WCE
  7337. template <class TBase>
  7338. class CComboBoxExT : public CComboBoxT< TBase >
  7339. {
  7340. public:
  7341. // Constructors
  7342. CComboBoxExT(HWND hWnd = NULL) : CComboBoxT< TBase >(hWnd)
  7343. { }
  7344. CComboBoxExT< TBase >& operator =(HWND hWnd)
  7345. {
  7346. m_hWnd = hWnd;
  7347. return *this;
  7348. }
  7349. HWND Create(HWND hWndParent, ATL::_U_RECT rect = NULL, LPCTSTR szWindowName = NULL,
  7350. DWORD dwStyle = 0, DWORD dwExStyle = 0,
  7351. ATL::_U_MENUorID MenuOrID = 0U, LPVOID lpCreateParam = NULL)
  7352. {
  7353. return TBase::Create(GetWndClassName(), hWndParent, rect.m_lpRect, szWindowName, dwStyle, dwExStyle, MenuOrID.m_hMenu, lpCreateParam);
  7354. }
  7355. // Attributes
  7356. static LPCTSTR GetWndClassName()
  7357. {
  7358. return WC_COMBOBOXEX;
  7359. }
  7360. CImageList GetImageList() const
  7361. {
  7362. ATLASSERT(::IsWindow(m_hWnd));
  7363. return CImageList((HIMAGELIST)::SendMessage(m_hWnd, CBEM_GETIMAGELIST, 0, 0L));
  7364. }
  7365. CImageList SetImageList(HIMAGELIST hImageList)
  7366. {
  7367. ATLASSERT(::IsWindow(m_hWnd));
  7368. return CImageList((HIMAGELIST)::SendMessage(m_hWnd, CBEM_SETIMAGELIST, 0, (LPARAM)hImageList));
  7369. }
  7370. #if (_WIN32_IE >= 0x0400)
  7371. DWORD GetExtendedStyle() const
  7372. {
  7373. ATLASSERT(::IsWindow(m_hWnd));
  7374. return (DWORD)::SendMessage(m_hWnd, CBEM_GETEXTENDEDSTYLE, 0, 0L);
  7375. }
  7376. DWORD SetExtendedStyle(DWORD dwExMask, DWORD dwExStyle)
  7377. {
  7378. ATLASSERT(::IsWindow(m_hWnd));
  7379. return (DWORD)::SendMessage(m_hWnd, CBEM_SETEXTENDEDSTYLE, dwExMask, dwExStyle);
  7380. }
  7381. BOOL GetUnicodeFormat() const
  7382. {
  7383. ATLASSERT(::IsWindow(m_hWnd));
  7384. return (BOOL)::SendMessage(m_hWnd, CBEM_GETUNICODEFORMAT, 0, 0L);
  7385. }
  7386. BOOL SetUnicodeFormat(BOOL bUnicode = TRUE)
  7387. {
  7388. ATLASSERT(::IsWindow(m_hWnd));
  7389. return (BOOL)::SendMessage(m_hWnd, CBEM_SETUNICODEFORMAT, bUnicode, 0L);
  7390. }
  7391. #endif // (_WIN32_IE >= 0x0400)
  7392. #if (_WIN32_WINNT >= 0x0501)
  7393. void SetWindowTheme(LPCWSTR lpstrTheme)
  7394. {
  7395. ATLASSERT(::IsWindow(m_hWnd));
  7396. ::SendMessage(m_hWnd, CBEM_SETWINDOWTHEME, 0, (LPARAM)lpstrTheme);
  7397. }
  7398. #endif // (_WIN32_WINNT >= 0x0501)
  7399. // Operations
  7400. int InsertItem(const COMBOBOXEXITEM* lpcCBItem)
  7401. {
  7402. ATLASSERT(::IsWindow(m_hWnd));
  7403. return (int)::SendMessage(m_hWnd, CBEM_INSERTITEM, 0, (LPARAM)lpcCBItem);
  7404. }
  7405. int InsertItem(UINT nMask, int nIndex, LPCTSTR lpszItem, int nImage, int nSelImage,
  7406. int iIndent, int iOverlay, LPARAM lParam)
  7407. {
  7408. ATLASSERT(::IsWindow(m_hWnd));
  7409. COMBOBOXEXITEM cbex = { 0 };
  7410. cbex.mask = nMask;
  7411. cbex.iItem = nIndex;
  7412. cbex.pszText = (LPTSTR) lpszItem;
  7413. cbex.iImage = nImage;
  7414. cbex.iSelectedImage = nSelImage;
  7415. cbex.iIndent = iIndent;
  7416. cbex.iOverlay = iOverlay;
  7417. cbex.lParam = lParam;
  7418. return (int)::SendMessage(m_hWnd, CBEM_INSERTITEM, 0, (LPARAM)&cbex);
  7419. }
  7420. int InsertItem(int nIndex, LPCTSTR lpszItem, int nImage, int nSelImage, int iIndent, LPARAM lParam = 0)
  7421. {
  7422. ATLASSERT(::IsWindow(m_hWnd));
  7423. COMBOBOXEXITEM cbex = { 0 };
  7424. cbex.mask = CBEIF_TEXT | CBEIF_IMAGE | CBEIF_SELECTEDIMAGE | CBEIF_INDENT | CBEIF_LPARAM;
  7425. cbex.iItem = nIndex;
  7426. cbex.pszText = (LPTSTR) lpszItem;
  7427. cbex.iImage = nImage;
  7428. cbex.iSelectedImage = nSelImage;
  7429. cbex.iIndent = iIndent;
  7430. cbex.lParam = lParam;
  7431. return (int)::SendMessage(m_hWnd, CBEM_INSERTITEM, 0, (LPARAM)&cbex);
  7432. }
  7433. int AddItem(UINT nMask, LPCTSTR lpszItem, int nImage, int nSelImage, int iIndent, int iOverlay, LPARAM lParam)
  7434. {
  7435. return InsertItem(nMask, -1, lpszItem, nImage, nSelImage, iIndent, iOverlay, lParam);
  7436. }
  7437. int AddItem(LPCTSTR lpszItem, int nImage, int nSelImage, int iIndent, LPARAM lParam = 0)
  7438. {
  7439. return InsertItem(-1, lpszItem, nImage, nSelImage, iIndent, lParam);
  7440. }
  7441. int DeleteItem(int nIndex)
  7442. {
  7443. ATLASSERT(::IsWindow(m_hWnd));
  7444. return (int)::SendMessage(m_hWnd, CBEM_DELETEITEM, nIndex, 0L);
  7445. }
  7446. BOOL GetItem(PCOMBOBOXEXITEM pCBItem) const
  7447. {
  7448. ATLASSERT(::IsWindow(m_hWnd));
  7449. return (BOOL)::SendMessage(m_hWnd, CBEM_GETITEM, 0, (LPARAM)pCBItem);
  7450. }
  7451. BOOL SetItem(const COMBOBOXEXITEM* lpcCBItem)
  7452. {
  7453. ATLASSERT(::IsWindow(m_hWnd));
  7454. return (BOOL)::SendMessage(m_hWnd, CBEM_SETITEM, 0, (LPARAM)lpcCBItem);
  7455. }
  7456. int SetItem(int nIndex, UINT nMask, LPCTSTR lpszItem, int nImage, int nSelImage,
  7457. int iIndent, int iOverlay, LPARAM lParam)
  7458. {
  7459. ATLASSERT(::IsWindow(m_hWnd));
  7460. COMBOBOXEXITEM cbex = { 0 };
  7461. cbex.mask = nMask;
  7462. cbex.iItem = nIndex;
  7463. cbex.pszText = (LPTSTR) lpszItem;
  7464. cbex.iImage = nImage;
  7465. cbex.iSelectedImage = nSelImage;
  7466. cbex.iIndent = iIndent;
  7467. cbex.iOverlay = iOverlay;
  7468. cbex.lParam = lParam;
  7469. return (int)::SendMessage(m_hWnd, CBEM_SETITEM, 0, (LPARAM)&cbex);
  7470. }
  7471. BOOL GetItemText(int nIndex, LPTSTR lpszItem, int nLen) const
  7472. {
  7473. ATLASSERT(::IsWindow(m_hWnd));
  7474. ATLASSERT(lpszItem != NULL);
  7475. COMBOBOXEXITEM cbex = { 0 };
  7476. cbex.mask = CBEIF_TEXT;
  7477. cbex.iItem = nIndex;
  7478. cbex.pszText = lpszItem;
  7479. cbex.cchTextMax = nLen;
  7480. return (BOOL)::SendMessage(m_hWnd, CBEM_GETITEM, 0, (LPARAM)&cbex);
  7481. }
  7482. #ifndef _ATL_NO_COM
  7483. BOOL GetItemText(int nIndex, BSTR& bstrText) const
  7484. {
  7485. USES_CONVERSION;
  7486. ATLASSERT(::IsWindow(m_hWnd));
  7487. ATLASSERT(bstrText == NULL);
  7488. COMBOBOXEXITEM cbex = { 0 };
  7489. cbex.mask = CBEIF_TEXT;
  7490. cbex.iItem = nIndex;
  7491. LPTSTR lpstrText = NULL;
  7492. BOOL bRet = FALSE;
  7493. for(int nLen = 256; ; nLen *= 2)
  7494. {
  7495. ATLTRY(lpstrText = new TCHAR[nLen]);
  7496. if(lpstrText == NULL)
  7497. break;
  7498. lpstrText[0] = NULL;
  7499. cbex.pszText = lpstrText;
  7500. cbex.cchTextMax = nLen;
  7501. bRet = (BOOL)::SendMessage(m_hWnd, CBEM_GETITEM, 0, (LPARAM)&cbex);
  7502. if(!bRet || (lstrlen(cbex.pszText) < nLen - 1))
  7503. break;
  7504. delete [] lpstrText;
  7505. lpstrText = NULL;
  7506. }
  7507. if(lpstrText != NULL)
  7508. {
  7509. if(bRet)
  7510. bstrText = ::SysAllocString(T2OLE(lpstrText));
  7511. delete [] lpstrText;
  7512. }
  7513. return (bstrText != NULL) ? TRUE : FALSE;
  7514. }
  7515. #endif // !_ATL_NO_COM
  7516. #if defined(_WTL_USE_CSTRING) || defined(__ATLSTR_H__)
  7517. BOOL GetItemText(int nIndex, _CSTRING_NS::CString& strText) const
  7518. {
  7519. ATLASSERT(::IsWindow(m_hWnd));
  7520. COMBOBOXEXITEM cbex = { 0 };
  7521. cbex.mask = CBEIF_TEXT;
  7522. cbex.iItem = nIndex;
  7523. strText.Empty();
  7524. BOOL bRet = FALSE;
  7525. for(int nLen = 256; ; nLen *= 2)
  7526. {
  7527. cbex.pszText = strText.GetBufferSetLength(nLen);
  7528. if(cbex.pszText == NULL)
  7529. {
  7530. bRet = FALSE;
  7531. break;
  7532. }
  7533. cbex.cchTextMax = nLen;
  7534. bRet = (BOOL)::SendMessage(m_hWnd, CBEM_GETITEM, 0, (LPARAM)&cbex);
  7535. if(!bRet || (lstrlen(cbex.pszText) < nLen - 1))
  7536. break;
  7537. }
  7538. strText.ReleaseBuffer();
  7539. return bRet;
  7540. }
  7541. #endif // defined(_WTL_USE_CSTRING) || defined(__ATLSTR_H__)
  7542. BOOL SetItemText(int nIndex, LPCTSTR lpszItem)
  7543. {
  7544. ATLASSERT(::IsWindow(m_hWnd));
  7545. return SetItem(nIndex, CBEIF_TEXT, lpszItem, 0, 0, 0, 0, 0);
  7546. }
  7547. CComboBox GetComboCtrl() const
  7548. {
  7549. ATLASSERT(::IsWindow(m_hWnd));
  7550. return CComboBox((HWND)::SendMessage(m_hWnd, CBEM_GETCOMBOCONTROL, 0, 0L));
  7551. }
  7552. CEdit GetEditCtrl() const
  7553. {
  7554. ATLASSERT(::IsWindow(m_hWnd));
  7555. return CEdit((HWND)::SendMessage(m_hWnd, CBEM_GETEDITCONTROL, 0, 0L));
  7556. }
  7557. BOOL HasEditChanged() const
  7558. {
  7559. ATLASSERT(::IsWindow(m_hWnd));
  7560. return (BOOL)::SendMessage(m_hWnd, CBEM_HASEDITCHANGED, 0, 0L);
  7561. }
  7562. // Non-functional
  7563. int AddString(LPCTSTR /*lpszItem*/)
  7564. {
  7565. ATLASSERT(FALSE); // Not available in CComboBoxEx; use InsertItem
  7566. return 0;
  7567. }
  7568. int InsertString(int /*nIndex*/, LPCTSTR /*lpszString*/)
  7569. {
  7570. ATLASSERT(FALSE); // Not available in CComboBoxEx; use InsertItem
  7571. return 0;
  7572. }
  7573. int Dir(UINT /*attr*/, LPCTSTR /*lpszWildCard*/)
  7574. {
  7575. ATLASSERT(FALSE); // Not available in CComboBoxEx
  7576. return 0;
  7577. }
  7578. int FindString(int /*nStartAfter*/, LPCTSTR /*lpszString*/) const
  7579. {
  7580. ATLASSERT(FALSE); // Not available in CComboBoxEx; try FindStringExact
  7581. return 0;
  7582. }
  7583. };
  7584. typedef CComboBoxExT<ATL::CWindow> CComboBoxEx;
  7585. #endif // !_WIN32_WCE
  7586. ///////////////////////////////////////////////////////////////////////////////
  7587. // CMonthCalendarCtrl
  7588. template <class TBase>
  7589. class CMonthCalendarCtrlT : public TBase
  7590. {
  7591. public:
  7592. // Constructors
  7593. CMonthCalendarCtrlT(HWND hWnd = NULL) : TBase(hWnd)
  7594. { }
  7595. CMonthCalendarCtrlT< TBase >& operator =(HWND hWnd)
  7596. {
  7597. m_hWnd = hWnd;
  7598. return *this;
  7599. }
  7600. HWND Create(HWND hWndParent, ATL::_U_RECT rect = NULL, LPCTSTR szWindowName = NULL,
  7601. DWORD dwStyle = 0, DWORD dwExStyle = 0,
  7602. ATL::_U_MENUorID MenuOrID = 0U, LPVOID lpCreateParam = NULL)
  7603. {
  7604. return TBase::Create(GetWndClassName(), hWndParent, rect.m_lpRect, szWindowName, dwStyle, dwExStyle, MenuOrID.m_hMenu, lpCreateParam);
  7605. }
  7606. // Attributes
  7607. static LPCTSTR GetWndClassName()
  7608. {
  7609. return MONTHCAL_CLASS;
  7610. }
  7611. COLORREF GetColor(int nColorType) const
  7612. {
  7613. ATLASSERT(::IsWindow(m_hWnd));
  7614. return (COLORREF)::SendMessage(m_hWnd, MCM_GETCOLOR, nColorType, 0L);
  7615. }
  7616. COLORREF SetColor(int nColorType, COLORREF clr)
  7617. {
  7618. ATLASSERT(::IsWindow(m_hWnd));
  7619. return (COLORREF)::SendMessage(m_hWnd, MCM_SETCOLOR, nColorType, clr);
  7620. }
  7621. BOOL GetCurSel(LPSYSTEMTIME lpSysTime) const
  7622. {
  7623. ATLASSERT(::IsWindow(m_hWnd));
  7624. return (BOOL)::SendMessage(m_hWnd, MCM_GETCURSEL, 0, (LPARAM)lpSysTime);
  7625. }
  7626. BOOL SetCurSel(LPSYSTEMTIME lpSysTime)
  7627. {
  7628. ATLASSERT(::IsWindow(m_hWnd));
  7629. return (BOOL)::SendMessage(m_hWnd, MCM_SETCURSEL, 0, (LPARAM)lpSysTime);
  7630. }
  7631. int GetFirstDayOfWeek(BOOL* pbLocaleVal = NULL) const
  7632. {
  7633. ATLASSERT(::IsWindow(m_hWnd));
  7634. DWORD dwRet = (DWORD)::SendMessage(m_hWnd, MCM_GETFIRSTDAYOFWEEK, 0, 0L);
  7635. if(pbLocaleVal != NULL)
  7636. *pbLocaleVal = (BOOL)HIWORD(dwRet);
  7637. return (int)(short)LOWORD(dwRet);
  7638. }
  7639. int SetFirstDayOfWeek(int nDay, BOOL* pbLocaleVal = NULL)
  7640. {
  7641. ATLASSERT(::IsWindow(m_hWnd));
  7642. DWORD dwRet = (DWORD)::SendMessage(m_hWnd, MCM_SETFIRSTDAYOFWEEK, 0, nDay);
  7643. if(pbLocaleVal != NULL)
  7644. *pbLocaleVal = (BOOL)HIWORD(dwRet);
  7645. return (int)(short)LOWORD(dwRet);
  7646. }
  7647. int GetMaxSelCount() const
  7648. {
  7649. ATLASSERT(::IsWindow(m_hWnd));
  7650. return (int)::SendMessage(m_hWnd, MCM_GETMAXSELCOUNT, 0, 0L);
  7651. }
  7652. BOOL SetMaxSelCount(int nMax)
  7653. {
  7654. ATLASSERT(::IsWindow(m_hWnd));
  7655. return (BOOL)::SendMessage(m_hWnd, MCM_SETMAXSELCOUNT, nMax, 0L);
  7656. }
  7657. int GetMonthDelta() const
  7658. {
  7659. ATLASSERT(::IsWindow(m_hWnd));
  7660. return (int)::SendMessage(m_hWnd, MCM_GETMONTHDELTA, 0, 0L);
  7661. }
  7662. int SetMonthDelta(int nDelta)
  7663. {
  7664. ATLASSERT(::IsWindow(m_hWnd));
  7665. return (int)::SendMessage(m_hWnd, MCM_SETMONTHDELTA, nDelta, 0L);
  7666. }
  7667. DWORD GetRange(LPSYSTEMTIME lprgSysTimeArray) const
  7668. {
  7669. ATLASSERT(::IsWindow(m_hWnd));
  7670. return (DWORD)::SendMessage(m_hWnd, MCM_GETRANGE, 0, (LPARAM)lprgSysTimeArray);
  7671. }
  7672. BOOL SetRange(DWORD dwFlags, LPSYSTEMTIME lprgSysTimeArray)
  7673. {
  7674. ATLASSERT(::IsWindow(m_hWnd));
  7675. return (BOOL)::SendMessage(m_hWnd, MCM_SETRANGE, dwFlags, (LPARAM)lprgSysTimeArray);
  7676. }
  7677. BOOL GetSelRange(LPSYSTEMTIME lprgSysTimeArray) const
  7678. {
  7679. ATLASSERT(::IsWindow(m_hWnd));
  7680. return (BOOL)::SendMessage(m_hWnd, MCM_GETSELRANGE, 0, (LPARAM)lprgSysTimeArray);
  7681. }
  7682. BOOL SetSelRange(LPSYSTEMTIME lprgSysTimeArray)
  7683. {
  7684. ATLASSERT(::IsWindow(m_hWnd));
  7685. return (BOOL)::SendMessage(m_hWnd, MCM_SETSELRANGE, 0, (LPARAM)lprgSysTimeArray);
  7686. }
  7687. BOOL GetToday(LPSYSTEMTIME lpSysTime) const
  7688. {
  7689. ATLASSERT(::IsWindow(m_hWnd));
  7690. return (BOOL)::SendMessage(m_hWnd, MCM_GETTODAY, 0, (LPARAM)lpSysTime);
  7691. }
  7692. void SetToday(LPSYSTEMTIME lpSysTime)
  7693. {
  7694. ATLASSERT(::IsWindow(m_hWnd));
  7695. ::SendMessage(m_hWnd, MCM_SETTODAY, 0, (LPARAM)lpSysTime);
  7696. }
  7697. BOOL GetMinReqRect(LPRECT lpRectInfo) const
  7698. {
  7699. ATLASSERT(::IsWindow(m_hWnd));
  7700. return (BOOL)::SendMessage(m_hWnd, MCM_GETMINREQRECT, 0, (LPARAM)lpRectInfo);
  7701. }
  7702. int GetMaxTodayWidth() const
  7703. {
  7704. ATLASSERT(::IsWindow(m_hWnd));
  7705. return (int)::SendMessage(m_hWnd, MCM_GETMAXTODAYWIDTH, 0, 0L);
  7706. }
  7707. #if (_WIN32_IE >= 0x0400) && !defined(_WIN32_WCE)
  7708. BOOL GetUnicodeFormat() const
  7709. {
  7710. ATLASSERT(::IsWindow(m_hWnd));
  7711. return (BOOL)::SendMessage(m_hWnd, MCM_GETUNICODEFORMAT, 0, 0L);
  7712. }
  7713. BOOL SetUnicodeFormat(BOOL bUnicode = TRUE)
  7714. {
  7715. ATLASSERT(::IsWindow(m_hWnd));
  7716. return (BOOL)::SendMessage(m_hWnd, MCM_SETUNICODEFORMAT, bUnicode, 0L);
  7717. }
  7718. #endif // (_WIN32_IE >= 0x0400) && !defined(_WIN32_WCE)
  7719. #if defined(NTDDI_VERSION) && (NTDDI_VERSION >= NTDDI_LONGHORN)
  7720. DWORD GetCurrentView() const
  7721. {
  7722. ATLASSERT(::IsWindow(m_hWnd));
  7723. return (DWORD)::SendMessage(m_hWnd, MCM_GETCURRENTVIEW, 0, 0L);
  7724. }
  7725. BOOL SetCurrentView(DWORD dwView)
  7726. {
  7727. ATLASSERT(::IsWindow(m_hWnd));
  7728. return (BOOL)::SendMessage(m_hWnd, MCM_SETCURRENTVIEW, 0, dwView);
  7729. }
  7730. DWORD GetCalendarCount() const
  7731. {
  7732. ATLASSERT(::IsWindow(m_hWnd));
  7733. return (DWORD)::SendMessage(m_hWnd, MCM_GETCALENDARCOUNT, 0, 0L);
  7734. }
  7735. BOOL GetCalendarGridInfo(PMCGRIDINFO pGridInfo) const
  7736. {
  7737. ATLASSERT(::IsWindow(m_hWnd));
  7738. return (BOOL)::SendMessage(m_hWnd, MCM_GETCALENDARGRIDINFO, 0, (LPARAM)pGridInfo);
  7739. }
  7740. CALID GetCALID() const
  7741. {
  7742. ATLASSERT(::IsWindow(m_hWnd));
  7743. return (CALID)::SendMessage(m_hWnd, MCM_GETCALID, 0, 0L);
  7744. }
  7745. void SetCALID(CALID calid)
  7746. {
  7747. ATLASSERT(::IsWindow(m_hWnd));
  7748. ::SendMessage(m_hWnd, MCM_SETCALID, (LPARAM)calid, 0L);
  7749. }
  7750. int GetCalendarBorder() const
  7751. {
  7752. ATLASSERT(::IsWindow(m_hWnd));
  7753. return (int)::SendMessage(m_hWnd, MCM_GETCALENDARBORDER, 0, 0L);
  7754. }
  7755. void SetCalendarBorder(int cxyBorder, BOOL bSet = TRUE)
  7756. {
  7757. ATLASSERT(::IsWindow(m_hWnd));
  7758. ::SendMessage(m_hWnd, MCM_SETCALENDARBORDER, (WPARAM)bSet, (LPARAM)cxyBorder);
  7759. }
  7760. #endif // defined(NTDDI_VERSION) && (NTDDI_VERSION >= NTDDI_LONGHORN)
  7761. // Operations
  7762. int GetMonthRange(DWORD dwFlags, LPSYSTEMTIME lprgSysTimeArray) const
  7763. {
  7764. ATLASSERT(::IsWindow(m_hWnd));
  7765. return (int)::SendMessage(m_hWnd, MCM_GETMONTHRANGE, dwFlags, (LPARAM)lprgSysTimeArray);
  7766. }
  7767. BOOL SetDayState(int nMonths, LPMONTHDAYSTATE lpDayStateArray)
  7768. {
  7769. ATLASSERT(::IsWindow(m_hWnd));
  7770. return (BOOL)::SendMessage(m_hWnd, MCM_SETDAYSTATE, nMonths, (LPARAM)lpDayStateArray);
  7771. }
  7772. DWORD HitTest(PMCHITTESTINFO pMCHitTest) const
  7773. {
  7774. ATLASSERT(::IsWindow(m_hWnd));
  7775. return (DWORD)::SendMessage(m_hWnd, MCM_HITTEST, 0, (LPARAM)pMCHitTest);
  7776. }
  7777. #if defined(NTDDI_VERSION) && (NTDDI_VERSION >= NTDDI_LONGHORN)
  7778. void SizeRectToMin(LPRECT lpRect)
  7779. {
  7780. ATLASSERT(::IsWindow(m_hWnd));
  7781. ::SendMessage(m_hWnd, MCM_SIZERECTTOMIN, 0, (LPARAM)lpRect);
  7782. }
  7783. #endif // defined(NTDDI_VERSION) && (NTDDI_VERSION >= NTDDI_LONGHORN)
  7784. };
  7785. typedef CMonthCalendarCtrlT<ATL::CWindow> CMonthCalendarCtrl;
  7786. ///////////////////////////////////////////////////////////////////////////////
  7787. // CDateTimePickerCtrl
  7788. template <class TBase>
  7789. class CDateTimePickerCtrlT : public TBase
  7790. {
  7791. public:
  7792. // Constructors
  7793. CDateTimePickerCtrlT(HWND hWnd = NULL) : TBase(hWnd)
  7794. { }
  7795. CDateTimePickerCtrlT< TBase >& operator =(HWND hWnd)
  7796. {
  7797. m_hWnd = hWnd;
  7798. return *this;
  7799. }
  7800. HWND Create(HWND hWndParent, ATL::_U_RECT rect = NULL, LPCTSTR szWindowName = NULL,
  7801. DWORD dwStyle = 0, DWORD dwExStyle = 0,
  7802. ATL::_U_MENUorID MenuOrID = 0U, LPVOID lpCreateParam = NULL)
  7803. {
  7804. return TBase::Create(GetWndClassName(), hWndParent, rect.m_lpRect, szWindowName, dwStyle, dwExStyle, MenuOrID.m_hMenu, lpCreateParam);
  7805. }
  7806. // Operations
  7807. static LPCTSTR GetWndClassName()
  7808. {
  7809. return DATETIMEPICK_CLASS;
  7810. }
  7811. BOOL SetFormat(LPCTSTR lpszFormat)
  7812. {
  7813. ATLASSERT(::IsWindow(m_hWnd));
  7814. return (BOOL)::SendMessage(m_hWnd, DTM_SETFORMAT, 0, (LPARAM)lpszFormat);
  7815. }
  7816. COLORREF GetMonthCalColor(int nColorType) const
  7817. {
  7818. ATLASSERT(::IsWindow(m_hWnd));
  7819. return (COLORREF)::SendMessage(m_hWnd, DTM_GETMCCOLOR, nColorType, 0L);
  7820. }
  7821. COLORREF SetMonthCalColor(int nColorType, COLORREF clr)
  7822. {
  7823. ATLASSERT(::IsWindow(m_hWnd));
  7824. return (COLORREF)::SendMessage(m_hWnd, DTM_SETMCCOLOR, nColorType, clr);
  7825. }
  7826. DWORD GetRange(LPSYSTEMTIME lpSysTimeArray) const
  7827. {
  7828. ATLASSERT(::IsWindow(m_hWnd));
  7829. return (DWORD)::SendMessage(m_hWnd, DTM_GETRANGE, 0, (LPARAM)lpSysTimeArray);
  7830. }
  7831. BOOL SetRange(DWORD dwFlags, LPSYSTEMTIME lpSysTimeArray)
  7832. {
  7833. ATLASSERT(::IsWindow(m_hWnd));
  7834. return (BOOL)::SendMessage(m_hWnd, DTM_SETRANGE, dwFlags, (LPARAM)lpSysTimeArray);
  7835. }
  7836. DWORD GetSystemTime(LPSYSTEMTIME lpSysTime) const
  7837. {
  7838. ATLASSERT(::IsWindow(m_hWnd));
  7839. return (DWORD)::SendMessage(m_hWnd, DTM_GETSYSTEMTIME, 0, (LPARAM)lpSysTime);
  7840. }
  7841. BOOL SetSystemTime(DWORD dwFlags, LPSYSTEMTIME lpSysTime)
  7842. {
  7843. ATLASSERT(::IsWindow(m_hWnd));
  7844. return (BOOL)::SendMessage(m_hWnd, DTM_SETSYSTEMTIME, dwFlags, (LPARAM)lpSysTime);
  7845. }
  7846. CMonthCalendarCtrl GetMonthCal() const
  7847. {
  7848. ATLASSERT(::IsWindow(m_hWnd));
  7849. return CMonthCalendarCtrl((HWND)::SendMessage(m_hWnd, DTM_GETMONTHCAL, 0, 0L));
  7850. }
  7851. #if (_WIN32_IE >= 0x0400)
  7852. CFontHandle GetMonthCalFont() const
  7853. {
  7854. ATLASSERT(::IsWindow(m_hWnd));
  7855. return CFontHandle((HFONT)::SendMessage(m_hWnd, DTM_GETMCFONT, 0, 0L));
  7856. }
  7857. void SetMonthCalFont(HFONT hFont, BOOL bRedraw = TRUE)
  7858. {
  7859. ATLASSERT(::IsWindow(m_hWnd));
  7860. ::SendMessage(m_hWnd, DTM_SETMCFONT, (WPARAM)hFont, MAKELPARAM(bRedraw, 0));
  7861. }
  7862. #endif // (_WIN32_IE >= 0x0400)
  7863. #if defined(NTDDI_VERSION) && (NTDDI_VERSION >= NTDDI_LONGHORN)
  7864. DWORD GetMonthCalStyle() const
  7865. {
  7866. ATLASSERT(::IsWindow(m_hWnd));
  7867. return (DWORD)::SendMessage(m_hWnd, DTM_GETMCSTYLE, 0, 0L);
  7868. }
  7869. DWORD SetMonthCalStyle(DWORD dwStyle)
  7870. {
  7871. ATLASSERT(::IsWindow(m_hWnd));
  7872. return (DWORD)::SendMessage(m_hWnd, DTM_SETMCSTYLE, 0, (LPARAM)dwStyle);
  7873. }
  7874. void GetDateTimePickerInfo(LPDATETIMEPICKERINFO lpPickerInfo) const
  7875. {
  7876. ATLASSERT(::IsWindow(m_hWnd));
  7877. ::SendMessage(m_hWnd, DTM_GETDATETIMEPICKERINFO, 0, (LPARAM)lpPickerInfo);
  7878. }
  7879. BOOL GetIdealSize(LPSIZE lpSize) const
  7880. {
  7881. ATLASSERT(::IsWindow(m_hWnd));
  7882. return (BOOL)::SendMessage(m_hWnd, DTM_GETIDEALSIZE, 0, (LPARAM)lpSize);
  7883. }
  7884. void CloseMonthCal()
  7885. {
  7886. ATLASSERT(::IsWindow(m_hWnd));
  7887. ::SendMessage(m_hWnd, DTM_CLOSEMONTHCAL, 0, 0L);
  7888. }
  7889. #endif // defined(NTDDI_VERSION) && (NTDDI_VERSION >= NTDDI_LONGHORN)
  7890. };
  7891. typedef CDateTimePickerCtrlT<ATL::CWindow> CDateTimePickerCtrl;
  7892. ///////////////////////////////////////////////////////////////////////////////
  7893. // CFlatScrollBarImpl - support for flat scroll bars
  7894. #if (_WIN32_IE >= 0x0400) && !defined(_WIN32_WCE)
  7895. template <class T>
  7896. class CFlatScrollBarImpl
  7897. {
  7898. public:
  7899. // Initialization
  7900. BOOL FlatSB_Initialize()
  7901. {
  7902. T* pT = static_cast<T*>(this);
  7903. ATLASSERT(::IsWindow(pT->m_hWnd));
  7904. return ::InitializeFlatSB(pT->m_hWnd);
  7905. }
  7906. HRESULT FlatSB_Uninitialize()
  7907. {
  7908. T* pT = static_cast<T*>(this);
  7909. ATLASSERT(::IsWindow(pT->m_hWnd));
  7910. return ::UninitializeFlatSB(pT->m_hWnd);
  7911. }
  7912. // Flat scroll bar properties
  7913. BOOL FlatSB_GetScrollProp(UINT uIndex, LPINT lpnValue) const
  7914. {
  7915. const T* pT = static_cast<const T*>(this);
  7916. ATLASSERT(::IsWindow(pT->m_hWnd));
  7917. return ::FlatSB_GetScrollProp(pT->m_hWnd, uIndex, lpnValue);
  7918. }
  7919. BOOL FlatSB_SetScrollProp(UINT uIndex, int nValue, BOOL bRedraw = TRUE)
  7920. {
  7921. T* pT = static_cast<T*>(this);
  7922. ATLASSERT(::IsWindow(pT->m_hWnd));
  7923. return ::FlatSB_SetScrollProp(pT->m_hWnd, uIndex, nValue, bRedraw);
  7924. }
  7925. // Attributes
  7926. int FlatSB_GetScrollPos(int nBar) const
  7927. {
  7928. const T* pT = static_cast<const T*>(this);
  7929. ATLASSERT(::IsWindow(pT->m_hWnd));
  7930. return ::FlatSB_GetScrollPos(pT->m_hWnd, nBar);
  7931. }
  7932. int FlatSB_SetScrollPos(int nBar, int nPos, BOOL bRedraw = TRUE)
  7933. {
  7934. T* pT = static_cast<T*>(this);
  7935. ATLASSERT(::IsWindow(pT->m_hWnd));
  7936. return ::FlatSB_SetScrollPos(pT->m_hWnd, nBar, nPos, bRedraw);
  7937. }
  7938. BOOL FlatSB_GetScrollRange(int nBar, LPINT lpMinPos, LPINT lpMaxPos) const
  7939. {
  7940. const T* pT = static_cast<const T*>(this);
  7941. ATLASSERT(::IsWindow(pT->m_hWnd));
  7942. return ::FlatSB_GetScrollRange(pT->m_hWnd, nBar, lpMinPos, lpMaxPos);
  7943. }
  7944. BOOL FlatSB_SetScrollRange(int nBar, int nMinPos, int nMaxPos, BOOL bRedraw = TRUE)
  7945. {
  7946. T* pT = static_cast<T*>(this);
  7947. ATLASSERT(::IsWindow(pT->m_hWnd));
  7948. return ::FlatSB_SetScrollRange(pT->m_hWnd, nBar, nMinPos, nMaxPos, bRedraw);
  7949. }
  7950. BOOL FlatSB_GetScrollInfo(int nBar, LPSCROLLINFO lpScrollInfo) const
  7951. {
  7952. const T* pT = static_cast<const T*>(this);
  7953. ATLASSERT(::IsWindow(pT->m_hWnd));
  7954. return ::FlatSB_GetScrollInfo(pT->m_hWnd, nBar, lpScrollInfo);
  7955. }
  7956. int FlatSB_SetScrollInfo(int nBar, LPSCROLLINFO lpScrollInfo, BOOL bRedraw = TRUE)
  7957. {
  7958. T* pT = static_cast<T*>(this);
  7959. ATLASSERT(::IsWindow(pT->m_hWnd));
  7960. return ::FlatSB_SetScrollInfo(pT->m_hWnd, nBar, lpScrollInfo, bRedraw);
  7961. }
  7962. // Operations
  7963. BOOL FlatSB_ShowScrollBar(UINT nBar, BOOL bShow = TRUE)
  7964. {
  7965. T* pT = static_cast<T*>(this);
  7966. ATLASSERT(::IsWindow(pT->m_hWnd));
  7967. return ::FlatSB_ShowScrollBar(pT->m_hWnd, nBar, bShow);
  7968. }
  7969. BOOL FlatSB_EnableScrollBar(UINT uSBFlags, UINT uArrowFlags = ESB_ENABLE_BOTH)
  7970. {
  7971. T* pT = static_cast<T*>(this);
  7972. ATLASSERT(::IsWindow(pT->m_hWnd));
  7973. return ::FlatSB_EnableScrollBar(pT->m_hWnd, uSBFlags, uArrowFlags);
  7974. }
  7975. };
  7976. template <class TBase>
  7977. class CFlatScrollBarT : public TBase, public CFlatScrollBarImpl<CFlatScrollBarT< TBase > >
  7978. {
  7979. public:
  7980. CFlatScrollBarT(HWND hWnd = NULL) : TBase(hWnd)
  7981. { }
  7982. CFlatScrollBarT< TBase >& operator =(HWND hWnd)
  7983. {
  7984. m_hWnd = hWnd;
  7985. return *this;
  7986. }
  7987. };
  7988. typedef CFlatScrollBarT<ATL::CWindow> CFlatScrollBar;
  7989. #endif // (_WIN32_IE >= 0x0400) && !defined(_WIN32_WCE)
  7990. ///////////////////////////////////////////////////////////////////////////////
  7991. // CIPAddressCtrl
  7992. #if (_WIN32_IE >= 0x0400)
  7993. template <class TBase>
  7994. class CIPAddressCtrlT : public TBase
  7995. {
  7996. public:
  7997. // Constructors
  7998. CIPAddressCtrlT(HWND hWnd = NULL) : TBase(hWnd)
  7999. { }
  8000. CIPAddressCtrlT< TBase >& operator =(HWND hWnd)
  8001. {
  8002. m_hWnd = hWnd;
  8003. return *this;
  8004. }
  8005. HWND Create(HWND hWndParent, ATL::_U_RECT rect = NULL, LPCTSTR szWindowName = NULL,
  8006. DWORD dwStyle = 0, DWORD dwExStyle = 0,
  8007. ATL::_U_MENUorID MenuOrID = 0U, LPVOID lpCreateParam = NULL)
  8008. {
  8009. return TBase::Create(GetWndClassName(), hWndParent, rect.m_lpRect, szWindowName, dwStyle, dwExStyle, MenuOrID.m_hMenu, lpCreateParam);
  8010. }
  8011. // Atteributes
  8012. static LPCTSTR GetWndClassName()
  8013. {
  8014. return WC_IPADDRESS;
  8015. }
  8016. BOOL IsBlank() const
  8017. {
  8018. ATLASSERT(::IsWindow(m_hWnd));
  8019. return (BOOL)::SendMessage(m_hWnd, IPM_ISBLANK, 0, 0L);
  8020. }
  8021. int GetAddress(LPDWORD lpdwAddress) const
  8022. {
  8023. ATLASSERT(::IsWindow(m_hWnd));
  8024. return (int)::SendMessage(m_hWnd, IPM_GETADDRESS, 0, (LPARAM)lpdwAddress);
  8025. }
  8026. void SetAddress(DWORD dwAddress)
  8027. {
  8028. ATLASSERT(::IsWindow(m_hWnd));
  8029. ::SendMessage(m_hWnd, IPM_SETADDRESS, 0, dwAddress);
  8030. }
  8031. void ClearAddress()
  8032. {
  8033. ATLASSERT(::IsWindow(m_hWnd));
  8034. ::SendMessage(m_hWnd, IPM_CLEARADDRESS, 0, 0L);
  8035. }
  8036. void SetRange(int nField, WORD wRange)
  8037. {
  8038. ATLASSERT(::IsWindow(m_hWnd));
  8039. ::SendMessage(m_hWnd, IPM_SETRANGE, nField, wRange);
  8040. }
  8041. void SetRange(int nField, BYTE nMin, BYTE nMax)
  8042. {
  8043. ATLASSERT(::IsWindow(m_hWnd));
  8044. ::SendMessage(m_hWnd, IPM_SETRANGE, nField, MAKEIPRANGE(nMin, nMax));
  8045. }
  8046. void SetFocus(int nField)
  8047. {
  8048. ATLASSERT(::IsWindow(m_hWnd));
  8049. ::SendMessage(m_hWnd, IPM_SETFOCUS, nField, 0L);
  8050. }
  8051. };
  8052. typedef CIPAddressCtrlT<ATL::CWindow> CIPAddressCtrl;
  8053. #endif // (_WIN32_IE >= 0x0400)
  8054. ///////////////////////////////////////////////////////////////////////////////
  8055. // CPagerCtrl
  8056. #if (_WIN32_IE >= 0x0400) && !defined(_WIN32_WCE)
  8057. template <class TBase>
  8058. class CPagerCtrlT : public TBase
  8059. {
  8060. public:
  8061. // Constructors
  8062. CPagerCtrlT(HWND hWnd = NULL) : TBase(hWnd)
  8063. { }
  8064. CPagerCtrlT< TBase >& operator =(HWND hWnd)
  8065. {
  8066. m_hWnd = hWnd;
  8067. return *this;
  8068. }
  8069. HWND Create(HWND hWndParent, ATL::_U_RECT rect = NULL, LPCTSTR szWindowName = NULL,
  8070. DWORD dwStyle = 0, DWORD dwExStyle = 0,
  8071. ATL::_U_MENUorID MenuOrID = 0U, LPVOID lpCreateParam = NULL)
  8072. {
  8073. return TBase::Create(GetWndClassName(), hWndParent, rect.m_lpRect, szWindowName, dwStyle, dwExStyle, MenuOrID.m_hMenu, lpCreateParam);
  8074. }
  8075. // Attributes
  8076. static LPCTSTR GetWndClassName()
  8077. {
  8078. return WC_PAGESCROLLER;
  8079. }
  8080. int GetButtonSize() const
  8081. {
  8082. ATLASSERT(::IsWindow(m_hWnd));
  8083. return (int)::SendMessage(m_hWnd, PGM_GETBUTTONSIZE, 0, 0L);
  8084. }
  8085. int SetButtonSize(int nButtonSize)
  8086. {
  8087. ATLASSERT(::IsWindow(m_hWnd));
  8088. return (int)::SendMessage(m_hWnd, PGM_SETBUTTONSIZE, 0, nButtonSize);
  8089. }
  8090. DWORD GetButtonState(int nButton) const
  8091. {
  8092. ATLASSERT(::IsWindow(m_hWnd));
  8093. ATLASSERT(nButton == PGB_TOPORLEFT || nButton == PGB_BOTTOMORRIGHT);
  8094. return (DWORD)::SendMessage(m_hWnd, PGM_GETBUTTONSTATE, 0, nButton);
  8095. }
  8096. COLORREF GetBkColor() const
  8097. {
  8098. ATLASSERT(::IsWindow(m_hWnd));
  8099. return (COLORREF)::SendMessage(m_hWnd, PGM_GETBKCOLOR, 0, 0L);
  8100. }
  8101. COLORREF SetBkColor(COLORREF clrBk)
  8102. {
  8103. ATLASSERT(::IsWindow(m_hWnd));
  8104. return (COLORREF)::SendMessage(m_hWnd, PGM_SETBKCOLOR, 0, (LPARAM)clrBk);
  8105. }
  8106. int GetBorder() const
  8107. {
  8108. ATLASSERT(::IsWindow(m_hWnd));
  8109. return (int)::SendMessage(m_hWnd, PGM_GETBORDER, 0, 0L);
  8110. }
  8111. int SetBorder(int nBorderSize)
  8112. {
  8113. ATLASSERT(::IsWindow(m_hWnd));
  8114. return (int)::SendMessage(m_hWnd, PGM_SETBORDER, 0, nBorderSize);
  8115. }
  8116. int GetPos() const
  8117. {
  8118. ATLASSERT(::IsWindow(m_hWnd));
  8119. return (int)::SendMessage(m_hWnd, PGM_GETPOS, 0, 0L);
  8120. }
  8121. int SetPos(int nPos)
  8122. {
  8123. ATLASSERT(::IsWindow(m_hWnd));
  8124. return (int)::SendMessage(m_hWnd, PGM_SETPOS, 0, nPos);
  8125. }
  8126. // Operations
  8127. void SetChild(HWND hWndChild)
  8128. {
  8129. ATLASSERT(::IsWindow(m_hWnd));
  8130. ::SendMessage(m_hWnd, PGM_SETCHILD, 0, (LPARAM)hWndChild);
  8131. }
  8132. void ForwardMouse(BOOL bForward = TRUE)
  8133. {
  8134. ATLASSERT(::IsWindow(m_hWnd));
  8135. ::SendMessage(m_hWnd, PGM_FORWARDMOUSE, bForward, 0L);
  8136. }
  8137. void RecalcSize()
  8138. {
  8139. ATLASSERT(::IsWindow(m_hWnd));
  8140. ::SendMessage(m_hWnd, PGM_RECALCSIZE, 0, 0L);
  8141. }
  8142. void GetDropTarget(IDropTarget** ppDropTarget)
  8143. {
  8144. ATLASSERT(::IsWindow(m_hWnd));
  8145. ATLASSERT(ppDropTarget != NULL);
  8146. ::SendMessage(m_hWnd, PGM_GETDROPTARGET, 0, (LPARAM)ppDropTarget);
  8147. }
  8148. };
  8149. typedef CPagerCtrlT<ATL::CWindow> CPagerCtrl;
  8150. #endif // (_WIN32_IE >= 0x0400) && !defined(_WIN32_WCE)
  8151. ///////////////////////////////////////////////////////////////////////////////
  8152. // CLinkCtrl - Windows SYSLINK control
  8153. #if (_WIN32_WINNT >= 0x0501) && !defined(_WIN32_WCE)
  8154. template <class TBase>
  8155. class CLinkCtrlT : public TBase
  8156. {
  8157. public:
  8158. // Constructors
  8159. CLinkCtrlT(HWND hWnd = NULL) : TBase(hWnd)
  8160. { }
  8161. CLinkCtrlT< TBase >& operator =(HWND hWnd)
  8162. {
  8163. m_hWnd = hWnd;
  8164. return *this;
  8165. }
  8166. HWND Create(HWND hWndParent, ATL::_U_RECT rect = NULL, LPCTSTR szWindowName = NULL,
  8167. DWORD dwStyle = 0, DWORD dwExStyle = 0,
  8168. ATL::_U_MENUorID MenuOrID = 0U, LPVOID lpCreateParam = NULL)
  8169. {
  8170. return TBase::Create(GetWndClassName(), hWndParent, rect.m_lpRect, szWindowName, dwStyle, dwExStyle, MenuOrID.m_hMenu, lpCreateParam);
  8171. }
  8172. // Attributes
  8173. static LPCTSTR GetWndClassName()
  8174. {
  8175. #ifdef _UNICODE
  8176. return WC_LINK;
  8177. #else // !_UNICODE
  8178. return "SysLink";
  8179. #endif // !_UNICODE
  8180. }
  8181. int GetIdealHeight(int cxMaxWidth = 0) const
  8182. {
  8183. ATLASSERT(::IsWindow(m_hWnd));
  8184. return (int)::SendMessage(m_hWnd, LM_GETIDEALHEIGHT, cxMaxWidth, 0L);
  8185. }
  8186. BOOL GetItem(PLITEM pLItem) const
  8187. {
  8188. ATLASSERT(::IsWindow(m_hWnd));
  8189. return (BOOL)::SendMessage(m_hWnd, LM_GETITEM, 0, (LPARAM)pLItem);
  8190. }
  8191. BOOL SetItem(PLITEM pLItem)
  8192. {
  8193. ATLASSERT(::IsWindow(m_hWnd));
  8194. return (BOOL)::SendMessage(m_hWnd, LM_SETITEM, 0, (LPARAM)pLItem);
  8195. }
  8196. // Vista only
  8197. int GetIdealSize(SIZE& size, int cxMaxWidth = 0) const
  8198. {
  8199. #ifndef LM_GETIDEALSIZE
  8200. const UINT LM_GETIDEALSIZE = LM_GETIDEALHEIGHT;
  8201. #endif
  8202. ATLASSERT(::IsWindow(m_hWnd));
  8203. return (int)::SendMessage(m_hWnd, LM_GETIDEALSIZE, cxMaxWidth, (LPARAM)&size);
  8204. }
  8205. // Operations
  8206. BOOL HitTest(PLHITTESTINFO pLHitTestInfo) const
  8207. {
  8208. ATLASSERT(::IsWindow(m_hWnd));
  8209. return (BOOL)::SendMessage(m_hWnd, LM_HITTEST, 0, (LPARAM)pLHitTestInfo);
  8210. }
  8211. };
  8212. typedef CLinkCtrlT<ATL::CWindow> CLinkCtrl;
  8213. #endif // (_WIN32_WINNT >= 0x0501) && !defined(_WIN32_WCE)
  8214. ///////////////////////////////////////////////////////////////////////////////
  8215. // CCustomDraw - MI class for custom-draw support
  8216. template <class T>
  8217. class CCustomDraw
  8218. {
  8219. public:
  8220. #if (_ATL_VER < 0x0700)
  8221. BOOL m_bHandledCD;
  8222. BOOL IsMsgHandled() const
  8223. {
  8224. return m_bHandledCD;
  8225. }
  8226. void SetMsgHandled(BOOL bHandled)
  8227. {
  8228. m_bHandledCD = bHandled;
  8229. }
  8230. #endif // !(_ATL_VER < 0x0700)
  8231. // Message map and handlers
  8232. BEGIN_MSG_MAP(CCustomDraw< T >)
  8233. NOTIFY_CODE_HANDLER(NM_CUSTOMDRAW, OnCustomDraw)
  8234. ALT_MSG_MAP(1)
  8235. REFLECTED_NOTIFY_CODE_HANDLER(NM_CUSTOMDRAW, OnCustomDraw)
  8236. END_MSG_MAP()
  8237. // message handler
  8238. LRESULT OnCustomDraw(int idCtrl, LPNMHDR pnmh, BOOL& bHandled)
  8239. {
  8240. T* pT = static_cast<T*>(this);
  8241. pT->SetMsgHandled(TRUE);
  8242. LPNMCUSTOMDRAW lpNMCustomDraw = (LPNMCUSTOMDRAW)pnmh;
  8243. DWORD dwRet = 0;
  8244. switch(lpNMCustomDraw->dwDrawStage)
  8245. {
  8246. case CDDS_PREPAINT:
  8247. dwRet = pT->OnPrePaint(idCtrl, lpNMCustomDraw);
  8248. break;
  8249. case CDDS_POSTPAINT:
  8250. dwRet = pT->OnPostPaint(idCtrl, lpNMCustomDraw);
  8251. break;
  8252. case CDDS_PREERASE:
  8253. dwRet = pT->OnPreErase(idCtrl, lpNMCustomDraw);
  8254. break;
  8255. case CDDS_POSTERASE:
  8256. dwRet = pT->OnPostErase(idCtrl, lpNMCustomDraw);
  8257. break;
  8258. case CDDS_ITEMPREPAINT:
  8259. dwRet = pT->OnItemPrePaint(idCtrl, lpNMCustomDraw);
  8260. break;
  8261. case CDDS_ITEMPOSTPAINT:
  8262. dwRet = pT->OnItemPostPaint(idCtrl, lpNMCustomDraw);
  8263. break;
  8264. case CDDS_ITEMPREERASE:
  8265. dwRet = pT->OnItemPreErase(idCtrl, lpNMCustomDraw);
  8266. break;
  8267. case CDDS_ITEMPOSTERASE:
  8268. dwRet = pT->OnItemPostErase(idCtrl, lpNMCustomDraw);
  8269. break;
  8270. #if (_WIN32_IE >= 0x0400)
  8271. case (CDDS_ITEMPREPAINT | CDDS_SUBITEM):
  8272. dwRet = pT->OnSubItemPrePaint(idCtrl, lpNMCustomDraw);
  8273. break;
  8274. #endif // (_WIN32_IE >= 0x0400)
  8275. default:
  8276. pT->SetMsgHandled(FALSE);
  8277. break;
  8278. }
  8279. bHandled = pT->IsMsgHandled();
  8280. return dwRet;
  8281. }
  8282. // Overrideables
  8283. DWORD OnPrePaint(int /*idCtrl*/, LPNMCUSTOMDRAW /*lpNMCustomDraw*/)
  8284. {
  8285. return CDRF_DODEFAULT;
  8286. }
  8287. DWORD OnPostPaint(int /*idCtrl*/, LPNMCUSTOMDRAW /*lpNMCustomDraw*/)
  8288. {
  8289. return CDRF_DODEFAULT;
  8290. }
  8291. DWORD OnPreErase(int /*idCtrl*/, LPNMCUSTOMDRAW /*lpNMCustomDraw*/)
  8292. {
  8293. return CDRF_DODEFAULT;
  8294. }
  8295. DWORD OnPostErase(int /*idCtrl*/, LPNMCUSTOMDRAW /*lpNMCustomDraw*/)
  8296. {
  8297. return CDRF_DODEFAULT;
  8298. }
  8299. DWORD OnItemPrePaint(int /*idCtrl*/, LPNMCUSTOMDRAW /*lpNMCustomDraw*/)
  8300. {
  8301. return CDRF_DODEFAULT;
  8302. }
  8303. DWORD OnItemPostPaint(int /*idCtrl*/, LPNMCUSTOMDRAW /*lpNMCustomDraw*/)
  8304. {
  8305. return CDRF_DODEFAULT;
  8306. }
  8307. DWORD OnItemPreErase(int /*idCtrl*/, LPNMCUSTOMDRAW /*lpNMCustomDraw*/)
  8308. {
  8309. return CDRF_DODEFAULT;
  8310. }
  8311. DWORD OnItemPostErase(int /*idCtrl*/, LPNMCUSTOMDRAW /*lpNMCustomDraw*/)
  8312. {
  8313. return CDRF_DODEFAULT;
  8314. }
  8315. #if (_WIN32_IE >= 0x0400)
  8316. DWORD OnSubItemPrePaint(int /*idCtrl*/, LPNMCUSTOMDRAW /*lpNMCustomDraw*/)
  8317. {
  8318. return CDRF_DODEFAULT;
  8319. }
  8320. #endif // (_WIN32_IE >= 0x0400)
  8321. };
  8322. // --- Windows CE common controls ---
  8323. #ifdef _WIN32_WCE
  8324. ///////////////////////////////////////////////////////////////////////////////
  8325. // CCECommandBarCtrl
  8326. template <class TBase>
  8327. class CCECommandBarCtrlT : public TBase
  8328. {
  8329. public:
  8330. // Constructors
  8331. CCECommandBarCtrlT(HWND hWnd = NULL) : TBase(hWnd) { }
  8332. CCECommandBarCtrlT< TBase >& operator=(HWND hWnd)
  8333. {
  8334. m_hWnd = hWnd;
  8335. return *this;
  8336. }
  8337. // Attributes
  8338. BOOL IsVisible() const
  8339. {
  8340. return IsWindowVisible();
  8341. }
  8342. int GetHeight() const
  8343. {
  8344. ATLASSERT(::IsWindow(m_hWnd));
  8345. return ::CommandBar_Height(m_hWnd);
  8346. }
  8347. HMENU GetMenu(WORD wButton) const
  8348. {
  8349. ATLASSERT(::IsWindow(m_hWnd));
  8350. return ::CommandBar_GetMenu(m_hWnd, wButton);
  8351. }
  8352. // Operations
  8353. HWND Create(HWND hWndParent, int nCmdBarID)
  8354. {
  8355. m_hWnd = ::CommandBar_Create(ModuleHelper::GetModuleInstance(), hWndParent, nCmdBarID);
  8356. ATLASSERT(::IsWindow(m_hWnd));
  8357. return m_hWnd;
  8358. }
  8359. void Destroy()
  8360. {
  8361. DestroyWindow();
  8362. }
  8363. BOOL Show(BOOL bShow = TRUE)
  8364. {
  8365. ATLASSERT(::IsWindow(m_hWnd));
  8366. return ::CommandBar_Show(m_hWnd, bShow);
  8367. }
  8368. BOOL DrawMenuBar(WORD wButton)
  8369. {
  8370. ATLASSERT(::IsWindow(m_hWnd));
  8371. return ::CommandBar_DrawMenuBar(m_hWnd, wButton);
  8372. }
  8373. BOOL AddAdornments(DWORD dwFlags = 0)
  8374. {
  8375. ATLASSERT(::IsWindow(m_hWnd));
  8376. return ::CommandBar_AddAdornments(m_hWnd, dwFlags, 0);
  8377. }
  8378. int AddBitmap(int nBitmapID, int nNumImages)
  8379. {
  8380. ATLASSERT(::IsWindow(m_hWnd));
  8381. return ::CommandBar_AddBitmap(m_hWnd, ModuleHelper::GetResourceInstance(), nBitmapID, nNumImages, 16, 16);
  8382. }
  8383. BOOL AddButtons(UINT uNumButtons, LPTBBUTTON lpButtons)
  8384. {
  8385. ATLASSERT(::IsWindow(m_hWnd));
  8386. return CommandBar_AddButtons(m_hWnd, uNumButtons, lpButtons);
  8387. }
  8388. BOOL AddToolTips(UINT uNumToolTips, LPTSTR lpToolTips)
  8389. {
  8390. ATLASSERT(::IsWindow(m_hWnd));
  8391. return CommandBar_AddToolTips(m_hWnd, uNumToolTips, lpToolTips);
  8392. }
  8393. BOOL InsertButton(int nButton, LPTBBUTTON lpButton)
  8394. {
  8395. ATLASSERT(::IsWindow(m_hWnd));
  8396. return CommandBar_InsertButton(m_hWnd, nButton, lpButton);
  8397. }
  8398. HWND InsertComboBox(int nWidth, UINT dwStyle, WORD wComboBoxID, WORD wButton)
  8399. {
  8400. ATLASSERT(::IsWindow(m_hWnd));
  8401. return ::CommandBar_InsertComboBox(m_hWnd, ModuleHelper::GetModuleInstance(), nWidth, dwStyle, wComboBoxID, wButton);
  8402. }
  8403. BOOL InsertMenubar(WORD wMenuID, WORD wButton)
  8404. {
  8405. ATLASSERT(::IsWindow(m_hWnd));
  8406. return ::CommandBar_InsertMenubar(m_hWnd, ModuleHelper::GetResourceInstance(), wMenuID, wButton);
  8407. }
  8408. BOOL InsertMenubarEx(ATL::_U_STRINGorID menu, WORD wButton)
  8409. {
  8410. ATLASSERT(::IsWindow(m_hWnd));
  8411. return ::CommandBar_InsertMenubarEx(m_hWnd, ModuleHelper::GetResourceInstance(), (LPTSTR)menu.m_lpstr, wButton);
  8412. }
  8413. BOOL IsCommandBarMessage(LPMSG lpMsg)
  8414. {
  8415. ATLASSERT(::IsWindow(m_hWnd));
  8416. return ::IsCommandBarMessage(m_hWnd, lpMsg);
  8417. }
  8418. };
  8419. #if defined(_AYGSHELL_H_) || defined(__AYGSHELL_H__) // PPC MenuBar
  8420. typedef CCECommandBarCtrlT<CToolBarCtrl> CMenuBarCtrl;
  8421. #else
  8422. typedef CCECommandBarCtrlT<CToolBarCtrl> CCECommandBarCtrl;
  8423. #endif // defined(_AYGSHELL_H_) || defined(__AYGSHELL_H__)
  8424. ///////////////////////////////////////////////////////////////////////////////
  8425. // CCECommandBandsCtrl
  8426. template <class TBase>
  8427. class CCECommandBandsCtrlT : public TBase
  8428. {
  8429. public:
  8430. // Constructors
  8431. CCECommandBandsCtrlT(HWND hWnd = NULL) : TBase(hWnd) { }
  8432. CCECommandBandsCtrlT< TBase >& operator=(HWND hWnd)
  8433. {
  8434. m_hWnd = hWnd;
  8435. return *this;
  8436. }
  8437. // Attributes
  8438. BOOL IsVisible() const
  8439. {
  8440. return IsWindowVisible();
  8441. }
  8442. #if (_WIN32_IE >= 0x0400)
  8443. UINT GetHeight() const
  8444. {
  8445. ATLASSERT(::IsWindow(m_hWnd));
  8446. return CommandBands_Height(m_hWnd);
  8447. }
  8448. #endif // (_WIN32_IE >= 0x0400)
  8449. HWND GetCommandBar(UINT uBand) const
  8450. {
  8451. ATLASSERT(::IsWindow(m_hWnd));
  8452. return ::CommandBands_GetCommandBar(m_hWnd, uBand);
  8453. }
  8454. BOOL GetRestoreInformation(UINT uBand, LPCOMMANDBANDSRESTOREINFO pcbr) const
  8455. {
  8456. ATLASSERT(::IsWindow(m_hWnd));
  8457. return ::CommandBands_GetRestoreInformation(m_hWnd, uBand, pcbr);
  8458. }
  8459. // Operations
  8460. HWND Create(HWND hWndParent, UINT wID, DWORD dwStyles, HIMAGELIST hImageList = NULL)
  8461. {
  8462. m_hWnd = ::CommandBands_Create(ModuleHelper::GetModuleInstance(), hWndParent, wID, dwStyles, hImageList);
  8463. ATLASSERT(::IsWindow(m_hWnd));
  8464. return m_hWnd;
  8465. }
  8466. BOOL AddAdornments(DWORD dwFlags = 0, LPREBARBANDINFO prbbi = NULL)
  8467. {
  8468. ATLASSERT(::IsWindow(m_hWnd));
  8469. return ::CommandBands_AddAdornments(m_hWnd, ModuleHelper::GetModuleInstance(), dwFlags, prbbi);
  8470. }
  8471. BOOL AddBands(UINT uBandCount, LPREBARBANDINFO prbbi)
  8472. {
  8473. ATLASSERT(::IsWindow(m_hWnd));
  8474. return ::CommandBands_AddBands(m_hWnd, ModuleHelper::GetModuleInstance(), uBandCount, prbbi);
  8475. }
  8476. BOOL Show(BOOL bShow = TRUE)
  8477. {
  8478. ATLASSERT(::IsWindow(m_hWnd));
  8479. return ::CommandBands_Show(m_hWnd, bShow);
  8480. }
  8481. };
  8482. typedef CCECommandBandsCtrlT<ATL::CWindow> CCECommandBandsCtrl;
  8483. #endif // _WIN32_WCE
  8484. }; // namespace WTL
  8485. #endif // __ATLCTRLS_H__