13
0
livetrax/libs/gtkmm2/gtk/gtkmm/statusicon.h
Carl Hetherington 89f1f09c04 Add stuff missing from yesterday's library commit.
git-svn-id: svn://localhost/ardour2/trunk@2643 d708f5d6-7413-0410-9779-e7cbd77b26cf
2007-11-13 10:29:44 +00:00

367 lines
12 KiB
C++

// -*- c++ -*-
// Generated by gtkmmproc -- DO NOT MODIFY!
#ifndef _GTKMM_STATUSICON_H
#define _GTKMM_STATUSICON_H
#include <glibmm.h>
/* $Id: statusicon.hg,v 1.6 2006/07/05 16:59:28 murrayc Exp $ */
/* Copyright (C) 2005 The gtkmm Development Team
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Library General Public
* License as published by the Free Software Foundation; either
* version 2 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Library General Public License for more details.
*
* You should have received a copy of the GNU Library General Public
* License along with this library; if not, write to the Free
* Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
*/
#include <gtkmm/image.h> //For ImageType.
#include <gtkmm/stockid.h>
#include <gdkmm/pixbuf.h>
#include <gdkmm/types.h>
#include <gtkmm/object.h>
#ifndef DOXYGEN_SHOULD_SKIP_THIS
typedef struct _GtkStatusIcon GtkStatusIcon;
typedef struct _GtkStatusIconClass GtkStatusIconClass;
#endif /* DOXYGEN_SHOULD_SKIP_THIS */
namespace Gtk
{ class StatusIcon_Class; } // namespace Gtk
namespace Gtk
{
/** The "system tray" or notification area is normally used for transient icons that indicate some
* special state. For example, a system tray icon might appear to tell the user that they have new
* mail, or have an incoming instant message, or something along those lines. The basic idea is
* that creating an icon in the notification area is less annoying than popping up a dialog.
*
* A StatusIcon object can be used to display an icon in a "system tray". The icon can have a
* tooltip, and the user can interact with it by activating it or popping up a context menu.
* Critical information should not solely be displayed in a StatusIcon, since it may not be
* visible (e.g. when the user doesn't have a notification area on his panel). This can be checked
* with is_embedded().
*
* On X11, the implementation follows the freedesktop.org "System Tray" specification.
* Implementations of the "tray" side of this specification can be found e.g. in the GNOME and KDE
* panel applications.
*
* @newin2p10
*/
class StatusIcon : public Glib::Object
{
#ifndef DOXYGEN_SHOULD_SKIP_THIS
public:
typedef StatusIcon CppObjectType;
typedef StatusIcon_Class CppClassType;
typedef GtkStatusIcon BaseObjectType;
typedef GtkStatusIconClass BaseClassType;
private: friend class StatusIcon_Class;
static CppClassType statusicon_class_;
private:
// noncopyable
StatusIcon(const StatusIcon&);
StatusIcon& operator=(const StatusIcon&);
protected:
explicit StatusIcon(const Glib::ConstructParams& construct_params);
explicit StatusIcon(GtkStatusIcon* castitem);
#endif /* DOXYGEN_SHOULD_SKIP_THIS */
public:
virtual ~StatusIcon();
#ifndef DOXYGEN_SHOULD_SKIP_THIS
static GType get_type() G_GNUC_CONST;
static GType get_base_type() G_GNUC_CONST;
#endif
///Provides access to the underlying C GObject.
GtkStatusIcon* gobj() { return reinterpret_cast<GtkStatusIcon*>(gobject_); }
///Provides access to the underlying C GObject.
const GtkStatusIcon* gobj() const { return reinterpret_cast<GtkStatusIcon*>(gobject_); }
///Provides access to the underlying C instance. The caller is responsible for unrefing it. Use when directly setting fields in structs.
GtkStatusIcon* gobj_copy();
private:
protected:
StatusIcon();
explicit StatusIcon(const Glib::RefPtr<Gdk::Pixbuf>& pixbuf);
explicit StatusIcon(const StockID& stock);
explicit StatusIcon(const Glib::ustring& icon_name);
public:
/** Creates a new Gtk::StatusIcon object.
* @return A Glib::RefPtr<> to a newly created Gtk::StatusIcon object.
*/
static Glib::RefPtr<StatusIcon> create(const Glib::RefPtr<Gdk::Pixbuf>& pixbuf);
static Glib::RefPtr<StatusIcon> create(const StockID& stock_id);
static Glib::RefPtr<StatusIcon> create(const Glib::ustring& icon_name);
/** Creates a status icon displaying the file @a filename.
* The image will be scaled down to fit in the available
* space in the notification area, if necessary.
*
* @param filename A filename.
* @result A new StatusIcon
*
* @newin2p10
*/
static Glib::RefPtr<StatusIcon> create_from_file(const std::string& filename);
void set(const Glib::RefPtr<Gdk::Pixbuf>& pixbuf);
void set_from_file(const Glib::ustring& filename);
void set(const StockID& stock_id);
void set(const Glib::ustring& icon_name);
ImageType get_storage_type() const;
Glib::RefPtr<Gdk::Pixbuf> get_pixbuf();
Glib::RefPtr<const Gdk::Pixbuf> get_pixbuf() const;
StockID get_stock() const;
Glib::ustring get_icon_name() const;
int get_size() const;
void set_tooltip(const Glib::ustring& tooltip_text);
void set_visible(bool visible = true);
bool get_visible() const;
void set_blinking(bool blinking = true);
bool get_blinking() const;
bool is_embedded() const;
//In gtk_status_icon_get_geometry(), any of the parameters may be NULL,
//but we don't need 6 different overloads, with different parameters.
//But we can add some if there are common cases.
/** Obtains information about the location of the status icon
* on screen. This information can be used to e.g. position
* popups like notification bubbles.
* See gtk_status_icon_position_menu() for a more convenient
* alternative for positioning menus.
*
* Note that some platforms do not allow GTK+ to provide
* this information.
*
* @param screen: The screen.
* @param area The area occupied by the status icon.
* @param orientation The orientation of the panel in which the status icon is embedded. A panel
* at the top or bottom of the screen is horizontal, a panel at the left or right is vertical.
* @result true if the location information has been filled in.
*
* @newin2p10
*/
bool get_geometry(Glib::RefPtr<Gdk::Screen>& screen, Gdk::Rectangle& area, Orientation& orientation);
#ifdef GLIBMM_PROPERTIES_ENABLED
/** A GdkPixbuf to display.
*
* You rarely need to use properties because there are get_ and set_ methods for almost all of them.
* @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
* the value of the property changes.
*/
Glib::PropertyProxy< Glib::RefPtr<Gdk::Pixbuf> > property_pixbuf() ;
#endif //#GLIBMM_PROPERTIES_ENABLED
#ifdef GLIBMM_PROPERTIES_ENABLED
/** A GdkPixbuf to display.
*
* You rarely need to use properties because there are get_ and set_ methods for almost all of them.
* @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
* the value of the property changes.
*/
Glib::PropertyProxy_ReadOnly< Glib::RefPtr<Gdk::Pixbuf> > property_pixbuf() const;
#endif //#GLIBMM_PROPERTIES_ENABLED
#ifdef GLIBMM_PROPERTIES_ENABLED
/** Filename to load and display.
*
* You rarely need to use properties because there are get_ and set_ methods for almost all of them.
* @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
* the value of the property changes.
*/
Glib::PropertyProxy_WriteOnly<std::string> property_file() ;
#endif //#GLIBMM_PROPERTIES_ENABLED
#ifdef GLIBMM_PROPERTIES_ENABLED
/** Stock ID for a stock image to display.
*
* You rarely need to use properties because there are get_ and set_ methods for almost all of them.
* @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
* the value of the property changes.
*/
Glib::PropertyProxy<StockID> property_stock() ;
#endif //#GLIBMM_PROPERTIES_ENABLED
#ifdef GLIBMM_PROPERTIES_ENABLED
/** Stock ID for a stock image to display.
*
* You rarely need to use properties because there are get_ and set_ methods for almost all of them.
* @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
* the value of the property changes.
*/
Glib::PropertyProxy_ReadOnly<StockID> property_stock() const;
#endif //#GLIBMM_PROPERTIES_ENABLED
#ifdef GLIBMM_PROPERTIES_ENABLED
/** The name of the icon from the icon theme.
*
* You rarely need to use properties because there are get_ and set_ methods for almost all of them.
* @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
* the value of the property changes.
*/
Glib::PropertyProxy<Glib::ustring> property_icon_name() ;
#endif //#GLIBMM_PROPERTIES_ENABLED
#ifdef GLIBMM_PROPERTIES_ENABLED
/** The name of the icon from the icon theme.
*
* You rarely need to use properties because there are get_ and set_ methods for almost all of them.
* @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
* the value of the property changes.
*/
Glib::PropertyProxy_ReadOnly<Glib::ustring> property_icon_name() const;
#endif //#GLIBMM_PROPERTIES_ENABLED
#ifdef GLIBMM_PROPERTIES_ENABLED
/** The representation being used for image data.
*
* You rarely need to use properties because there are get_ and set_ methods for almost all of them.
* @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
* the value of the property changes.
*/
Glib::PropertyProxy_ReadOnly<ImageType> property_storage_type() const;
#endif //#GLIBMM_PROPERTIES_ENABLED
#ifdef GLIBMM_PROPERTIES_ENABLED
/** The size of the icon.
*
* You rarely need to use properties because there are get_ and set_ methods for almost all of them.
* @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
* the value of the property changes.
*/
Glib::PropertyProxy_ReadOnly<int> property_size() const;
#endif //#GLIBMM_PROPERTIES_ENABLED
#ifdef GLIBMM_PROPERTIES_ENABLED
/** Whether or not the status icon is blinking.
*
* You rarely need to use properties because there are get_ and set_ methods for almost all of them.
* @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
* the value of the property changes.
*/
Glib::PropertyProxy<bool> property_blinking() ;
#endif //#GLIBMM_PROPERTIES_ENABLED
#ifdef GLIBMM_PROPERTIES_ENABLED
/** Whether or not the status icon is blinking.
*
* You rarely need to use properties because there are get_ and set_ methods for almost all of them.
* @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
* the value of the property changes.
*/
Glib::PropertyProxy_ReadOnly<bool> property_blinking() const;
#endif //#GLIBMM_PROPERTIES_ENABLED
/**
* @par Prototype:
* <tt>bool %size_changed(int size)</tt>
*/
Glib::SignalProxy1< bool,int > signal_size_changed();
//Keybinding signal.
//Keybinding signal.
public:
public:
//C++ methods used to invoke GTK+ virtual functions:
#ifdef GLIBMM_VFUNCS_ENABLED
#endif //GLIBMM_VFUNCS_ENABLED
protected:
//GTK+ Virtual Functions (override these to change behaviour):
#ifdef GLIBMM_VFUNCS_ENABLED
#endif //GLIBMM_VFUNCS_ENABLED
//Default Signal Handlers::
#ifdef GLIBMM_DEFAULT_SIGNAL_HANDLERS_ENABLED
virtual bool on_size_changed(int size);
#endif //GLIBMM_DEFAULT_SIGNAL_HANDLERS_ENABLED
};
} // namespace Gtk
namespace Glib
{
/** @relates Gtk::StatusIcon
* @param object The C instance
* @param take_copy False if the result should take ownership of the C instance. True if it should take a new copy or ref.
* @result A C++ instance that wraps this C instance.
*/
Glib::RefPtr<Gtk::StatusIcon> wrap(GtkStatusIcon* object, bool take_copy = false);
}
#endif /* _GTKMM_STATUSICON_H */