2009-10-05 22:54:13 +00:00
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Name: wx/infobar.h
|
|
|
|
// Purpose: declaration of wxInfoBarBase defining common API of wxInfoBar
|
|
|
|
// Author: Vadim Zeitlin
|
|
|
|
// Created: 2009-07-28
|
2009-10-06 03:42:55 +00:00
|
|
|
// RCS-ID: $Id$
|
2009-10-05 22:54:13 +00:00
|
|
|
// Copyright: (c) 2009 Vadim Zeitlin <vadim@wxwidgets.org>
|
|
|
|
// Licence: wxWindows licence
|
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
#ifndef _WX_INFOBAR_H_
|
|
|
|
#define _WX_INFOBAR_H_
|
|
|
|
|
|
|
|
#include "wx/defs.h"
|
|
|
|
|
|
|
|
#if wxUSE_INFOBAR
|
|
|
|
|
2009-10-06 03:42:55 +00:00
|
|
|
#include "wx/control.h"
|
2009-10-05 22:54:13 +00:00
|
|
|
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
// wxInfoBar shows non-critical but important information to the user
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
|
2010-05-05 12:20:08 +00:00
|
|
|
class WXDLLIMPEXP_CORE wxInfoBarBase : public wxControl
|
2009-10-05 22:54:13 +00:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
// real ctors are provided by the derived classes, just notice that unlike
|
|
|
|
// most of the other windows, info bar is created hidden and must be
|
|
|
|
// explicitly shown when it is needed (this is done because it is supposed
|
|
|
|
// to be shown only intermittently and hiding it after creating it from the
|
|
|
|
// user code would result in flicker)
|
|
|
|
wxInfoBarBase() { }
|
|
|
|
|
|
|
|
|
|
|
|
// show the info bar with the given message and optionally an icon
|
2009-10-05 22:55:10 +00:00
|
|
|
virtual void ShowMessage(const wxString& msg,
|
|
|
|
int flags = wxICON_INFORMATION) = 0;
|
2009-10-05 22:54:13 +00:00
|
|
|
|
2009-10-05 22:56:07 +00:00
|
|
|
// hide the info bar
|
|
|
|
virtual void Dismiss() = 0;
|
|
|
|
|
2009-10-05 22:55:40 +00:00
|
|
|
// add an extra button to the bar, near the message (replacing the default
|
|
|
|
// close button which is only shown if no extra buttons are used)
|
2009-10-05 22:54:31 +00:00
|
|
|
virtual void AddButton(wxWindowID btnid,
|
|
|
|
const wxString& label = wxString()) = 0;
|
|
|
|
|
2009-10-05 22:55:17 +00:00
|
|
|
// remove a button previously added by AddButton()
|
|
|
|
virtual void RemoveButton(wxWindowID btnid) = 0;
|
|
|
|
|
2009-10-05 22:54:13 +00:00
|
|
|
private:
|
|
|
|
wxDECLARE_NO_COPY_CLASS(wxInfoBarBase);
|
|
|
|
};
|
|
|
|
|
2009-10-05 22:55:10 +00:00
|
|
|
// currently only GTK+ has a native implementation
|
2009-10-14 22:49:38 +00:00
|
|
|
#if defined(__WXGTK218__) && !defined(__WXUNIVERSAL__)
|
|
|
|
#include "wx/gtk/infobar.h"
|
|
|
|
#define wxHAS_NATIVE_INFOBAR
|
2009-10-05 22:55:10 +00:00
|
|
|
#endif // wxGTK2
|
|
|
|
|
|
|
|
// if the generic version is the only one we have, use it
|
|
|
|
#ifndef wxHAS_NATIVE_INFOBAR
|
|
|
|
#include "wx/generic/infobar.h"
|
|
|
|
#define wxInfoBar wxInfoBarGeneric
|
|
|
|
#endif
|
2009-10-05 22:54:13 +00:00
|
|
|
|
|
|
|
#endif // wxUSE_INFOBAR
|
|
|
|
|
|
|
|
#endif // _WX_INFOBAR_H_
|