| Top | Description | Object Hierarchy | Implemented Interfaces | Properties | Signals |  |  |  |  | 
#include <libgwydgets/gwydgets.h> struct GwyMarkerBox; struct GwyMarkerBoxClass; gboolean (*GwyMarkerValidateFunc) (GwyMarkerBox *mbox,GwyMarkerOperationType optype,gint *i,gdouble *pos); gint gwy_marker_box_get_selected_marker (GwyMarkerBox *mbox); void gwy_marker_box_set_selected_marker (GwyMarkerBox *mbox,gint i); gdouble gwy_marker_box_get_marker_position (GwyMarkerBox *mbox,gint i); gboolean gwy_marker_box_set_marker_position (GwyMarkerBox *mbox,gint i,gdouble pos); gint gwy_marker_box_add_marker (GwyMarkerBox *mbox,gint i,gdouble pos); gboolean gwy_marker_box_remove_marker (GwyMarkerBox *mbox,gint i); gint gwy_marker_box_get_nmarkers (GwyMarkerBox *mbox); const gdouble * gwy_marker_box_get_markers (GwyMarkerBox *mbox); void gwy_marker_box_set_markers (GwyMarkerBox *mbox,gint n,const gdouble *markers); void gwy_marker_box_set_flipped (GwyMarkerBox *mbox,gboolean flipped); gboolean gwy_marker_box_get_flipped (GwyMarkerBox *mbox); void gwy_marker_box_set_highlight_selected (GwyMarkerBox *mbox,gboolean highlight); gboolean gwy_marker_box_get_highlight_selected (GwyMarkerBox *mbox); void gwy_marker_box_set_validator (GwyMarkerBox *mbox,GwyMarkerValidateFunc validate); GwyMarkerValidateFunc gwy_marker_box_get_validator (GwyMarkerBox *mbox);
GObject +----GInitiallyUnowned +----GtkObject +----GtkWidget +----GwyMarkerBox +----GwyHMarkerBox
"flipped" gboolean : Read / Write "highlight-selected" gboolean : Read / Write "selected-marker" gint : Read / Write
"marker-added" :Run First"marker-moved" :Run First"marker-removed" :Run First"marker-selected" :Run First"markers-set" :Run First
GwyMarkerBox is a box with triangular markers that can be moved, added, and/or deleted. One or no marker can be selected.
Marker coordinates are always from the range [0.0, 1.0].
It is possible to fully control where and how user can move, add, and/or
delete markers with marker validation function set with
gwy_marker_box_set_validator().  By default, no validator is in effect
and user can change markers completely freely.
struct GwyMarkerBoxClass {
    GtkWidgetClass parent_class;
    /* signals */
    void (*marker_selected)(GwyMarkerBox *mbox,
                            gint i);
    void (*marker_moved)(GwyMarkerBox *mbox,
                         gint i);
    void (*marker_added)(GwyMarkerBox *mbox,
                         gint i);
    void (*marker_removed)(GwyMarkerBox *mbox,
                           gint i);
    void (*markers_set)(GwyMarkerBox *mbox);
    /* virtual methods */
    void (*draw_box)(GwyMarkerBox *mbox);
    void (*draw_marker)(GwyMarkerBox *mbox,
                        gint i);
    void (*reserved1)(void);
    void (*reserved2)(void);
    void (*reserved3)(void);
};
gboolean (*GwyMarkerValidateFunc) (GwyMarkerBox *mbox,GwyMarkerOperationType optype,gint *i,gdouble *pos);
Marker validation function.
It is called for each single-marker change, both by user and by
GwyMarkerBox methods.  However, it is NOT called upon
gwy_marker_box_set_markers() as it is unclear how the validation should
proceed.
The function must not have any side-effects, that is it must not assume the
operation will be actually performed when it returns TRUE.
Marker validator that allows free marker movement but disables insertion and removal could look:
| 1 2 3 4 5 6 7 8 9 10 11 | static gboolean validate_marker(GwyMarkerBox *mbox, GwyMarkerOperationType optype, gint *i, gdouble *pos) { if (optype == GWY_MARKER_OPERATION_ADD || optype == GWY_MARKER_OPERATION_REMOVE) return FALSE; return TRUE; } | 
Marker validator that assures markers are sorted and there is always a marker at 0.0 and another at 1.0 could look:
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 | static gboolean validate_marker(GwyMarkerBox *mbox, GwyMarkerOperationType optype, gint *i, gdouble *pos) { const gdouble *markers; gint j, n; n = gwy_marker_box_get_nmarkers(mbox); /* Insertions are sorted */ if (optype == GWY_MARKER_OPERATION_ADD) { markers = gwy_marker_box_get_markers(mbox); for (j = 0; j < n; j++) { if (*pos < markers[j]) break; } if (j == 0 || j == n) return FALSE; *i = j; return TRUE; } /* Nothing at all can be done with border markers */ if (*i == 0 || *i == n-1) return FALSE; /* Inner markers can be moved only from previous to next */ if (optype == GWY_MARKER_OPERATION_MOVE) { markers = gwy_marker_box_get_markers(mbox); *pos = CLAMP(*pos, markers[*i - 1], markers[*i + 1]); } return TRUE; } | 
| 
 | The GwyMarkerBox to validate markers for. | 
