----------------------------------------------------------------------- -- GtkAda - Ada95 binding for Gtk+/Gnome -- -- -- -- Copyright (C) 1998-2000 E. Briot, J. Brobecker and A. Charlet -- -- Copyright (C) 2000-2007 AdaCore -- -- -- -- This library is free software; you can redistribute it and/or -- -- modify it under the terms of the GNU 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 -- -- General Public License for more details. -- -- -- -- You should have received a copy of the GNU General Public -- -- License along with this library; if not, write to the -- -- Free Software Foundation, Inc., 59 Temple Place - Suite 330, -- -- Boston, MA 02111-1307, USA. -- -- -- ----------------------------------------------------------------------- -- <description> -- The Gtk_Curve widget allows the user to edit a curve covering a range of -- values. It is typically used to fine-tune color balances in graphics -- applications like the Gimp. -- -- The Gtk_Curve widget has 3 modes of operation: spline, linear and free. -- In spline mode the user places points on the curve which are automatically -- connected together into a smooth curve. In linear mode the user places -- points on the curve which are connected by straight lines. In free mode the -- user can draw the points of the curve freely, and they are not connected at -- all. -- </description> -- <c_version>2.8.17</c_version> -- <group>Drawing</group> with Gtk.Drawing_Area;
with Gtk.Enums; use Gtk.Enums;
with Glib.Generic_Properties; use Glib.Generic_Properties;
pragma Elaborate_All (Glib.Generic_Properties);
with Glib.Properties;
package Gtk.Curve is
type Gtk_Curve_Record is new
Gtk.Drawing_Area.Gtk_Drawing_Area_Record with private;
type Gtk_Curve is access all Gtk_Curve_Record'Class;
procedure Gtk_New (Curve : out Gtk_Curve);
-- Create a new Curve. procedure Initialize (Curve : access Gtk_Curve_Record'Class);
-- Internal initialization function. -- See the section "Creating your own widgets" in the documentation. function Get_Type return Gtk.Gtk_Type;
-- Return the internal value associated with a Gtk_Curve. procedure Reset (Curve : access Gtk_Curve_Record);
-- Reset the curve. -- Reset to a straight line from the minimum x & y values to the maximum -- x & y values (i.e. from the bottom-left to the top-right corners). -- The curve type is not changed. procedure Set_Gamma (Curve : access Gtk_Curve_Record; Gamma : Gfloat);
-- Recompute the entire curve using the given gamma value. -- A gamma value of 1.0 results in a straight line. Values greater than 1.0 -- result in a curve above the straight line. Values less than 1.0 result -- in a curve below the straight line. The curve type is changed to -- Curve_Type_Free. procedure Set_Range
(Curve : access Gtk_Curve_Record;
Min_X : Gfloat;
Max_X : Gfloat;
Min_Y : Gfloat;
Max_Y : Gfloat);
-- Set the minimum and maximum x & y values of the curve. -- The curve is also reset with a call to Reset. procedure Set_Vector
(Curve : access Gtk_Curve_Record; Vector : Gfloat_Array);
procedure Get_Vector
(Curve : access Gtk_Curve_Record; Vector : out Gfloat_Array);
-- Set the vector of points on the curve. -- The curve type is set to Curve_Type_Free. procedure Set_Curve_Type
(Curve : access Gtk_Curve_Record;
Curve_Type : Gtk_Curve_Type);
-- Set the type of the curve. -- The curve will remain unchanged except when changing from a free curve -- to a linear or spline curve, in which case the curve will be changed as -- little as possible. ---------------- -- Properties -- ---------------- -- <properties> -- The following properties are defined for this widget. See -- Glib.Properties for more information on properties. -- -- - Name: Curve_Type_Property -- Type: Gtk_Curve_Type -- Flags: read-write -- Descr: Is this curve linear, spline interpolated, or free-form -- See also: Set_Curve_Type -- -- - Name: Min_X_Property -- Type: Gfloat -- Flags: read-write -- Descr: Minimum possible value for X -- See also: Set_Range -- -- - Name: Min_Y_Property -- Type: Gfloat -- Flags: read-write -- Descr: Minimum possible value for Y -- See also: Set_Range -- -- - Name: Max_X_Property -- Type: Gfloat -- Flags: read-write -- Descr: Maximum possible value for X -- See also: Set_Range -- -- - Name: Max_Y_Property -- Type: Gfloat -- Flags: read-write -- Descr: Maximum possible value for Y -- See also: Set_Range -- -- </properties> package Curve_Type_Properties is new Generic_Internal_Discrete_Property
(Gtk_Curve_Type); type Property_Gtk_Curve_Type is new Curve_Type_Properties.Property;
Curve_Type_Property : constant Property_Gtk_Curve_Type;
Min_X_Property : constant Glib.Properties.Property_Float;
Max_X_Property : constant Glib.Properties.Property_Float;
Min_Y_Property : constant Glib.Properties.Property_Float;
Max_Y_Property : constant Glib.Properties.Property_Float;
------------- -- Signals -- ------------- -- <signals> -- The following new signals are defined for this widget: -- - "curve-type-changed" -- procedure Handler (Curve : access Gtk_Curve_Record'Class); -- -- Emitted when the curve type has been changed. The curve type can be -- changed explicitly with a call to Set_Curve_Type. It is also changed as -- a side-effect of calling Reset or Set_Gamma. -- </signals> Signal_Curve_Type_Changed : constant Glib.Signal_Name :=
"curve_type_changed"; private type Gtk_Curve_Record is new Gtk.Drawing_Area.Gtk_Drawing_Area_Record
with null record;
Curve_Type_Property : constant Property_Gtk_Curve_Type :=
Build ("curve_type");
Min_X_Property : constant Glib.Properties.Property_Float :=
Glib.Properties.Build ("min_x");
Max_X_Property : constant Glib.Properties.Property_Float :=
Glib.Properties.Build ("max_x");
Min_Y_Property : constant Glib.Properties.Property_Float :=
Glib.Properties.Build ("min_y");
Max_Y_Property : constant Glib.Properties.Property_Float :=
Glib.Properties.Build ("max_y");
pragma Import (C, Get_Type, "gtk_curve_get_type");
end Gtk.Curve;