Click here to Skip to main content
15,879,474 members
Articles / Desktop Programming / MFC
Article

CExtStatusControlBar - Managing status bar's panes is getting easier

Rate me:
Please Sign up or sign in to vote.
4.91/5 (63 votes)
15 Jan 20043 min read 234.9K   11K   185   67
An enhanced status bar which allows you to easily add/remove almost any controls to/from its panes, on-the-fly.

Sample Image - statuspanes.gif

Introduction

The article introduces an enhanced version of the standard MFC status bar control. The new class should enable you to easily add/remove panes to/from the application's status bar, on-the-fly. The status bar's panes may contain almost any control you need: buttons, edits, animations, progress bars, and etc.

The class is partially based on the status bar presented in the freeware version of the Prof-UIS library available here.

How to use it

The CExtStatusControlBar class is simple to use. To add it to your project, please follow the steps below:

  1. Put its source files (CExtStatusControlBar.cpp and CExtStatusControlBar.h) into the proper folder and add their file names to your Visual Studio project.
  2. Include its header to the appropriate header file. If you plan to use CExtStatusControlBar in several places of your application, it's reasonable to add it to your stdafx.h file.
    #include "CExtStatusControlBar.h"
  3. If you used CStatusBar, you should replace it with CExtStatusControlBar everywhere in the project.
    CExtStatusControlBar  m_wndStatusBar;

Sample

The StatusPanes sample project shows how to use the class in practice (including how to place controls into the control bar's panes).

List of methods

  • BOOL AddPane(UINT nID, int nIndex)

    Inserts a new pane into the status bar.

    Parameters
    nID
    ID of the pane to be added.
    nIndex
    The index of the newly created pane.
    Return Value
    Nonzero if successful.

  • BOOL RemovePane(UINT nID)

    Deletes a pane from the status bar.

    Parameters
    nID
    ID of the pane to be deleted.
    Return Value
    Nonzero if successful.

  • BOOL AddPaneControl(CWnd* pWnd, UINT nID, BOOL bAutoDestroy)

    Inserts a control into a specified pane.

    Parameters
    pWnd
    Pointer to the control to be added.
    nID
    ID of the target pane.
    bAutoDestroy
    Specifies whether the control should be destroyed when the pane is removed.
    Return Value
    Nonzero if successful; otherwise zero.

  • BOOL AddPaneControl(HWND hWnd, UINT nID, BOOL bAutoDestroy)

    Inserts a control into a specified pane.

    Parameters
    hWnd
    Handle to the control to be added.
    nID
    ID of the target pane.
    bAutoDestroy
    Specifies whether the control should be destroyed when the pane is removed.
    Return Value
    Nonzero if successful.

  • void DisableControl( int nIndex, BOOL bDisable=TRUE)

    Disables the control at a specified pane.

    Parameters
    nIndex
    Index of the pane.
    bDisable
    Flag specifying that the control is enabled if it is set to TRUE.
     

  • int GetPanesCount() const

    Retrieves the current number of panes in the status bar.


  • void SetPaneWidth(int nIndex, int nWidth)

    Sets a width in pixels for a specified pane.

    Parameters
    nIndex
    Index of the pane.
    nStyle
    Width to be set.


  • void SetPaneInfo(int nIndex, UINT nID, UINT nStyle, int cxWidth)

    Sets the specified pane to a new ID, style and width.

    Parameters
    nIndex
    Index of the pane whose style is to be set.
    nID
    New ID for the pane.
    nStyle
    New style for the pane.
    cxWidth
    New width for the pane.

  • void SetPaneStyle(int nIndex, UINT nStyle)

    Sets the style of a status bar's pane. A pane's style determines how the pane appears.

    Parameters
    nIndex
    Index of the pane whose style is to be set.
    nStyle
    Style of the pane whose style is to be set.

Copyright

You can use these sources for absolutely free.

Reporting bugs

Your questions, suggestions and bug reports may be posted either to the forum below or to the forum at the Prof-UIS website.

License

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


Written By
Software Developer (Senior)
Ukraine Ukraine
This member has not yet provided a Biography. Assume it's interesting and varied, and probably something to do with programming.

Comments and Discussions

 
QuestionNo License? Pin
Eric Smith12-Feb-04 8:27
Eric Smith12-Feb-04 8:27 
AnswerRe: No License? Pin
Dmitriy Yakovlev13-Feb-04 2:16
Dmitriy Yakovlev13-Feb-04 2:16 
GeneralSmall gotcha Pin
RLyon29-Jan-04 22:40
RLyon29-Jan-04 22:40 
GeneralRe: Small gotcha Pin
Dmitriy Yakovlev30-Jan-04 2:50
Dmitriy Yakovlev30-Jan-04 2:50 
QuestionWhat about bitmaps, icons, ... Pin
RLyon29-Jan-04 18:54
RLyon29-Jan-04 18:54 
AnswerRe: What about bitmaps, icons, ... Pin
Dmitriy Yakovlev29-Jan-04 22:05
Dmitriy Yakovlev29-Jan-04 22:05 
GeneralRe: What about bitmaps, icons, ... Pin
RLyon29-Jan-04 23:13
RLyon29-Jan-04 23:13 
GeneralUse in VB.Net project Pin
scsoft24-Jan-04 2:56
scsoft24-Jan-04 2:56 
GeneralRe: Use in VB.Net project Pin
Dmitriy Yakovlev26-Jan-04 23:46
Dmitriy Yakovlev26-Jan-04 23:46 
GeneralHelp - string ID Pin
Bamaco221-Jan-04 4:18
Bamaco221-Jan-04 4:18 
GeneralRe: Help - string ID Pin
Dmitriy Yakovlev21-Jan-04 5:25
Dmitriy Yakovlev21-Jan-04 5:25 
QuestionOffice XP Style ? Pin
darthmaul19-Jan-04 20:44
darthmaul19-Jan-04 20:44 
AnswerRe: Office XP Style ? Pin
Dmitriy Yakovlev19-Jan-04 21:04
Dmitriy Yakovlev19-Jan-04 21:04 
GeneralNice job with it Pin
Snyp17-Jan-04 11:32
Snyp17-Jan-04 11:32 
GeneralNice Pin
Giles17-Jan-04 6:12
Giles17-Jan-04 6:12 
Generalvery nice Pin
RichardLC16-Jan-04 10:53
RichardLC16-Jan-04 10:53 

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.