Widgets
Widgets in the Fyne toolkit are designed for a clean and pleasant user interaction, following a standard theme and supporting rapid app development, solid testing and easy maintenance. There are various design considerations that promote that ambition, we explore them in this page.
Behaviour API
One thing that you will notice about the standard widgets is that the API is all about behaviour and state - but very little that controls the actual look of an element. This is by design. It enables our code, and that of app developers, to focus on the behaviour of a widget so that it’s rendering process can be left to other code. This makes it much easier to test, in fact full applications can be run through unit tests in memory without ever having to render the app.
You can extend an existing widget
to add new behaviours without needing to worry about how it is
rendered.
It is also possible to write your own
components, an application is not limited to using the provided
widget set.
When building your own widget you will notice that the rendering
details are completely separate from the state - this is part
of the design mentioned above. A WidgetRenderer
(the code that
renders a Widget
) typically holds a reference to the widget
that it will be rendering to access state or other information.
When a widget state changes then Refresh()
is called - the
renderer will then be asked to refresh and it should update the
display to reflect the new state.
Custom widgets are recommended to use the current Theme
but
can choose to specify their own sizes, colours and icons where
that seems desirable.
Content Padding
The standard widgets use the theme specified padding to make
appropriate space around their graphical components.
The widget
package uses a standard height and baseline to ensure that
provided layouts will align well by default.
If you are building a custom widget it is recommended to follow these guidelines.
The value of theme.Padding()
is used in layouts to space elements
of a container, it creates a consistent space around the various
parts of an application. Some widgets, however, have content that
should be inset from the edges of the extents. Consider Entry
,
It has a background and a border that go out to the edges, but its content
should be inset. And so we have standardised the amount of spacing used to
inset so that alignment matches.
The standard inset, or content padding, of a widget is defined as
theme.InnerPadding()
. The standard value of padding is 4
and the inner
padding is 8
. You can see in Label
and Entry
how the (text) content
is inset by this much so that their content will align horizontally and
vertically when placed next to each other.
It is recommended that custom widgets include similar dimensions so that they fit well alongside the standard widgets.