Click here to Skip to main content
15,314,303 members
Articles / Desktop Programming / WTL
Posted 6 Feb 2002


214 bookmarked

WTL Docking Windows

Rate me:
Please Sign up or sign in to vote.
4.89/5 (73 votes)
21 Nov 20077 min read
This is an implementation of docking windows for the WTL library

Sample Image - WTLDockingWindows1.png


This is an implementation of docking windows for the WTL library. The following topics describe how to use docking window classes.

Pre-Build Set-Up.

  • Make sure all header files are placed in the appropriate location and compiler can reach it.
  • Add DockImpl.cpp to the project. Probably the best way to do it is to add #include<span class="code-keyword"><DockImpl.cpp></span> to the stdafx.cpp.
  • Docking Windows use STL so it's requires to enable exception handling (/GX or /EH compiler options) and remove _ATL_MIN_CRT from the list the preprocessor defines in release configuration. If you use standard HP's STL you can leave default project setting intact, but I don't think it is a good idea.
  • If you use boost library define USE_BOOST.
  • I use some private message in range WM_USER to WM_USER + 2
    So if you define your own private messages please use WMDF_LAST+1 or if it is impossible redefine WMDF_FIRST.

Add to Main Frame Support for Docking Window Features

  • Create a new project with ATL/WTL AppWizard (MDI or SDI as you like)
  • Add #include <span class="code-keyword"><DockingFrame.h></span> to CMainFrame header.
  • Change the base of your CMainFrame class to dockwins::CDockingFrameImpl<CMainFrame> for SDI applications or to dockwins::CMDIDockingFrameImpl<CMainFrame> for MDI applications. All references to previous base class should be replaced by new one.
  • Add to the OnCreate method of your CMainFrame class InitializeDockingFrame(); it's the best place to change windows behavior of docking window. By default it is depend on system setting (Show window contents while dragging) if you for some reason need to change it you should use the following flags:
    CDockingBarStyle::sUseSysSettings — depend on system setting, default.
    CDockingBarStyle::sIgnoreSysSettings | CDockingBarStyle::sFullDrag — full drag
    CDockingBarStyle::sIgnoreSysSettings | CDockingBarStyle::sGhostDrag — ghost drag.
    If you use auto-hiding features you also can use the following flags:
    CDockingBarStyle::sAnimation — animate auto-hiding windows.
    CDockingBarStyle::sNoAnimation — do not animate auto-hiding windows.

Implement a Docking Window

  • Add #include <span class="code-keyword"><ExtDockingWindow.h></span> to header file of your docking window.
  • Create new class CSampleDockingWindow for example. Derive it from dockwins::CTitleDockingWindowImpl.
  • Add message map and DECLARE_WND_CLASS macro The CSampleDockingWindow class should look like this:
    class CSampleDockingWindow :
             public dockwins::CTitleDockingWindowImpl< SampleDockingWindow,
                    CWindow, dockwins::COutlookLikeTitleDockingWindowTraits >
            typedef CSampleDockingWindow    thisClass;
            typedef dockwins::CTitleDockingWindowImpl<CSAMPLEDOCKINGWINDOW,
             dockwins::COutlookLikeTitleDockingWindowTraits>  baseClass;
  • Instantiate an object of the CSampleDockingWindow class as a member of the CMainFrame
  • In the CMainFrame::OnCreate(...) method, call the Create(...) method of the instantiated docking window class.
    LRESULT OnCreate(UINT /*uMsg*/, WPARAM /*wParam*/, LPARAM /*lParam*/, 
                     BOOL& /*bHandled*/)
            CRect rcBar(0,0,100,100);
            m_sampleDockWnd.Create(m_hWnd,rcBar,_T("Sample docking window"));

    Do not use empty rect even if you dock the window. When window start dragging it use previously stored floating rect size.

Add to Generic Window Support for Docking Window Features

To implement a window with docking window features, derive a class from dockwins::CDockingSiteImpl. In derived class chain default message map to the base class.

class CDockSiteSampleWnd : public dockwins::CDockingSiteImpl < 
        CDockSiteSampleWnd >
        typedef dockwins::CDockingSiteImpl < CDockSiteSampleWnd > baseClass;