| 
 | Marker operation to validate. | 
| 
 | Pointer to index of marker to validate. For insertion, it's the position the marker would be inserted to (but it's not there yet), for removal it's the position where it still is. The validator can change the index, but it has an effect only when a marker is being added. | 
| 
 | Pointer to requested marker position. The validator can change the position and the marker will be then moved or inserted to the changed position. For removal, its changes have no effect. | 
| Returns : | TRUEto allow requested the operation,FALSEto disallow it. | 
gint                gwy_marker_box_get_selected_marker  (GwyMarkerBox *mbox);
Gets the index of the currently selected marker in a marker box.
| 
 | A marker box. | 
| Returns : | The index of currently selected marker, -1 when none is selected. | 
void gwy_marker_box_set_selected_marker (GwyMarkerBox *mbox,gint i);
Selects a marker in a marker box.
| 
 | A marker box. | 
| 
 | The index of marker to select. Pass -1 to unselect. | 
gdouble gwy_marker_box_get_marker_position (GwyMarkerBox *mbox,gint i);
Gets the position of a marker in a marker box.
| 
 | A marker box. | 
| 
 | The index of marker to get position of. | 
| Returns : | The marker position, in the range [0.0, 1.0]. | 
gboolean gwy_marker_box_set_marker_position (GwyMarkerBox *mbox,gint i,gdouble pos);
Moves a marker in a marker box.
gint gwy_marker_box_add_marker (GwyMarkerBox *mbox,gint i,gdouble pos);
Adds a marker to a marker box.
| 
 | A marker box. | 
| 
 | Index to insert marker at. | 
| 
 | Position to insert marker to, in the range [0.0, 1.0]. | 
| Returns : | On success, the index the marker was added at. If the insertion does not validate, -1 is returned and no marker is added. | 
gboolean gwy_marker_box_remove_marker (GwyMarkerBox *mbox,gint i);
Removes a marker from a marker box.
gint                gwy_marker_box_get_nmarkers         (GwyMarkerBox *mbox);
Gets the number of markers in a marker box.
| 
 | A marker box. | 
| Returns : | The number of markers. | 
const gdouble *     gwy_marker_box_get_markers          (GwyMarkerBox *mbox);
Gets all markers in a marker box.
| 
 | A marker box. | 
| Returns : | The markers as an array of positions, owned by mbox.  It must
not be modified nor freed by caller and it's valid only until
next marker change. | 
void gwy_marker_box_set_markers (GwyMarkerBox *mbox,gint n,const gdouble *markers);
Sets positions of all markers in a marker box.
No validation is performed, even if validator is set. It's up to caller to set markers that do not logically conflict with the validator.
| 
 | A marker box. | 
