Click here to Skip to main content
Click here to Skip to main content

How to place controls on toolbars

, 12 Jan 2000
Rate this:
Please Sign up or sign in to vote.
How to place combo-boxes, edit boxes, progress controls, etc. into toolbars
<!-- Article Starts -->

It is very easy (once you see how it is done) to place combo-boxes, edit boxes, progress controls, etc. into toolbars. Below are two examples of this, in the first a ComboBox is placed on a toolbar, and in the second a cluster of checkboxes is added. In both cases the technique is the same:

Step 1: Place a button on the toolbar in the spot where you want the control(s) to eventually be. YOU MUST place a seperator on either side of the button!. Give the button an easily remembered resource name such as IDP_PLACEHOLDER2 in the example below.

Step 2: Derive a class from CToolBar and give it a member variable for the control you will be creating. For the ComboBox example that class looks like this. No extra methods are required, just a place for the instance of the control to live.

class CMainToolBar : public CToolBar 
    CComboBox m_wndSnap;

Step 3: In your main frame's .h file replace the instance of the CToolBar with you new class. Be sure to add an include statement for the class definition created in step 1.

protected: // control bar embedded members
    CStatusBar m_wndStatusBar;
    CMainToolBar m_wndToolBar;

Step 4: At the end of your main frame's OnCreate method you replace the placeholder button with your control as follows:

