Fyne (software)

Fyne is a free and open-source cross-platform widget toolkit for creating graphical user interfaces (GUIs) across desktop and mobile platforms. It is inspired by the principles of Material Design to create applications that look and behave consistently across all platforms.[2] It is licensed under the terms of the 3-clause BSD License, supporting the creation of free and proprietary applications. In December 2019 Fyne became the most popular GUI toolkit for Go, by GitHub star count[3] and in early February 2020 it was trending as #1 project in GitHub trending ranks.[4]

Fyne
Screenshot of fyne_demo showcasing many widgets
Original author(s)Andrew Williams
Developer(s)Andrew Williams, Tilo Prütz, Luca Corbo, Steve O'Connor, Stephen Houston, Stuart Scott
Initial releaseFebruary 5, 2018 (2018-02-05)
Stable release
1.3.0 / June 6, 2020 (2020-06-06)[1]
Written inGo
Operating systemLinux, Unix-like, macOS, Windows, IOS, Android (operating system)
TypeWidget toolkit
LicenseNew BSD License
Websitefyne.io

Development

Fyne is currently developed by a team of volunteers and is supported by around 40 contributors.[5] Members of this group also work on the FyneDesk project to create a new Linux desktop environment.[6]

The Fyne toolkit is written primarily in Go.[7] The team focuses on clean APIs and follows the principles of Clean Code to sustain maintainability of the project.[8] All Fyne projects are continuously tested to check correctness, stability as well as formatting and documentation.[9][10]

Example

The code required for a simple "Hello World" application is minimal, as follows:

package main

import (
	"fyne.io/fyne/app"
	"fyne.io/fyne/widget"
)

func main() {
	a := app.New()

	w := a.NewWindow("Hello")
	w.SetContent(widget.NewVBox(
		widget.NewLabel("Hello Fyne!"),
		widget.NewButton("Quit", func() {
			a.Quit()
		}),
	))

	w.ShowAndRun()
}

To build this application you will need the Go language and a C compiler installed, as well as a graphics driver that supports OpenGL. It an be built and run using the command: $ go run main.go

Design

Design of the Fyne API and user interface components follows a careful process to ensure the simplicity.[11] The Fyne toolkit is built in various layers, with each in separate packages. Notable layers include:[12]

API

API, or Application programming interface, is an interface or protocol that allows for communication across different parts of the software. Fyne has a self-documenting API that is also extensible resulting in the ability for each developer to create custom tools unique to their project that will mesh with Fyne itself.

Vector graphics

The use of vector graphics to paint the UI provides a method of adapting to different device and display sizes without losing image fidelity. This allows the programmer to only need to create the UI once and it will look as expected on any device.

Hierarchy

Canvas

Canvas contains all of the contents of a window ranging from the full screen to a group of CanvasObjects.

CanvasObject

CanvasObjects are what actually get rendered on screen such as Text, Rectangle, Line. The objects store size, position and color information for the rendering process.

Container

Containers are groups of CanvasObjects, each container can specify a layout which will contain the sizing and position of its child components. Layouts help the developer arrange components in a manner that response to the container or window size, with several layout types provided including Border, Center, and Grid.

Widget

All of the components of a window in a CanvasObject are widgets that contain standard user interface elements. Fyne widgets include but are not limited to UI basics such as: Button, Check, Form, Hyperlink, Label, TabContainer, and Toolbar. Basic UI widgets ensure that standard aspects of GUI interactivity act in a predictable and expected way across applications. This helps improve quality of programs while assisting the programmer by removing the need for them to create these tools themself.

Packages

All components of Fyne are split into packages and then connected via the API to create a final GUI application. In addition to the canvas, layout, and widget packages, notable packages include:

  • App package which is the main entry point for the app which manages understanding the type of device the application is running on and ensures the code will run as expected on that device.
  • Test package enabling test-driven development to validate the GUI itself functions as expected.

Use

The largest project currently using the Fyne toolkit is the FyneDesk project, a complete desktop environment for Linux.[13]

There are many other applications being built using the toolkit, those that are open source can be found in an application listing[14] website managed by the project.

Many businesses are using the Fyne toolkit to quickly add a graphical user interface to command line tools which they have already built using Go.

Releases

  • 1.2 - Mobile Support[15]
    • Addition of Mobile support (iOS and Android)
    • Addition of support for Raspberry Pi devices (and other OpenGL ES devices)
    • BaseWidget introduced to simplify creation of custom widgets
  • 1.1 - Feature Release[16]
    • MenuBar, PopUpMenu, Select widgets added
    • Gradient primitive added and shadows introduced
    • Added support for text selection
    • Support for disabling widgets
    • Tab / Shift-Tab introduced to rotate focused elements
  • 1.0 - First Major Release[17]
    • Introduced canvas API for drawing primitives
    • Introduced widget API including Box, Button, Check, Entry, Form, Group, Hyperlink, Icon, Label, ProgressBar, Radio, Scroller, TabContainer and Toolbar
    • Light and dark themes for user interface
    • Support for Linux, macOS and Windows operating systems

Criticism

Issue 299 of Golang Weekly noted the new mobile support from the Fyne project but suggested the design aesthetic was less Material Design and more "generally Linux-y".[18]

gollark: Also, I *just today* heard about a python interpreter in JS.
gollark: You could generate that script tag in JS, but no sane browser supports that insanity.
gollark: Hack the Matrix!
gollark: Pyτhon and Jαvaςrιpt are the best markup languages.
gollark: As an elite h4xx0r I can just parse HTML, the best programming language, in my head.

References

Bibliography

This article is issued from Wikipedia. The text is licensed under Creative Commons - Attribution - Sharealike. Additional terms may apply for the media files.