python-efl/efl/elementary/radio.pxi

126 lines
4.0 KiB
Cython

# Copyright (C) 2007-2022 various contributors (see AUTHORS)
#
# This file is part of Python-EFL.
#
# Python-EFL is free software; you can redistribute it and/or
# modify it under the terms of the GNU Lesser General Public
# License as published by the Free Software Foundation; either
# version 3 of the License, or (at your option) any later version.
#
# Python-EFL 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
# Lesser General Public License for more details.
#
# You should have received a copy of the GNU Lesser General Public License
# along with this Python-EFL. If not, see <http://www.gnu.org/licenses/>.
include "radio_cdef.pxi"
cdef class Radio(LayoutClass):
"""
This is the class that actually implements the widget.
"""
def __init__(self, evasObject parent, *args, **kwargs):
"""
:param parent: The parent object
:type parent: :py:class:`efl.evas.Object`
:param \**kwargs: All the remaining keyword arguments are interpreted
as properties of the instance
"""
self._set_obj(elm_radio_add(parent.obj))
self._set_properties_from_keyword_args(kwargs)
def group_add(self, evasObject group):
"""Add this radio to a group of other radio objects
Radio objects work in groups. Each member should have a different
integer value assigned. In order to have them work as a group, they
need to know about each other. This adds the given radio object to
the group of which the group object indicated is a member.
:param group: Any object whose group the object is to join.
:type group: :py:class:`Radio`
"""
elm_radio_group_add(self.obj, group.obj)
property state_value:
"""The integer value that this radio object represents
:type: int
"""
def __get__(self):
return elm_radio_state_value_get(self.obj)
def __set__(self, value):
elm_radio_state_value_set(self.obj, value)
def state_value_set(self, value):
elm_radio_state_value_set(self.obj, value)
def state_value_get(self):
return elm_radio_state_value_get(self.obj)
property value:
"""The value of the radio group.
This reflects the value of the radio group and will also set the
value if pointed to, to the value supplied, but will not call any
callbacks.
:type: int
"""
def __get__(self):
return elm_radio_value_get(self.obj)
def __set__(self, value):
elm_radio_value_set(self.obj, value)
def value_set(self, value):
elm_radio_value_set(self.obj, value)
def value_get(self):
return elm_radio_value_get(self.obj)
@DEPRECATED("1.8", "Don't use this, only works in C.")
def value_pointer_set(self, int value):
"""Set a convenience pointer to a integer to change when radio group
value changes.
This function DO NOTHING in python !! DO NOT USE !!
"""
# cdef int * valuep = <int *>value
# elm_radio_value_pointer_set(self.obj, valuep)
pass
property selected_object:
"""Get the selected radio object.
:type: :py:class:`Radio`
"""
def __get__(self):
return object_from_instance(elm_radio_selected_object_get(self.obj))
def selected_object_get(self):
return object_from_instance(elm_radio_selected_object_get(self.obj))
def callback_changed_add(self, func, *args, **kwargs):
"""This is called whenever the user changes the state of one of the
radio objects within the group of radio objects that work together.
"""
self._callback_add("changed", func, args, kwargs)
def callback_changed_del(self, func):
self._callback_del("changed", func)
_object_mapping_register("Efl.Ui.Radio_Legacy", Radio)