git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@50586 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
		
			
				
	
	
		
			160 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			160 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| ///////////////////////////////////////////////////////////////////////////////
 | |
| // Name:        wx/notifmsg.h
 | |
| // Purpose:     class allowing to show notification messages to the user
 | |
| // Author:      Vadim Zeitlin
 | |
| // Created:     2007-11-19
 | |
| // RCS-ID:      $Id$
 | |
| // Copyright:   (c) 2007 Vadim Zeitlin <vadim@wxwindows.org>
 | |
| // Licence:     wxWindows licence
 | |
| ///////////////////////////////////////////////////////////////////////////////
 | |
| 
 | |
| #ifndef _WX_NOTIFMSG_H_
 | |
| #define _WX_NOTIFMSG_H_
 | |
| 
 | |
| #include "wx/event.h"
 | |
| 
 | |
| #if wxUSE_NOTIFICATION_MESSAGE
 | |
| 
 | |
| // ----------------------------------------------------------------------------
 | |
| // wxNotificationMessage: allows to show the user a message non intrusively
 | |
| // ----------------------------------------------------------------------------
 | |
| 
 | |
| // notice that this class is not a window and so doesn't derive from wxWindow
 | |
| 
 | |
| class WXDLLIMPEXP_ADV wxNotificationMessageBase : public wxEvtHandler
 | |
| {
 | |
| public:
 | |
|     // ctors and initializers
 | |
|     // ----------------------
 | |
| 
 | |
|     // default ctor, use setters below to initialize it later
 | |
|     wxNotificationMessageBase()
 | |
|     {
 | |
|         m_parent = NULL;
 | |
|         m_flags = wxICON_INFORMATION;
 | |
|     }
 | |
| 
 | |
|     // create a notification object with the given title and message (the
 | |
|     // latter may be empty in which case only the title will be shown)
 | |
|     wxNotificationMessageBase(const wxString& title,
 | |
|                               const wxString& message = wxString(),
 | |
|                               wxWindow *parent = NULL,
 | |
|                               int flags = wxICON_INFORMATION)
 | |
|         : m_title(title),
 | |
|           m_message(message),
 | |
|           m_parent(parent)
 | |
|     {
 | |
|         SetFlags(flags);
 | |
|     }
 | |
| 
 | |
|     // note that the setters must be called before Show()
 | |
| 
 | |
|     // set the title: short string, markup not allowed
 | |
|     void SetTitle(const wxString& title) { m_title = title; }
 | |
| 
 | |
|     // set the text of the message: this is a longer string than the title and
 | |
|     // some platforms allow simple HTML-like markup in it
 | |
|     void SetMessage(const wxString& message) { m_message = message; }
 | |
| 
 | |
|     // set the parent for this notification: we'll be associated with the top
 | |
|     // level parent of this window or, if this method is not called, with the
 | |
|     // main application window by default
 | |
|     void SetParent(wxWindow *parent) { m_parent = parent; }
 | |
| 
 | |
|     // this method can currently be used to choose a standard icon to use: the
 | |
|     // parameter may be one of wxICON_INFORMATION, wxICON_WARNING or
 | |
|     // wxICON_ERROR only (but not wxICON_QUESTION)
 | |
|     void SetFlags(int flags)
 | |
|     {
 | |
|         wxASSERT_MSG( flags == wxICON_INFORMATION ||
 | |
|                         flags == wxICON_WARNING || flags == wxICON_ERROR,
 | |
|                             "Invalid icon flags specified" );
 | |
| 
 | |
|         m_flags = flags;
 | |
|     }
 | |
| 
 | |
| 
 | |
|     // showing and hiding
 | |
|     // ------------------
 | |
| 
 | |
|     // possible values for Show() timeout
 | |
|     enum
 | |
|     {
 | |
|         Timeout_Auto = -1,  // notification will be hidden automatically
 | |
|         Timeout_Never = 0   // notification will never time out
 | |
|     };
 | |
| 
 | |
|     // show the notification to the user and hides it after timeout seconds
 | |
|     // pass (special values Timeout_Auto and Timeout_Never can be used)
 | |
|     //
 | |
|     // returns false if an error occurred
 | |
|     virtual bool Show(int timeout = Timeout_Auto) = 0;
 | |
| 
 | |
|     // hide the notification, returns true if it was hidden or false if it
 | |
|     // couldn't be done (e.g. on some systems automatically hidden
 | |
|     // notifications can't be hidden manually)
 | |
|     virtual bool Close() = 0;
 | |
| 
 | |
| protected:
 | |
|     // accessors for the derived classes
 | |
|     const wxString& GetTitle() const { return m_title; }
 | |
|     const wxString& GetMessage() const { return m_message; }
 | |
|     wxWindow *GetParent() const { return m_parent; }
 | |
|     int GetFlags() const { return m_flags; }
 | |
| 
 | |
|     // return the concatenation of title and message separated by a new line,
 | |
|     // this is suitable for simple implementation which have no support for
 | |
|     // separate title and message parts of the notification
 | |
|     wxString GetFullMessage() const
 | |
|     {
 | |
|         wxString text(m_title);
 | |
|         if ( !m_message.empty() )
 | |
|         {
 | |
|             text << "\n\n" << m_message;
 | |
|         }
 | |
| 
 | |
|         return text;
 | |
|     }
 | |
| 
 | |
| private:
 | |
|     wxString m_title,
 | |
|              m_message;
 | |
| 
 | |
|     wxWindow *m_parent;
 | |
| 
 | |
|     int m_flags;
 | |
| 
 | |
|     DECLARE_NO_COPY_CLASS(wxNotificationMessageBase)
 | |
| };
 | |
| 
 | |
| #if defined(__WXGTK__) && wxUSE_LIBHILDON
 | |
|     #include "wx/gtk/hildon/notifmsg.h"
 | |
| /*
 | |
|     TODO: provide support for
 | |
|         - libnotify (Gnome)
 | |
|         - Growl (http://growl.info/, OS X)
 | |
|  */
 | |
| #elif defined(__WXMSW__) && wxUSE_TASKBARICON && wxUSE_TASKBARICON_BALLOONS
 | |
|     #include "wx/msw/notifmsg.h"
 | |
| #else
 | |
|     #include "wx/generic/notifmsg.h"
 | |
| 
 | |
|     class wxNotificationMessage : public wxGenericNotificationMessage
 | |
|     {
 | |
|     public:
 | |
|         wxNotificationMessage() { }
 | |
|         wxNotificationMessage(const wxString& title,
 | |
|                               const wxString& message = wxString(),
 | |
|                               wxWindow *parent = NULL,
 | |
|                               int flags = wxICON_INFORMATION)
 | |
|             : wxGenericNotificationMessage(title, message, parent, flags)
 | |
|         {
 | |
|         }
 | |
|     };
 | |
| #endif
 | |
| 
 | |
| #endif // wxUSE_NOTIFICATION_MESSAGE
 | |
| 
 | |
| #endif // _WX_NOTIFMSG_H_
 | |
| 
 |