// -*- c++ -*- // Generated by gtkmmproc -- DO NOT MODIFY! #ifndef _GTKMM_TOOLBUTTON_H #define _GTKMM_TOOLBUTTON_H #include /* $Id$ */ /* box.h * * Copyright (C) 2003 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 #ifndef DOXYGEN_SHOULD_SKIP_THIS typedef struct _GtkToolButton GtkToolButton; typedef struct _GtkToolButtonClass GtkToolButtonClass; #endif /* DOXYGEN_SHOULD_SKIP_THIS */ namespace Gtk { class ToolButton_Class; } // namespace Gtk namespace Gtk { /** A Gtk::ToolItem subclass that displays buttons. * * A ToolButton is are Gtk::ToolItem containing a button. * @ingroup Widgets */ class ToolButton : public ToolItem { public: #ifndef DOXYGEN_SHOULD_SKIP_THIS typedef ToolButton CppObjectType; typedef ToolButton_Class CppClassType; typedef GtkToolButton BaseObjectType; typedef GtkToolButtonClass BaseClassType; #endif /* DOXYGEN_SHOULD_SKIP_THIS */ virtual ~ToolButton(); #ifndef DOXYGEN_SHOULD_SKIP_THIS private: friend class ToolButton_Class; static CppClassType toolbutton_class_; // noncopyable ToolButton(const ToolButton&); ToolButton& operator=(const ToolButton&); protected: explicit ToolButton(const Glib::ConstructParams& construct_params); explicit ToolButton(GtkToolButton* castitem); #endif /* DOXYGEN_SHOULD_SKIP_THIS */ public: #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 GtkObject. GtkToolButton* gobj() { return reinterpret_cast(gobject_); } ///Provides access to the underlying C GtkObject. const GtkToolButton* gobj() const { return reinterpret_cast(gobject_); } public: //C++ methods used to invoke GTK+ virtual functions: protected: //GTK+ Virtual Functions (override these to change behaviour): //Default Signal Handlers:: virtual void on_clicked(); private: public: /** Creates a new ToolButton. */ ToolButton(); /** Creates a new ToolButton from a StockID. * * The ToolButton will be created according to the @a stock_id properties. * * @param stock_id The StockID which determines the look of the ToolButton. */ explicit ToolButton(const Gtk::StockID& stock_id); /** Creates a new ToolButton with a label. * * The ToolButton will have the label @a label. * * @param label The string used to display the label for this ToolButton. */ explicit ToolButton(const Glib::ustring& label); /** Creates a new ToolButton with an image. * * The ToolButton will have the label @a label and an image widget @a icon_widget. * * @param icon_widget The widget placed as the ToolButton's icon. * @param label The string used to display the label for this ToolButton. */ explicit ToolButton(Widget& icon_widget, const Glib::ustring& label = Glib::ustring()); /** Sets @a label as the label used for the tool button. The "label" property * only has an effect if not overridden by a non-0 "label_widget" property. * If both the "label_widget" and "label" properties are 0, the label * is determined by the "stock_id" property. If the "stock_id" property is also * 0, @a button will not have a label. * * Since: 2.4 * @param label A string that will be used as label, or 0. */ void set_label(const Glib::ustring& label); /** Returns the label used by the tool button, or 0 if the tool button * doesn't have a label. or uses a the label from a stock item. The returned * string is owned by GTK+, and must not be modified or freed. * @return The label, or 0 * * Since: 2.4. */ Glib::ustring get_label() const; /** If set, an underline in the label property indicates that the next character * should be used for the mnemonic accelerator key in the overflow menu. For * example, if the label property is "_Open" and @a use_underline is true, * the label on the tool button will be "Open" and the item on the overflow * menu will have an underlined 'O'. * * Labels shown on tool buttons never have mnemonics on them; this property * only affects the menu item on the overflow menu. * * Since: 2.4 * @param use_underline Whether the button label has the form "_Open". */ void set_use_underline(bool use_underline = true); /** Returns whether underscores in the label property are used as mnemonics * on menu items on the overflow menu. See set_use_underline(). * @return true if underscores in the label property are used as * mnemonics on menu items on the overflow menu. * * Since: 2.4. */ bool get_use_underline() const; /** Sets the name of the stock item. See new_from_stock(). * The stock_id property only has an effect if not * overridden by non-0 "label" and "icon_widget" properties. * * Since: 2.4 * @param stock_id A name of a stock item, or 0. */ void set_stock_id(const Gtk::StockID& stock_id); /** Returns the name of the stock item. See set_stock_id(). * The returned string is owned by GTK+ and must not be freed or modifed. * @return The name of the stock item for @a button . * * Since: 2.4. */ Glib::ustring get_stock_id() const; /** Sets @a icon as the widget used as icon on @a button . If @a icon_widget is * 0 the icon is determined by the "stock_id" property. If the * "stock_id" property is also 0, @a button will not have an icon. * * Since: 2.4 * @param icon_widget The widget used as icon, or 0. */ void set_icon_widget(Widget& icon_widget); /** Return the widget used as icon widget on @a button . See * set_icon_widget(). * @return The widget used as icon on @a button , or 0. * * Since: 2.4. */ Widget* get_icon_widget(); /** Return the widget used as icon widget on @a button . See * set_icon_widget(). * @return The widget used as icon on @a button , or 0. * * Since: 2.4. */ const Widget* get_icon_widget() const; /** Sets @a label_widget as the widget that will be used as the label * for @a button . If @a label_widget is 0 the "label" property is used * as label. If "label" is also 0, the label in the stock item * determined by the "stock_id" property is used as label. If * "stock_id" is also 0, @a button does not have a label. * * Since: 2.4 * @param label_widget The widget used as label, or 0. */ void set_label_widget(Widget& label_widget); /** Returns the widget used as label on @a button . See * set_label_widget(). * @return The widget used as label on @a button , or 0. * * Since: 2.4. */ Widget* get_label_widget(); /** Returns the widget used as label on @a button . See * set_label_widget(). * @return The widget used as label on @a button , or 0. * * Since: 2.4. */ const Widget* get_label_widget() const; Glib::SignalProxy0< void > signal_clicked(); /** Text to show in the item. * * 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 property_label() ; /** Text to show in the item. * * 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 property_label() const; /** If set * * 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 property_use_underline() ; /** If set * * 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 property_use_underline() const; /** Widget to use as the item label. * * 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 property_label_widget() ; /** Widget to use as the item label. * * 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 property_label_widget() const; /** The stock icon displayed on the item. * * 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 property_stock_id() ; /** The stock icon displayed on the item. * * 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 property_stock_id() const; /** Icon widget to display in the item. * * 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 property_icon_widget() ; /** Icon widget to display in the item. * * 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 property_icon_widget() const; }; } // namespace Gtk namespace Glib { /** @relates Gtk::ToolButton * @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. */ Gtk::ToolButton* wrap(GtkToolButton* object, bool take_copy = false); } #endif /* _GTKMM_TOOLBUTTON_H */