| 
 | The number of markers to set.  If it is zero, markerscan beNULL. | 
| 
 | Markers position. | 
void gwy_marker_box_set_flipped (GwyMarkerBox *mbox,gboolean flipped);
Sets whether a marker box is drawn upside down.
| 
 | A marker box. | 
| 
 | TRUEto draw markers upside down. | 
gboolean            gwy_marker_box_get_flipped          (GwyMarkerBox *mbox);
Returns whether a marker box is drawn upside down.
| 
 | A marker box. | 
| Returns : | TRUEif markers are drawn upside down. | 
void gwy_marker_box_set_highlight_selected (GwyMarkerBox *mbox,gboolean highlight);
Sets whether a marker box highlights selected marker.
gboolean            gwy_marker_box_get_highlight_selected
                                                        (GwyMarkerBox *mbox);
Returns whether a marker box highlights selected marker.
void gwy_marker_box_set_validator (GwyMarkerBox *mbox,GwyMarkerValidateFunc validate);
Sets marker box marker validation function.
It is used the next time an attempt to change markers is made, no revalidation is done immediately. It's up to caller to set a validator that do not logically conflict with the distribution of markers.
| 
 | A marker box. | 
| 
 | Marker validation function.  Pass NULLto disable validation. | 
GwyMarkerValidateFunc gwy_marker_box_get_validator      (GwyMarkerBox *mbox);
Gets the marker validation function currently in use.
| 
 | A marker box. | 
| Returns : | The marker validation function. | 
"flipped" property"flipped" gboolean : Read / Write
Whether marks are drawn upside down.
Default value: FALSE
"highlight-selected" property"highlight-selected" gboolean : Read / Write
Whether to visually differentiate selected marker.
Default value: TRUE
"selected-marker" property"selected-marker" gint : Read / Write
The index of selected marker, -1 if none.
Allowed values: [-1,1024]
Default value: -1
"marker-added" signalvoid                user_function                      (GwyMarkerBox *arg1,
                                                        gint          gwymarkerbox,
                                                        gpointer      user_data)         : Run First
The ::marker-added signal is emitted when a marker is added.
| 
 | The index a marker was added at. | 
| 
 | The GwyMarkerBox which received the signal. | 
| 
 | user data set when the signal handler was connected. | 
"marker-moved" signalvoid                user_function                      (GwyMarkerBox *arg1,
                                                        gint          gwymarkerbox,
                                                        gpointer      user_data)         : Run First
The ::marker-moved signal is emitted when a marker is moved.
| 
 | The index of moved marker. | 
| 
 | The GwyMarkerBox which received the signal. | 
| 
 | user data set when the signal handler was connected. | 
"marker-removed" signalvoid                user_function                      (GwyMarkerBox *arg1,
                                                        gint          gwymarkerbox,
                                                        gpointer      user_data)         : Run First
The ::marker-removed signal is emitted when a marker is removed.
| 
 | The index a marker was removed from. | 
| 
 | The GwyMarkerBox which received the signal. | 
| 
 | user data set when the signal handler was connected. | 
"marker-selected" signalvoid                user_function                      (GwyMarkerBox *arg1,
                                                        gint          gwymarkerbox,
                                                        gpointer      user_data)         : Run First
The ::marker-selected signal is emitted when marker selection changes.
| 
 | The index of selected marker, -1 when marker was unselected. | 
| 
 | The GwyMarkerBox which received the signal. | 
| 
 | user data set when the signal handler was connected. | 
"markers-set" signalvoid                user_function                      (GwyMarkerBox *gwymarkerbox,
                                                        gpointer      user_data)         : Run First
The ::markers-set signal is emitted when markers are explicitly set
with gwy_marker_box_set_markers().
| 
 | The GwyMarkerBox which received the signal. | 
| 
 | user data set when the signal handler was connected. |