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 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56
|
# (C) Copyright 2004-2023 Enthought, Inc., Austin, TX
# All rights reserved.
#
# This software is provided without warranty under the terms of the BSD
# license included in LICENSE.txt and may be redistributed only under
# the conditions described in the aforementioned license. The license
# is also available online at http://www.enthought.com/licenses/BSD.txt
#
# Thanks for using Enthought open source!
"""
Button editor
A Button trait is displayed as a button in a Traits UI view. When the button is
clicked, Traits UI will execute a method of your choice (a 'listener').
In this example, the listener just increments a click counter.
Please refer to the `ButtonEditor API docs`_ for further information.
.. _ButtonEditor API docs: https://docs.enthought.com/traitsui/api/traitsui.editors.button_editor.html#traitsui.editors.button_editor.ButtonEditor
"""
from traits.api import HasTraits, Button, Int, observe
from traitsui.api import Item, View
class ButtonEditorDemo(HasTraits):
"""Defines the main ButtonEditor demo class."""
# Define a Button trait:
my_button_trait = Button('Click Me')
click_counter = Int(0)
# When the button is clicked, do something.
@observe("my_button_trait")
def _increment_counter(self, event):
self.click_counter += 1
# Demo view:
traits_view = View(
'my_button_trait',
Item('click_counter', style='readonly'),
title='ButtonEditor',
buttons=['OK'],
resizable=True,
)
# Create the demo:
demo = ButtonEditorDemo()
# Run the demo (if invoked from the command line):
if __name__ == '__main__':
demo.configure_traits()
|