ardour/libs/gtkmm2/gtk/src/range.hg
Paul Davis 449aab3c46 rollback to 3428, before the mysterious removal of libs/* at 3431/3432
git-svn-id: svn://localhost/ardour2/branches/3.0@3435 d708f5d6-7413-0410-9779-e7cbd77b26cf
2008-06-02 21:41:35 +00:00

114 lines
5.1 KiB
Text

/* $Id: range.hg,v 1.8 2006/04/12 11:11:25 murrayc Exp $ */
/* Copyright (C) 1998-2002 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/widget.h>
_DEFS(gtkmm,gtk)
_PINCLUDE(gtkmm/private/widget_p.h)
namespace Gtk
{
_WRAP_ENUM(SensitivityType, GtkSensitivityType)
class Adjustment;
/** Base class for widgets which visualize an adjustment.
*
* @ingroup Widgets
*/
class Range : public Widget
{
_CLASS_GTKOBJECT(Range,GtkRange,GTK_RANGE,Gtk::Widget,GtkWidget)
protected:
_CTOR_DEFAULT
public:
_WRAP_METHOD(void set_update_policy(UpdateType policy), gtk_range_set_update_policy)
_WRAP_METHOD(UpdateType get_update_policy() const, gtk_range_get_update_policy)
_WRAP_METHOD(void set_adjustment(Gtk::Adjustment& adjustment), gtk_range_set_adjustment)
void unset_adjustment();
_WRAP_METHOD(Gtk::Adjustment* get_adjustment(), gtk_range_get_adjustment)
_WRAP_METHOD(const Gtk::Adjustment* get_adjustment() const, gtk_range_get_adjustment, constversion)
_WRAP_METHOD(void set_inverted(bool setting = true), gtk_range_set_inverted)
_WRAP_METHOD(bool get_inverted() const, gtk_range_get_inverted)
_WRAP_METHOD(void set_lower_stepper_sensitivity(SensitivityType sensitivity), gtk_range_set_lower_stepper_sensitivity)
_WRAP_METHOD(SensitivityType get_lower_stepper_sensitivity() const, gtk_range_get_lower_stepper_sensitivity)
_WRAP_METHOD(void set_upper_stepper_sensitivity(SensitivityType sensitivity), gtk_range_set_upper_stepper_sensitivity)
_WRAP_METHOD(SensitivityType get_upper_stepper_sensitivity() const, gtk_range_get_upper_stepper_sensitivity)
_WRAP_METHOD(void set_increments(double step, double page), gtk_range_set_increments)
_WRAP_METHOD(void set_range(double min, double max), gtk_range_set_range)
_WRAP_METHOD(void set_value(double value), gtk_range_set_value)
_WRAP_METHOD(double get_value() const, gtk_range_get_value)
_WRAP_METHOD(void set_show_fill_level(bool show_fill_level = true), gtk_range_set_show_fill_level)
_WRAP_METHOD(bool get_show_fill_level() const, gtk_range_get_show_fill_level)
_WRAP_METHOD(void set_restrict_to_fill_level(bool restrict_to_fill_level = true), gtk_range_set_restrict_to_fill_level)
_WRAP_METHOD(bool get_restrict_to_fill_level() const, gtk_range_get_restrict_to_fill_level)
_WRAP_METHOD(void set_fill_level(double fill_level), gtk_range_set_fill_level)
_WRAP_METHOD(double get_fill_level() const, gtk_range_get_fill_level)
_WRAP_SIGNAL(void value_changed(), "value_changed")
_WRAP_SIGNAL(void adjust_bounds(double new_value), "adjust_bounds")
_WRAP_SIGNAL(void move_slider(ScrollType scroll), "move_slider")
//We use no_default_handler for this, because we can not add a new vfunc to 2.5 without breaking ABI.
//TODO: Remove no_default_handler when we do an ABI-break-with-parallel-install.
/** The change_value signal is emitted when a scroll action is
* performed on a range. It allows an application to determine the
* type of scroll event that occurred and the resultant new value.
* The application can handle the event itself and return true to
* prevent further processing. Or, by returning false, it can pass
* the event to other handlers until the default GTK+ handler is
* reached.
*
* The value parameter is unrounded. An application that overrides
* the change_value signal is responsible for clamping the value to
* the desired number of decimal digits; the default handler
* clamps the value based on range->round_digits.
*
* It is not possible to use delayed update policies in an overridden
* change_value handler.
*
* @param scroll the type of scroll action that was performed.
* @param new_value the new value resulting from the scroll action.
* @result true to prevent other handlers from being invoked for the
* signal, or false to propagate the signal further.
*/
_WRAP_SIGNAL(bool change_value(ScrollType scroll, double new_value), "change_value", no_default_handler)
_WRAP_PROPERTY("update-policy", UpdateType)
_WRAP_PROPERTY("adjustment", Adjustment*)
_WRAP_PROPERTY("inverted", bool)
_WRAP_PROPERTY("lower-stepper-sensitivity", SensitivityType)
_WRAP_PROPERTY("upper-stepper-sensitivity", SensitivityType)
_WRAP_PROPERTY("show-fill-level", bool)
_WRAP_PROPERTY("restrict-to-fill-level", bool)
_WRAP_PROPERTY("fill-level", double)
protected:
_WRAP_VFUNC(void get_range_border(GtkBorder* border) const, get_range_border)
};
} // namespace Gtk