Add Support for Tabbed Docking Window

  • The tabbed docking window depend on Daniel Bowen's The Codeproject article "Custom Tab Controls,Tabbed Frame and Tabbed MDI", Please download the source code for this article.
  • Change the base class of your docking window from dockwins::CTitleDockingWindowImpl to dockwins::CBoxedDockingWindowImpl.
  • Use the following classes as traits for the dockwins::CBoxedDockingWindowImpl: COutlookLikeBoxedDockingWindowTraits, COutlookLikeExBoxedDockingWindowTraits or CVC6LikeBoxedDockingWindowTraits.
  • To add tabbed docking features support to the previous CSampleDockingWindow class, the code should look like this:
    class CSampleTabDockingWindow :
             public dockwins::CBoxedDockingWindowImpl< SampleDockingWindow,
                    CWindow, dockwins::COutlookLikeBoxedDockingWindowTraits >
            typedef CSampleTabDockingWindow    thisClass;
            typedef dockwins::CBoxedDockingWindowImpl<CSAMPLEDOCKINGWINDOW,
             dockwins::COutlookLikeBoxedDockingWindowTraits>  baseClass;

Add Support for Auto-Hiding Features

To add auto-hiding features to your project just include a DWAutoHide.h header before any other docking windows headers.

Dock a Docking Window

Call the DockWindow methods from your frame window class.

template<class T>
bool DockWindow(T& dockWnd,CDockingSide side,
                unsigned long nBar,float fPctPos,
                unsigned long nWidth, unsigned long nHeight);
Docking window.
Sides of the frame window to dock to
CDockingSide::sSingle force docking window to occupy the fulll width of the docking bar, combine this style with one of the following:
CDockingSide::sRight Dock to the right side of the frame window.
CDockingSide::sLeft Dock to the left side of the frame window.
CDockingSide::sTop Dock to the top side of the frame window.
CDockingSide::sBottom Dock to the bottom side of the frame window.
Index of dockbar to dock to, it's zero-based.
The percent of the dock bar's width that the docking window should use as top point.
The requested width (in pixels) of the docking window. If the docking window is vertical, this parameter actually represents the control bar height.
The requested height (in pixels) of the docking window. If the docking window is vertical, this parameter actually represents the control bar width.

Dock One Tabbed Docking Window to Another

Call the DockTo method of the tabbed docking window.

bool DockTo(HWND hWnd,int index=0);
Tabbed docking window to dock to.
Zero-based index.

Float a Docking Window that is Docked

Call the Float methods from your docking window class.

bool Float() - restore previous floating position
bool Float(LPCRECT pRc, <br />UINT flags=SWP_SHOWWINDOW | SWP_NOACTIVATE,<br />HWND hWndInsertAfter=HWND_TOP) - float docking window and move to a specified location.

Pin-up Docking Window

Call the one of the PinUp methods of the tabbed docking window.

bool PinUp(const CDockingSide& side);
bool PinUp(const CDockingSide& side, unsigned long width, 
    bool bVisualize=false);
Sides of the frame window to pin-up to:
CDockingSide::sRight Pin-up to the right side of the frame window.
CDockingSide::sLeft Pin-up to the left side of the frame window.
CDockingSide::sTop Pin-up to the top side of the frame window.
CDockingSide::sBottom Pin-up to the bottom side of the frame window.
The requested width (in pixels) of the docking window.
Specifies the show state of the docking window after pinning.

Unpin Pinned Docking Window

Call Hide then Show methods of the pinned window to emulate the pin button press,
or call Float method to float a pinned docking window,
or call Hide method then call any functions that set docking window position.

Receive Notifications when the Docked State of a Docking Window Changes

Override the following member functions of your docking window class

void OnDocked(HDOCKBAR hBar,bool bHorizontal)
void OnUndocked(HDOCKBAR hBar)
Handle to the dockbar to docking to.
Docking window orientation.

Hide/Show a Docking Window

To hide/show a docking window simply call Hide()/ Show() or Togle() methods of the CTitleDockingWindowImpl class.

Specify Minimum Docking Window Size

You can specify minimum docking window size by overriding GetMinMaxInfo method of your docking window, like this:

void GetMinMaxInfo(LPMINMAXINFO pMinMaxInfo) const

Preserve Docking Window Position

You can use following member functions of the CDockingWindowBaseImpl class:

bool GetDockingWindowPlacement(DFDOCKPOSEX* pHdr) const
bool SetDockingWindowPlacement(DFDOCKPOSEX* pHdr)

Replace Splitter Bar

If you do not like splitter bar you can make your own. If you just want to change it's appearance probably the best way to derive it from CSimpleSplitterBar. And override Draw(),DrawGhostBar() etc. Then define your traits

typedef CDockingFrameTraitsT <CMySplitterBar,
                WS_EX_APPWINDOW | WS_EX_WINDOWEDGE>  CMyDockingFrameTraits;
