123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327 |
- class IUP_TOGGLE
- -- Creates the toggle interface element. It is a two-state (on/off) button
- -- that, when selected, generates an action that activates a function in the
- -- associated application. Its visual representation can contain a text or an
- -- image.
- --
- -- Toggle with image or text can not change its behavior after mapped. This is
- -- a creation attribute. But after creation the image can be changed for
- -- another image, and the text for another text.
- --
- -- Toggles are activated using the Space key.
- --
- -- To build a set of mutual exclusive toggles, insert them in an IUP_RADIO
- -- container. They must be inserted before creation, and their behavior can not
- -- be changed. If you need to dynamically remove toggles that belongs to a
- -- radio in Windows, then put the radio inside an IUP_FRAME that has a title.
- --
- -- A toggle that is a child of an IUP_RADIO automatically receives a name when
- -- its is mapped into the native system.
- inherit
- IUP_BUTTON
- redefine
- execute_map,
- execute_unmap,
- execute_destroy,
- execute_getfocus,
- execute_killfocus,
- execute_enterwindow,
- execute_leavewindow,
- execute_k_any,
- execute_help,
- execute_action_fni,
- execute_valuechanged
- end
- IUP_WIDGET_IGNORERADIO
- IUP_WIDGET_IMPRESS_BORDER
- export
- {NONE} all
- end
- IUP_WIDGET_IMAGE_POSITION
- export
- {NONE} all
- end
- IUP_WIDGET_SPACING
- export
- {NONE} all
- end
- IUP_WIDGET_CB_ACTION
- export
- {NONE} all
- end
- IUP_WIDGET_CB_BUTTON
- export
- {NONE} all
- end
- IUP_WIDGET_TOGGLE
- create {ANY}
- toggle
- feature {ANY}
- toggle (title: STRING)
- -- A new toggle. title is the text to be shown on the toggle. It can be
- -- Void. It will set the TITLE attribute.
- local
- a_toggle, p: POINTER
- do
- if title /= Void then
- a_toggle := int_toggle(get_pointer(title.to_c), p)
- else
- a_toggle := int_toggle(p, p)
- end
-
- set_widget(a_toggle)
- end
- -- Attributes
- is_radio: BOOLEAN
- -- (read-only): returns if the toggle is inside a radio. Valid only after
- -- the element is mapped.
- local
- str: STRING
- do
- str := iup_open.get_attribute(Current, "RADIO")
- Result := yesno_to_boolean(str)
- end
- set_right_button (state: BOOLEAN)
- -- (Windows Only) (creation only): place the check button at the right of
- -- the text. Default: "False".
- do
- iup_open.set_attribute(Current, "RIGHTBUTTON", boolean_to_yesno(state))
- end
- set_value (value: STRING)
- -- (non inheritable): Toggle's state. Values can be "ON" or "OFF". If
- -- 3state=True then can also be "NOTDEF". Default: "OFF". In GTK if you
- -- change the state of a radio, the unchecked toggle will receive an
- -- ACTION callback notification. Can only be set to "ON" for a toggle
- -- inside a radio, it will automatically set to OFF the previous toggle
- -- that was ON.
- require
- is_valid_state (value)
- do
- iup_open.set_attribute(Current, "VALUE", value)
- end
- get_value: STRING
- do
- Result := iup_open.get_attribute(Current, "VALUE")
- end
- set_3state (state: BOOLEAN)
- -- (creation only): Enable a three state toggle. Valid for toggles with
- -- text only and that do not belong to a radio. Default: "False".
- do
- iup_open.set_attribute(Current, "3STATE", boolean_to_yesno(state))
- end
- -- Operations
- invert
- -- Invert the current state.
- do
- iup_open.set_attribute(Current, "VALUE", "TOGGLE")
- end
- -- Callbacks
- set_cb_toggle (act: detachable FUNCTION[TUPLE[IUP_TOGGLE, INTEGER], STRING])
- -- Action generated when the toggle's state (on/off) was changed. The
- -- callback also receives the toggle's state.
- --
- -- ih: identifier of the element that activated the event.
- -- state: 1 if the toggle's state was shifted to on; 0 if it was shifted
- -- to off.
- --
- -- Returns: IUP_CLOSE will be processed.
- local
- operation: INTEGER
- do
- cb_action_fni := act
- if cb_action_fni /= Void then
- operation := 1
- else
- operation := 0
- end
-
- iup_open.set_callback (Current, "ACTION", "Fn", operation)
- end
- set_cb_value_changed (act: detachable FUNCTION[TUPLE[IUP_TOGGLE], STRING])
- -- Called after the value was interactively changed by the
- -- user. Called after the ACTION callback, but under the same context.
- local
- operation: INTEGER
- do
- cb_valuechanged := act
- if cb_valuechanged /= Void then
- operation := 1
- else
- operation := 0
- end
-
- iup_open.set_callback (Current, "VALUECHANGED_CB", "NONEEDED", operation)
- end
- -- Validations
- is_valid_state (value: STRING): BOOLEAN
- do
- if value.is_equal("ON") or
- value.is_equal("OFF") or
- value.is_equal("NOTDEF") then
- Result := True
- else
- Result := False
- end
- end
- feature {IUP}
- -- Common callbacks
-
- execute_map: STRING
- do
- if attached cb_map as int_cb then
- Result := int_cb.item([Current])
- else
- Result := "IUP_DEFAULT"
- end
- end
- execute_unmap: STRING
- do
- if attached cb_unmap as int_cb then
- Result := int_cb.item([Current])
- else
- Result := "IUP_DEFAULT"
- end
- end
- execute_destroy: STRING
- do
- if attached cb_destroy as int_cb then
- Result := int_cb.item([Current])
- else
- Result := "IUP_DEFAULT"
- end
- end
- execute_getfocus: STRING
- do
- if attached cb_getfocus as int_cb then
- Result := int_cb.item([Current])
- else
- Result := "IUP_DEFAULT"
- end
- end
- execute_killfocus: STRING
- do
- if attached cb_killfocus as int_Cb then
- Result := int_cb.item([Current])
- else
- Result := "IUP_DEFAULT"
- end
- end
- execute_enterwindow: STRING
- do
- if attached cb_enterwindow as int_cb then
- Result := int_cb.item([Current])
- else
- Result := "IUP_DEFAULT"
- end
- end
- execute_leavewindow: STRING
- do
- if attached cb_leavewindow as int_cb then
- Result := int_cb.item([Current])
- else
- Result := "IUP_DEFAULT"
- end
- end
- execute_k_any (c: INTEGER): STRING
- do
- if attached cb_k_any as int_cb then
- Result := int_cb.item([Current, c])
- else
- Result := "IUP_DEFAULT"
- end
- end
- execute_help
- do
- if attached cb_help as int_cb then
- int_cb.call([Current])
- end
- end
- -- Extra
- execute_action_fni (state: INTEGER): STRING
- do
- if attached cb_action_fni as int_cb then
- Result := int_cb.item([Current, state])
- else
- Result := "IUP_DEFAULT"
- end
- end
- execute_valuechanged: STRING
- do
- if attached cb_valuechanged as int_cb then
- Result := int_cb.item([Current])
- else
- Result := "IUP_DEFAULT"
- end
- end
- feature {NONE}
- -- For callbacks
- cb_action_fni: detachable FUNCTION[TUPLE[IUP_TOGGLE, INTEGER], STRING]
- cb_valuechanged: detachable FUNCTION[TUPLE[IUP_TOGGLE], STRING]
- -- Internals
-
- int_toggle (title: POINTER; action: POINTER): POINTER
- external
- "C inline use %"eiffel-iup.h%""
- alias
- "return IupToggle ($title, $action);"
- end
- end
- -- The MIT License (MIT)
- -- Copyright (c) 2016, 2017, 2019, 2020 by German A. Arias
- -- Permission is hereby granted, free of charge, to any person obtaining a copy
- -- of this software and associated documentation files (the "Software"), to deal
- -- in the Software without restriction, including without limitation the rights
- -- to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
- -- copies of the Software, and to permit persons to whom the Software is
- -- furnished to do so, subject to the following conditions:
- --
- -- The above copyright notice and this permission notice shall be included in
- -- all copies or substantial portions of the Software.
- --
- -- THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- -- IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- -- FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
- -- AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
- -- LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
- -- OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
- -- SOFTWARE.
|