347 lines
12 KiB
C
347 lines
12 KiB
C
|
// -*- c++ -*-
|
||
|
// Generated by gtkmmproc -- DO NOT MODIFY!
|
||
|
#ifndef _GTKMM_TOOLBUTTON_H
|
||
|
#define _GTKMM_TOOLBUTTON_H
|
||
|
|
||
|
#include <glibmm.h>
|
||
|
|
||
|
/* $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 <gtkmm/toolitem.h>
|
||
|
|
||
|
|
||
|
#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<GtkToolButton*>(gobject_); }
|
||
|
|
||
|
///Provides access to the underlying C GtkObject.
|
||
|
const GtkToolButton* gobj() const { return reinterpret_cast<GtkToolButton*>(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-<tt>0</tt> "label_widget" property.
|
||
|
* If both the "label_widget" and "label" properties are <tt>0</tt>, the label
|
||
|
* is determined by the "stock_id" property. If the "stock_id" property is also
|
||
|
* <tt>0</tt>, @a button will not have a label.
|
||
|
*
|
||
|
* Since: 2.4
|
||
|
* @param label A string that will be used as label, or <tt>0</tt>.
|
||
|
*/
|
||
|
void set_label(const Glib::ustring& label);
|
||
|
|
||
|
/** Returns the label used by the tool button, or <tt>0</tt> 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 <tt>0</tt>
|
||
|
*
|
||
|
* 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 <tt>true</tt>,
|
||
|
* 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 <tt>true</tt> 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-<tt>0</tt> "label" and "icon_widget" properties.
|
||
|
*
|
||
|
* Since: 2.4
|
||
|
* @param stock_id A name of a stock item, or <tt>0</tt>.
|
||
|
*/
|
||
|
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
|
||
|
* <tt>0</tt> the icon is determined by the "stock_id" property. If the
|
||
|
* "stock_id" property is also <tt>0</tt>, @a button will not have an icon.
|
||
|
*
|
||
|
* Since: 2.4
|
||
|
* @param icon_widget The widget used as icon, or <tt>0</tt>.
|
||
|
*/
|
||
|
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 <tt>0</tt>.
|
||
|
*
|
||
|
* 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 <tt>0</tt>.
|
||
|
*
|
||
|
* 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 <tt>0</tt> the "label" property is used
|
||
|
* as label. If "label" is also <tt>0</tt>, the label in the stock item
|
||
|
* determined by the "stock_id" property is used as label. If
|
||
|
* "stock_id" is also <tt>0</tt>, @a button does not have a label.
|
||
|
*
|
||
|
* Since: 2.4
|
||
|
* @param label_widget The widget used as label, or <tt>0</tt>.
|
||
|
*/
|
||
|
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 <tt>0</tt>.
|
||
|
*
|
||
|
* 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 <tt>0</tt>.
|
||
|
*
|
||
|
* 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<Glib::ustring> 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<Glib::ustring> 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<bool> 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<bool> 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<Gtk::Widget*> 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<Gtk::Widget*> 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<Glib::ustring> 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<Glib::ustring> 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<Gtk::Widget> 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<Gtk::Widget> 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 */
|
||
|
|