efl/src/lib/elementary/efl_ui_spinner.eo

175 lines
6.0 KiB
Plaintext

class Efl.Ui.Spinner (Efl.Ui.Layout, Efl.Ui.Spin,
Elm.Interface.Atspi.Value, Elm.Interface.Atspi_Widget_Action)
{
[[Elementary spinner class]]
legacy_prefix: elm_spinner;
event_prefix: elm_spinner;
methods {
@property wrap {
[[Control whether the spinner should wrap when it reaches its minimum or maximum value.
Disabled by default. If disabled, when the user tries to increment the
value,
but displayed value plus step value is bigger than maximum value,
the new value will be the maximum value.
The same happens when the user tries to decrement it,
but the value less step is less than minimum value. In this case,
the new displayed value will be the minimum value.
When wrap is enabled, when the user tries to increment the value,
but displayed value plus step value is bigger than maximum value,
the new value will be the minimum value. When the the user tries to
decrement it, but the value less step is less than minimum value,
the new displayed value will be the maximum value.
E.g.:
$min = 10
$max = 50
$step = 20
$displayed = 20
When the user decrement value (using left or bottom arrow), it will
displays $50.]]
set {
}
get {
}
values {
wrap: bool; [[$true to enable wrap or $false to disable it.]]
}
}
@property round {
[[Control the round value for rounding
Sets the rounding value used for value rounding in the spinner.]]
set {
}
get {
}
values {
rnd: int; [[The rounding value]]
}
}
@property editable {
[[Control whether the spinner can be directly edited by the user or not.
Spinner objects can have edition disabled, in which state they will
be changed only by arrows.
Useful for contexts
where you don't want your users to interact with it writing the value.
Specially
when using special values, the user can see real value instead
of special label on edition.
It's enabled by default.]]
set {
}
get {
}
values {
editable: bool; [[$true to allow users to edit it or $false to don't allow users to edit it directly.]]
}
}
@property base {
[[Control the base for rounding
Rounding works as follows:
rounded_val = base + (double)(((value - base) / round) * round)
Where rounded_val, value and base are doubles, and round is an integer.
This means that things will be rounded to increments (or decrements) of
"round" starting from value $base. The default base for rounding is 0.
Example: round = 3, base = 2
Values: ..., -2, 0, 2, 5, 8, 11, 14, ...
Example: round = 2, base = 5.5
Values: ..., -0.5, 1.5, 3.5, 5.5, 7.5, 9.5, 11.5, ...]]
set {
}
get {
}
values {
base: double; [[The base value]]
}
}
@property label_format {
[[Control the format string of the displayed label.
If $NULL, this sets the format to "%.0f". If not it sets the format
string for the label text. The label text is provided a floating point
value, so the label text can display up to 1 floating point value.
Note that this is optional.
Use a format string such as "%1.2f meters" for example, and it will
display values like: "3.14 meters" for a value equal to 3.14159.
Default is "%0.f".]]
set {
}
get {
}
values {
fmt: string @nullable; [[The format string for the label display.]]
}
}
special_value_add {
[[Control special string to display in the place of the numerical value.
It's useful for cases when a user should select an item that is
better indicated by a label than a value. For example, weekdays or months.
Note: If another label was previously set to $value, it will be replaced
by the new label.]]
/* FIXME-doc
E.g.:
@code
sp = elm_spinner_add(win);
elm_spinner_min_max_set(sp, 1, 3);
elm_spinner_special_value_add(sp, 1, "January");
elm_spinner_special_value_add(sp, 2, "February");
elm_spinner_special_value_add(sp, 3, "March");
evas_object_show(sp);
@endcode
*/
params {
@in value: double; [[The value to be replaced.]]
@in label: string; [[The label to be used.]]
}
}
}
implements {
class.constructor;
Efl.Object.constructor;
Elm.Widget.theme_apply;
Elm.Widget.focus_next_manager_is;
Elm.Widget.focus_direction_manager_is;
Elm.Widget.on_access_update;
Elm.Widget.focus_next;
Elm.Widget.focus_direction;
Elm.Widget.on_focus_update;
Elm.Widget.widget_event;
Efl.Ui.Spin.min_max { get; set; }
Efl.Ui.Spin.step { get; set; }
Efl.Ui.Spin.value { get; set; }
Efl.Ui.Spin.interval { get; set; }
Elm.Interface.Atspi_Accessible.name { get; }
Elm.Interface.Atspi.Value.value_and_text { get; set; }
Elm.Interface.Atspi.Value.range { get; }
Elm.Interface.Atspi.Value.increment { get; }
Elm.Interface.Atspi_Widget_Action.elm_actions { get; }
}
events {
changed; [[Called when spinner changed]]
delay,changed; [[Called when spinner delay changed]]
spinner,drag,start; [[Called when spinner drag started]]
spinner,drag,stop; [[Called when spinner drag stopped]]
min,reached; [[Called when spinner value reached min]]
max,reached; [[Called when spinner value reached max]]
}
}