You cannot select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
	
	
		
			252 lines
		
	
	
		
			9.1 KiB
		
	
	
	
		
			C++
		
	
			
		
		
	
	
			252 lines
		
	
	
		
			9.1 KiB
		
	
	
	
		
			C++
		
	
| // XTPReBar.h : header file
 | |
| //
 | |
| // This file is a part of the XTREME COMMANDBARS MFC class library.
 | |
| // (c)1998-2012 Codejock Software, All Rights Reserved.
 | |
| //
 | |
| // THIS SOURCE FILE IS THE PROPERTY OF CODEJOCK SOFTWARE AND IS NOT TO BE
 | |
| // RE-DISTRIBUTED BY ANY MEANS WHATSOEVER WITHOUT THE EXPRESSED WRITTEN
 | |
| // CONSENT OF CODEJOCK SOFTWARE.
 | |
| //
 | |
| // THIS SOURCE CODE CAN ONLY BE USED UNDER THE TERMS AND CONDITIONS OUTLINED
 | |
| // IN THE XTREME TOOLKIT PRO LICENSE AGREEMENT. CODEJOCK SOFTWARE GRANTS TO
 | |
| // YOU (ONE SOFTWARE DEVELOPER) THE LIMITED RIGHT TO USE THIS SOFTWARE ON A
 | |
| // SINGLE COMPUTER.
 | |
| //
 | |
| // CONTACT INFORMATION:
 | |
| // support@codejock.com
 | |
| // http://www.codejock.com
 | |
| //
 | |
| /////////////////////////////////////////////////////////////////////////////
 | |
| 
 | |
| //{{AFX_CODEJOCK_PRIVATE
 | |
| #if !defined(__XTPREBAR_H__)
 | |
| #define __XTPREBAR_H__
 | |
| //}}AFX_CODEJOCK_PRIVATE
 | |
| 
 | |
| #if _MSC_VER > 1000
 | |
| #pragma once
 | |
| #endif // _MSC_VER > 1000
 | |
| 
 | |
| class CXTPToolBar;
 | |
| 
 | |
| //{{AFX_CODEJOCK_PRIVATE
 | |
| #if _MSC_VER < 1200 // MFC 6.0
 | |
| 
 | |
| #ifndef AFX_IDW_REBAR
 | |
| #define AFX_IDW_REBAR                   0xE804
 | |
| #endif
 | |
| 
 | |
| class _XTP_EXT_CLASS CXTPReBarBase : public CControlBar
 | |
| {
 | |
| 	DECLARE_DYNAMIC(CXTPReBarBase)
 | |
| 
 | |
| // Construction
 | |
| public:
 | |
| 	CXTPReBarBase();
 | |
| 	BOOL Create(CWnd* pParentWnd, DWORD dwCtrlStyle = RBS_BANDBORDERS,
 | |
| 		DWORD dwStyle = WS_CHILD | WS_VISIBLE | WS_CLIPSIBLINGS | WS_CLIPCHILDREN | CBRS_TOP,
 | |
| 		UINT nID = AFX_IDW_REBAR);
 | |
| 
 | |
| // Attributes
 | |
| public:
 | |
| 	int m_iComCtlVersion;
 | |
| 
 | |
| // Operations
 | |
| public:
 | |
| 	BOOL AddBar(CWnd* pBar, LPCTSTR pszText = NULL, CBitmap* pbmp = NULL,
 | |
| 		DWORD dwStyle = RBBS_GRIPPERALWAYS | RBBS_FIXEDBMP);
 | |
| 	BOOL AddBar(CWnd* pBar, COLORREF clrFore, COLORREF clrBack,
 | |
| 		LPCTSTR pszText = NULL, DWORD dwStyle = RBBS_GRIPPERALWAYS);
 | |
| 
 | |
| // Implementation
 | |
| 	virtual void OnUpdateCmdUI(CFrameWnd* pTarget, BOOL bDisableIfNoHndler);
 | |
| 	virtual INT_PTR OnToolHitTest(CPoint point, TOOLINFO* pTI) const;
 | |
| 	virtual CSize CalcFixedLayout(BOOL bStretch, BOOL bHorz);
 | |
| 	virtual CSize CalcDynamicLayout(int nLength, DWORD nMode);
 | |
| #ifdef _DEBUG
 | |
| 	void EnableDocking(DWORD dwDockStyle);
 | |
| #endif
 | |
| 
 | |
| protected:
 | |
| 	virtual LRESULT WindowProc(UINT message, WPARAM wParam, LPARAM lParam);
 | |
| 	BOOL _AddBar(CWnd* pBar, REBARBANDINFO* pRBBI);
 | |
| 
 | |
| 	//{{AFX_MSG(CReBar)
 | |
| 	afx_msg BOOL OnNcCreate(LPCREATESTRUCT);
 | |
| 	afx_msg void OnHeightChange(NMHDR* pNMHDR, LRESULT* pResult);
 | |
| 	afx_msg void OnNcPaint();
 | |
| 	afx_msg void OnNcCalcSize(BOOL, NCCALCSIZE_PARAMS*);
 | |
| 	afx_msg LRESULT OnShowBand(WPARAM wParam, LPARAM lParam);
 | |
| 	afx_msg void OnRecalcParent();
 | |
| 	//}}AFX_MSG
 | |
| 	DECLARE_MESSAGE_MAP()
 | |
| };
 | |