and apply it to base class of CMainFrame.

Make Custom Caption

Create a new caption class. You can derive it from CCaptionBase or from other available Caption classes. Then define DockingWindowTraits

typedef CDockingWindowTraits<CMyCaption,
                       WS_OVERLAPPEDWINDOW | WS_POPUP | WS_VISIBLE |
                       WS_CLIPCHILDREN | WS_CLIPSIBLINGS,
                       WS_EX_TOOLWINDOW> CMyTitleDockingWindowTraits;

and apply it to CTitleDockingWindowImpl.

Docking Window Classes

Docking Windows Frame Classes

CDockingFrameImplBase[DockingFrame.h] — this class provides basic docking window features.
CDockingFrameImpl [DockingFrame.h] — base class for a single document interface (SDI) frame window.
CMDIDockingFrameImpl [DockingFrame.h] — base class for a multiple document interface (MDI) frame window.
CDockingSiteImpl [DockingFrame.h] — base class for a generic window with docking window features.
CDockingFrameTraitsT [DockMisc.h] — traits of docking frame it's derived from CWinTraits class and add TSplitterBar parameter.

Docking Windows Classes

CDockingWindowBaseImpl [DockingWindow.h] — base class for docking windows. The CDockingWindowBaseImpl class derives from CWindowImpl and has the same parameters except TWinTraits. Instead, it is uses CDockingWindowTraits.
CTitleDockingWindowImpl [DockingWindow.h] — titled docking window.
CBoxedDockingWindowImpl [DockingBox.h] — titled docking window which support tabbed docking.
CDockingWindowTraits [DockingWindow.h] — traits of docking window it's derived from CWinTraits class and add TCaption parameter. If you need to customize the docking window caption, make new caption class and use CDockingWindowTraits with new class as TCaption parameter.

Docking Windows Captions Classes

CCaptionBase[DockingWindow.h] — base class for other caption class
COutlookLikeExCaption and COutlookLikeCaption [ExtDockingWindow.h] — Microsoft Outlook™ likes caption.
COutlookLikeCaption — always horizontal caption.
COutlookLikeExCaption — orientation of the caption depends on docking position.
CVC6LikeCaption [ExtDockingWindow.h] — Microsoft Visual C++ 6™ IDE like caption.

Docking Windows Traits Classes

COutlookLikeTitleDockingWindowTraits [ExtDockingWindow.h] traits for COutlookLikeCaption, use this class with CTitleDockingWindowImpl
COutlookLikeExTitleDockingWindowTraits [ExtDockingWindow.h] traits for COutlookLikeExCaption, use this class with CTitleDockingWindowImpl
CVC6LikeTitleDockingWindowTraits [ExtDockingWindow.h] traits forCVC6LikeCaption, use this class with CTitleDockingWindowImpl
COutlookLikeBoxedDockingWindowTraits [TabDockingBox.h] traits for COutlookLikeCaption, use this class with CBoxedDockingWindowImpl
COutlookLikeExBoxedDockingWindowTraits [TabDockingBox.h] traits for COutlookLikeExCaption, use this class with CBoxedDockingWindowImpl
CVC6LikeBoxedDockingWindowTraits[TabDockingBox.h] traits for CVC6LikeCaption, use this class with CBoxedDockingWindowImpl

Docking Windows Splitter Bar Classes

CSimpleSplitterBar[SimpleSplitterBar.h] - Very simple splitter bar.
CSimpleSplitterBarEx[SimpleSplitterBar.h] - another simple splitter bar.


This article has no explicit license attached to it but may contain usage terms in the article text or the download files themselves. If in doubt please contact the author via the discussion board below.

A list of licenses authors might use can be found here


About the Author

Serge Klimov
Software Developer
Ireland Ireland
No Biography provided

Comments and Discussions

GeneralClose only Active Tab in TabDockingBox Pin
Jens Nilsson30-Jan-03 17:54
MemberJens Nilsson30-Jan-03 17:54 
GeneralDifferent Layouts Pin
Mat B27-Jan-03 0:09
MemberMat B27-Jan-03 0:09 
GeneralRe: Different Layouts Pin
Paul Selormey15-Mar-03 2:03
MemberPaul Selormey15-Mar-03 2:03 
GeneralRe: Different Layouts Pin
Kjetil Haga2-Apr-03 17:33
MemberKjetil Haga2-Apr-03 17:33 
GeneralRe: Different Layouts Pin
Simon Steele14-May-03 7:45
MemberSimon Steele14-May-03 7:45 
GeneralRe: Different Layouts Pin
Seattle Diver18-Jul-03 13:00
MemberSeattle Diver18-Jul-03 13:00 
GeneralRe: Different Layouts Pin
khaki668818-Jun-09 21:17
Memberkhaki668818-Jun-09 21:17 
GeneralWindow Size Restriction Pin
Ismail Ufuk PAZARBASI13-Dec-02 3:27
MemberIsmail Ufuk PAZARBASI13-Dec-02 3:27 

