|  |  |  | GIMP Widgets Library Reference Manual |  | 
|---|---|---|---|---|
| Top | Description | Object Hierarchy | Implemented Interfaces | Properties | Signals | ||||
GimpChainButton; enum GimpChainPosition; GtkWidget * gimp_chain_button_new (GimpChainPosition position); void gimp_chain_button_set_active (GimpChainButton *button,gboolean active); gboolean gimp_chain_button_get_active (GimpChainButton *button);
  GObject
   +----GInitiallyUnowned
         +----GtkObject
               +----GtkWidget
                     +----GtkContainer
                           +----GtkTable
                                 +----GimpChainButton
This widget provides a button showing either a linked or a broken chain that can be used to link two entries, spinbuttons, colors or other GUI elements and show that they may be locked. Use it for example to connect X and Y ratios to provide the possibility of a constrained aspect ratio.
The GimpChainButton only gives visual feedback, it does not really connect widgets. You have to take care of locking the values yourself by checking the state of the GimpChainButton whenever a value changes in one of the connected widgets and adjusting the other value if necessary.
typedef enum {
  GIMP_CHAIN_TOP,
  GIMP_CHAIN_LEFT,
  GIMP_CHAIN_BOTTOM,
  GIMP_CHAIN_RIGHT
} GimpChainPosition;
Possible chain positions for GimpChainButton.
GtkWidget *         gimp_chain_button_new               (GimpChainPosition position);
Creates a new GimpChainButton widget.
This returns a button showing either a broken or a linked chain and small clamps attached to both sides that visually group the two widgets you want to connect. This widget looks best when attached to a table taking up two columns (or rows respectively) next to the widgets that it is supposed to connect. It may work for more than two widgets, but the look is optimized for two.
| 
 | The position you are going to use for the button with respect to the widgets you want to chain. | 
| Returns : | Pointer to the new GimpChainButton, which is inactive
by default. Use gimp_chain_button_set_active()to
change its state. | 
void gimp_chain_button_set_active (GimpChainButton *button,gboolean active);
Sets the state of the GimpChainButton to be either locked (TRUE) or
unlocked (FALSE) and changes the showed pixmap to reflect the new state.
| 
 | Pointer to a GimpChainButton. | 
| 
 | The new state. | 
gboolean            gimp_chain_button_get_active        (GimpChainButton *button);
Checks the state of the GimpChainButton.
| 
 | Pointer to a GimpChainButton. | 
| Returns : | TRUEif the GimpChainButton is active (locked). | 
"position" property"position" GimpChainPosition : Read / Write / Construct Only
The position in which the chain button will be used.
Default value: GIMP_CHAIN_TOP
Since GIMP 2.4
"toggled" signalvoid                user_function                      (GimpChainButton *gimpchainbutton,
                                                        gpointer         user_data)            : Run First
| 
 | the object which received the signal. | 
| 
 | user data set when the signal handler was connected. | 
gimp_coordinates_new() to set up two GimpSizeEntries
           (see GimpSizeEntry) linked with a GimpChainButton.