| 
 | |
| #else
 | |
| #define CXTPReBarBase CReBar
 | |
| #endif
 | |
| //}}AFX_CODEJOCK_PRIVATE
 | |
| 
 | |
| //===========================================================================
 | |
| // Summary:
 | |
| //     The CXTPReBar object extends the standard MFC CReBar class to
 | |
| //     provide extended functionality such as saving and restoring of
 | |
| //     band layouts.
 | |
| //===========================================================================
 | |
| class _XTP_EXT_CLASS CXTPReBar : public CXTPReBarBase
 | |
| {
 | |
| 	DECLARE_DYNAMIC(CXTPReBar)
 | |
| 
 | |
| public:
 | |
| 	//-------------------------------------------------------------------------
 | |
| 	// Summary:
 | |
| 	//     Constructs a CXTPReBar object.
 | |
| 	//-------------------------------------------------------------------------
 | |
| 	CXTPReBar();
 | |
| 
 | |
| 	//-------------------------------------------------------------------------
 | |
| 	// Summary:
 | |
| 	//     Destroys a CXTPReBar object, handles cleanup and deallocation.
 | |
| 	//-------------------------------------------------------------------------
 | |
| 	virtual ~CXTPReBar();
 | |
| 
 | |
| public:
 | |
| 
 | |
| 	//-----------------------------------------------------------------------
 | |
| 	// Summary:
 | |
| 	//     Call this member to add a band to the rebar. The specified Toolbar
 | |
| 	//     will be inserted into the band.
 | |
| 	// Parameters:
 | |
| 	//     pToolBar - Pointer to the Toolbar object that will be added to
 | |
| 	//                rebar band.
 | |
| 	//     dwStyle  - Contains styles that can be applied to the rebar.
 | |
| 	//                * RBBS_BREAK          - The band is on a new line.
 | |
| 	//                * RBBS_CHILDEDGE      - The band has an edge at the top and bottom of the child window.
 | |
| 	//                * RBBS_FIXEDBMP       - The background bitmap does not move when the band is resized.
 | |
| 	//                * RBBS_FIXEDSIZE      - The band cannot be sized. With this style, the sizing grip is not displayed on the band.
 | |
| 	//                * RBBS_GRIPPERALWAYS  - The band will always have sizing grip, even if it is the only band in the rebar.
 | |
| 	//                * RBBS_HIDDEN         - The band will not be visible.
 | |
| 	//                * RBBS_NOVERT         - The band is not displayed when the rebar control uses the CCS_VERT style.
 | |
| 	// Remarks:
 | |
| 	//     The id of the band that contains the toolbar is assigned the same id
 | |
| 	//     as the toolbar.
 | |
| 	// Returns:
 | |
| 	//     TRUE is the bar was added successfully, FALSE if the bar wasn't added.
 | |
| 	//-----------------------------------------------------------------------
 | |
| 	BOOL AddToolBar(CXTPToolBar* pToolBar, DWORD dwStyle = RBBS_GRIPPERALWAYS);
 | |
| 
 | |
| 	//-----------------------------------------------------------------------
 | |
| 	// Summary:
 | |
| 	//     Call this member to remove a toolbar within the rebar.  This will
 | |
| 	//     also remove the band that contained the toolbar.
 | |
| 	// Parameters:
 | |
| 	//     pToolBar - Pointer to the toolbar that will be removed.
 | |
| 	//-----------------------------------------------------------------------
 | |
| 	void DeleteToolBar(CXTPToolBar* pToolBar);
 | |
| 
 | |
| 	//-----------------------------------------------------------------------
 | |
| 	// Summary:
 | |
| 	//     Call this member to locate the band that contains a toolbar.
 | |
| 	// Parameters:
 | |
| 	//     pToolBar - Pointer to the toolbar you want to find.
 | |
| 	// Returns: -1 if the toolbar was not found on a band in the rebar.  If found
 | |
| 	//          the Id of the band that contains the toolbar is returned.
 | |
| 	//-----------------------------------------------------------------------
 | |
| 	int FindBand(CXTPToolBar* pToolBar);
 | |
| 
 | |
| 	//-----------------------------------------------------------------------
 | |
| 	// Summary:
 | |
| 	//     Call this member to retrieve a pointer to a toolbar that is contained
 | |
| 	//     in the band with the specified id.
 | |
| 	// Parameters:
 | |
| 	//     nBand - Id of a band in the rebar.
 | |
| 	// Returns:
 | |
| 	//     A pointer to the toolbar contained in the specified band.
 | |
| 	//-----------------------------------------------------------------------
 | |
| 	CXTPToolBar* GetToolBar(int nBand);
 | |
| 
 | |
| 	//-----------------------------------------------------------------------
 | |
| 	// Summary:
 | |
| 	//     Call this function to retrieve state information from the
 | |
| 	//     registry.
 | |
| 	// Parameters:
 | |
| 	//     lpszProfileName - Points to a null-teminated string that specifies
 | |
| 	//     the name of a key in the Windows registry where state
 | |
| 	//     information is stored.
 | |
| 	//-----------------------------------------------------------------------
 | |
| 	void LoadState(LPCTSTR lpszProfileName);
 | |
| 
 | |
| 	//-----------------------------------------------------------------------
 | |
| 	// Summary:
 | |
| 	//     Call this function to save state information from the
 | |
| 	//     registry.
 | |
| 	// Parameters:
 | |
| 	//     lpszProfileName - Points to a null-teminated string that specifies
 | |
| 	//     the name of a key in the Windows registry where the state
 | |
| 	//     information should be stored.
 | |
| 	//-----------------------------------------------------------------------
 | |
| 	void SaveState(LPCTSTR lpszProfileName);
 | |
| 
 | |
| 	//-----------------------------------------------------------------------
 | |
| 	// Summary:
 | |
| 	//     This member function implements the behavior of the Win32 message
 | |
| 	//     RB_SETBANDINFO, as described in the Platform SDK.
 | |
| 	// Parameters:
 | |
| 	//     uBand - Zero-based index of the band to receive the new settings.
 | |
| 	//             prbbi - Pointer to a REBARBANDINFO structure that defines the band to be inserted.
 | |
| 	//             You must set the 'cbSize' member of this structure to sizeof(REBARBANDINFO)
 | |
| 	//             before sending this message.
 | |
| 	// Returns:
 | |
| 	//     Nonzero if successful, otherwise returns zero.
 | |
| 	// Example:
 | |
| 	// <code>
 | |
| 	// int nCount = m_wndReBar.GetReBarCtrl().GetBandCount();
 | |
| 	// CString strText = "Band #:";
 | |
| 	//
 | |
| 	// int i;
 | |
| 	// for (i = 0; i<nCount; i++)
 | |
| 	// {
 | |
| 	//     LPREBARBANDINFO prbbi = (LPREBARBANDINFO)alloca(sizeof(REBARBANDINFO));
 | |
| 	//     prbbi->cbSize = sizeof(REBARBANDINFO);
 | |
| 	//
 | |
| 	//     CString strText;
 | |
| 	//     strText.Format("Band #: %d", i);
 | |
| 	//
 | |
| 	//     LPTSTR lpszText = strText.GetBuffer(strText.GetLength());
 | |
| 	//     prbbi->lpText = lpszText;
 | |
| 	//     prbbi->cch = strlen(lpszText) + 1;
 | |
| 	//     prbbi->fMask = RBBIM_TEXT;
 | |
| 	//
 | |
| 	//     m_wndReBar.SetBandInfo(i, prbbi);
 | |
| 	//
 | |
| 	//     strText.ReleaseBuffer();
 | |
| 	// }
 | |
| 	// </code>
 | |
| 	//-----------------------------------------------------------------------
 | |
| 	BOOL SetBandInfo(UINT uBand, REBARBANDINFO* prbbi);
 | |
| 
 | |
| protected:
 | |
| //{{AFX_CODEJOCK_PRIVATE
 | |
| 	DECLARE_MESSAGE_MAP()
 | |
| 
 | |
| 	//{{AFX_MSG(CXTPReBar)
 | |
| 	void OnChildSize(NMHDR* pNotifyStruct, LRESULT* result);
 | |
| 	void OnPaint();
 | |
| 	BOOL OnEraseBkgnd(CDC* pDC);
 | |
| 	virtual CSize CalcFixedLayout(BOOL bStretch, BOOL bHorz);
 | |
| 	//}}AFX_MSG
 | |
| 
 | |
| //}}AFX_CODEJOCK_PRIVATE
 | |
| 
 | |
| private:
 | |
| 	static const LPCTSTR m_lpszStateInfoEntry;
 | |
| 	static const LPCTSTR m_lpszStateInfoFormat;
 | |
| };
 | |
| 
 | |
| AFX_INLINE BOOL CXTPReBar::SetBandInfo(UINT uBand, REBARBANDINFO* prbbi) {
 | |
| 	return (BOOL)DefWindowProc(RB_SETBANDINFO, uBand, (LPARAM)prbbi);
 | |
| }
 | |
| /////////////////////////////////////////////////////////////////////////////
 | |
| 
 | |
| #endif // !defined(__XTPREBAR_H__)
 |