int SMCMainFrame::OnCreate(LPCREATESTRUCT lpCreateStruct)
    //Body of On Create goes here

    #define SNAP_WIDTH 80 //the width of the combo box

    //set up the ComboBox control as a snap mode select box
    //First get the index of the placeholder's position in the toolbar
    index = 0;
    while (m_wndToolBar.GetItemID(index) != IDP_PLACEHOLDER2) index++;

    //next convert that button to a seperator and get its position
    m_wndToolBar.SetButtonInfo(index, IDP_PLACEHOLDER2, TBBS_SEPARATOR,
    m_wndToolBar.GetItemRect(index, &rect);

    //expand the rectangle to allow the combo box room to drop down;
    rect.bottom += 200;

    // then .Create the combo box and show it
    if (!m_wndToolBar.m_wndSnap.Create(WS_CHILD|WS_VISIBLE|CBS_AUTOHSCROLL| 
                                       rect, &m_wndToolBar, IDC_SNAP_COMBO))
        TRACE0("Failed to create combo-box\n");
        return FALSE;

    //fill the combo box
    m_wndToolBar.m_wndSnap.AddString("SNAP OFF");
    m_wndToolBar.m_wndSnap.AddString("SNAP GRID");
    m_wndToolBar.m_wndSnap.AddString("SNAP RASTER");
    m_wndToolBar.m_wndSnap.AddString("SNAP VERTEX");
    m_wndToolBar.m_wndSnap.AddString("SNAP LINE");

The result looks like this:

Here is one that is a little trickier:

Four check boxes are placed in the toolbar. In addition to adding multiple controls in place of a single button this example shows how to change the font of the checkboxes.

1. Derive the new toolbar class and add it to the main frame. Also add a CFont called gSmallFont to the Main Frame.

class CCoupleToolBar : public CToolBar
    CButton m_wndCenter;
    CButton m_wndEdge;
    CButton m_wndTrack;
    CButton m_wndZoom;

2. Place a placeholder button on the toolbar resource MAKING SURE to leave a space on either side. This is done just as in the first example.

3. At the end of OnCreate in the main frame, first set up the font we are going to use, then replace the placeholder button with the new controls.

int CMainFrame::OnCreate(LPCREATESTRUCT lpCreateStruct)
    // Body of OnCreate here
    //set up the small font to use for the button text
    // remember to declare CFont gSmallFont in the .h file
    // font for tool bar use
    CClientDC DC(GetDesktopWindow());
    long logical_pixels = DC.GetDeviceCaps(LOGPIXELSX);
    if(logical_pixels <100)

        gSmallFont.CreatePointFont(67, "DEFAULT", NULL);  
        gSmallFont.CreatePointFont(50, "DEFAULT", NULL); 
    //create the four check boxes  
    #define CHECK_WIDTH 94  
    int index;   
    CRect rect;   
    CRect safe_rect;
    index = 0;  
    while (m_wndViewBar.GetItemID(index) != IDP_PLACHOLDER) index++;     
    // Create the "CENTER" check box   
    m_wndViewBar.SetButtonInfo(index, IDP_PLACHOLDER, TBBS_SEPARATOR,
    m_wndViewBar.GetItemRect(index, &rect); 
    rect.left +=2;   
    rect.right=rect.left + ((CHECK_WIDTH / 2)-4);; + 10;   
    if (!m_wndViewBar.m_wndCenter.Create("CNTR",
        BS_CHECKBOX|WS_CHILD|WS_VISIBLE, rect, &m_wndViewBar,
        TRACE0("Failed to create CENTER check-box\n");       
        return FALSE;    
        (WPARAM)HFONT(gSmallFont),TRUE); = rect.bottom += 2;   
    rect.bottom = + 10;    
    if (!m_wndViewBar.m_wndEdge.Create("EDGE",
        BS_CHECKBOX|WS_CHILD|WS_VISIBLE, rect, &m_wndViewBar,
        TRACE0("Failed to create EDGE check-box\n");        
        return FALSE; 
        (WPARAM)HFONT(gSmallFont), TRUE);
    rect = safe_rect;
    rect.left += ((CHECK_WIDTH / 2) + 4); = 2;

    rect.bottom = + 10; 
    if (!m_wndViewBar.m_wndZoom.Create("ZOOM",
        BS_CHECKBOX|WS_CHILD|WS_VISIBLE, rect, &m_wndViewBar,
        TRACE0("Failed to create ZOOM check-box\n");    
        return FALSE;   
        (WPARAM)HFONT(gSmallFont),TRUE); = rect.bottom += 2;   
    rect.bottom = + 10;  
    if (!m_wndViewBar.m_wndTrack.Create("TRKR",
        BS_CHECKBOX|WS_CHILD|WS_VISIBLE, rect, &m_wndViewBar,
        TRACE0("Failed to create EDGE check-box\n");    
        return FALSE;   
        (WPARAM)HFONT(gSmallFont), TRUE); 


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

Randy More

United States United States
No Biography provided

Comments and Discussions

QuestionHow does this works on a splitter frame toolbar? Pinmemberfdkhb4-Jan-09 16:20 
Questionm_wndToolBar.m_wndSnap.Create(......)? Pinmemberbonmeepon26-Feb-06 20:29 
GeneralHandling return Pinmemberviaduct3-Oct-05 6:17 
GeneralDraw on Toolbar button PinmemberAnything.J25-Mar-05 0:57 
I have a toolbar on SDI frame. I am able to add the buttons onto the toolbar at run time. I want to draw line or draw rect on that buttons. I don't want to insert a BMP into it.Can anybody let me know how I can draw line or draw rect on that buttons at run time. Thank you in advance!!!

GeneralFont In Combobox In Toolbar Pinmemberkoorosh7-Jan-05 23:33 
GeneralHandle to the MENU PinmemberAlex Evans16-Nov-04 14:22 
GeneralThat looks familiar... PinmemberAnna-Jayne Metcalfe16-Apr-04 4:49 
GeneralCatching Messages from CView PinmemberJay Jonna Jameson31-Mar-04 10:38 
GeneralRe: Catching Messages from CView Pinmember*Dreamz2-Apr-04 3:20 
GeneralRe: Catching Messages from CView PinmemberBig Eyes, Small Head2-Apr-04 7:00 
Generalthe &quot;little&quot; ComboBox PinsussCynicannibal30-Oct-03 0:55 
GeneralCatch Index PinsussThim7-Oct-03 3:41 
GeneralRe: Catch Index PinmemberThim7-Oct-03 5:06 
QuestionWhy can't I place a CStatic on the toolbar? PinmemberHighersong5-Jun-03 1:28 
AnswerRe: Why can't I place a CStatic on the toolbar? PinmemberBrendan Tregear6-Aug-03 16:41 
GeneralRe: Why can't I place a CStatic on the toolbar? Pinmembervikas amin29-Sep-05 0:05 
QuestionHow to Catch Event from the VB ActiveX Control from ToolBar ? PinmemberDominicOn1-May-03 11:39 
GeneralMenu on toolbar PinmemberCSZX3-Apr-02 23:49 
QuestionHow to use Drop Down Arrow to show a wnd, just as what the arrow by Undo-button does in Visual Studio? Pinmembermsvcna26-Mar-02 17:46 
GeneralResizing Embedded Controls PinmemberMarcus Carey21-Mar-02 15:06 
Generalset focus & lost focus Pinmemberpiyer19-Mar-02 22:56 
GeneralCapturing data from ComboBox PinmemberStew2-Jan-02 6:30 
GeneralWondering what I'm doing wrong PinmemberStew1-Jan-02 17:50 
GeneralRe: Wondering what I'm doing wrong PinmemberAnonymous28-Jun-02 15:43 
Generalsome code to enable checkboxes PinmemberAydin Bakir6-Dec-01 4:13 
GeneralWhen toolbar is too small... PinmemberVale30-Oct-01 5:11 
GeneralCustom-colored buttons on a toolbar PinmemberAmir Kibar10-Oct-01 2:54 
GeneralNeed to add button to default toolbar in WinSDK PinmemberAshley Pinto8-Oct-01 7:41 
GeneralToolbar without C++ PinmemberNovacain2-Aug-01 22:50 
GeneralTooltips PinmemberJean-Yves26-Dec-00 22:21 
GeneralRe: Tooltips PinmemberUma Mahes28-Oct-03 20:50 
GeneralRe: Tooltips PinsussDenisZ4-Nov-03 3:10 
GeneralOver and over PinsussAlexander27-Jul-00 2:50 
GeneralRe: Over and over PinsussUser27-Jul-00 2:59 
GeneralRe: Over and over PinsussAlexander27-Jul-00 4:15 
GeneralRe: Over and over PinmemberShyguy from China6-Nov-00 21:38 
GeneralRe: Over and over PinmemberMember #408077827-Jan-08 19:08 
GeneralRe: Over and over PinmemberMember #408077827-Jan-08 19:14 
GeneralRe: Over and over PinsussDave R17-Aug-00 5:32 
GeneralRe: Over and over PinsussAndy Metcalfe11-Oct-00 2:31 
GeneralRe: Over and over PinmemberRay Romero22-Nov-00 8:13 
GeneralEXACTLY! GOT IT GUYS! :) PinmemberMasoud Samimi30-Dec-00 10:43 
GeneralRe: Over and over Pinmembercypherljk30-Dec-00 8:27 
GeneralRe: Over and over PinmemberWarren Gardner10-Jul-01 11:21 
QuestionWhat about edit/spin combinations? PinsussRob Edwards9-Jun-00 11:13 
AnswerRe: What about edit/spin combinations? PinmemberMasoud Samimi27-Dec-00 1:56 
GeneralCombo font - too large PinsussFrédéric Marion-Poll5-Mar-00 12:57 
GeneralRe: Combo font - too large PinsussRichard Odenweller4-Apr-00 8:23 
GeneralRe: Combo font - too large PinmemberAdam Bialowas18-Aug-01 11:20 
GeneralRe: Combo font - too large Pinmemberdrhender27-Jun-02 6:33 

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

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

| Advertise | Privacy | Terms of Use | Mobile
Web01 | 2.8.150327.1 | Last Updated 13 Jan 2000
Article Copyright 2000 by Randy More
Everything else Copyright © CodeProject, 1999-2015
Layout: fixed | fluid