I am trying to limit size of docking windows according to its position, and docking state. I have tried to override GetMinMaxInfo, but window never receives WM_GETMINMAXINFO, since it. I then attached parent window (CPackageWindowFrame) to a CContainedWindow to catch messages (for WM_WINDOWPOSCHANGING). Handler converts lParam to LPWINDOWPOS, and checks cy, for example for a window docking top. If cy>120, function sets new size (120 and flags=SWP_NOSIZE, and I tried SWP_DRAWFRAME, too). But I could not stop window resizing. I returned 1, and not called DefWindowProc. Well, actually docking window itself stops resizing, but parent CPackageFrame does not stop. Docking window has WS_OVERLAPPED style, but WM_GETMINMAXINFO never called. I wonder, if there is a way to restrict size of the window (actually,splitter's max size for that pane)? I did not read project's page entirely, but I would like to ask, if there is a way to restrict docking to right docking site only, for example? Or, I should handle OnDock, and check dock site than disallow docking?

I would really appreciate, if there is a way to restrict size.

Thank you for your interest,
Best regards.
GeneralDocking Window Manager and CBoxedDockingWindowImpl Pin
brainsucker8-Dec-02 4:46
Memberbrainsucker8-Dec-02 4:46 
Questionis there a mfc version? Pin
Yu_Matrix29-Nov-02 14:58
MemberYu_Matrix29-Nov-02 14:58 
GeneralExcellent! (hosting WebBrowser) Pin
3-Nov-02 23:41
suss3-Nov-02 23:41 
GeneralRe: Excellent! (hosting WebBrowser) Pin
P3452611-Feb-03 2:02
MemberP3452611-Feb-03 2:02 
GeneralLooking for Sergey Pin
Peter Krnjevic30-Oct-02 10:44
MemberPeter Krnjevic30-Oct-02 10:44 
GeneralRe: Looking for Sergey Pin
Hydra20-Nov-02 12:27
MemberHydra20-Nov-02 12:27 
GeneralNew changes, and leak and a question (was: Re: Looking for Sergey) Pin
Hydra27-Nov-02 13:40
MemberHydra27-Nov-02 13:40 
GeneralRe: New changes, and leak and a question (was: Re: Looking for Sergey) Pin
Alex Kamenev19-Feb-03 21:37
MemberAlex Kamenev19-Feb-03 21:37 
GeneralRe: New changes, and leak and a question (was: Re: Looking for Sergey) Pin
Hydra20-Feb-03 23:35
MemberHydra20-Feb-03 23:35 
GeneralThanks (-) Pin
Alex Kamenev24-Feb-03 20:37
MemberAlex Kamenev24-Feb-03 20:37 
GeneralRe: Thanks (-) Pin
Hydra25-Feb-03 7:38
MemberHydra25-Feb-03 7:38 
Generalwhy this function can't complies "AtlInitCommonControls" Pin
Hp1223-Oct-02 18:28
MemberHp1223-Oct-02 18:28 
GeneralRe: why this function can't complies "AtlInitCommonControls" Pin
kamal_upreti2-Jan-03 23:45
Memberkamal_upreti2-Jan-03 23:45 
GeneralKeyboard accelerators Pin
Anatoly Ivasyuk10-Oct-02 8:44
MemberAnatoly Ivasyuk10-Oct-02 8:44 
GeneralRe: Keyboard accelerators Pin
Hydra20-Nov-02 12:19
MemberHydra20-Nov-02 12:19 
GeneralRe: Keyboard accelerators Pin
peter@howudodat.com11-Apr-03 4:47
Memberpeter@howudodat.com11-Apr-03 4:47 
GeneralRe: Keyboard accelerators Pin
Anatoly Ivasyuk12-Apr-03 16:46
MemberAnatoly Ivasyuk12-Apr-03 16:46 

General General    News News    Suggestion Suggestion    Question Question    Bug Bug    Answer Answer    Joke Joke    Praise Praise    Rant Rant    Admin Admin   

Use Ctrl+Left/Right to switch messages, Ctrl+Up/Down to switch threads, Ctrl+Shift+Left/Right to switch pages.