Kivy (framework)
This article needs additional citations for verification. (June 2012) |
Developer(s) | Kivy organization |
---|---|
Initial release | February 1, 2011[1] |
Stable release | 1.10.1
/ 8 July 2018[1] |
Repository | |
Written in | Python, Cython |
Operating system | Cross-platform |
Type | Application framework |
License | MIT (Free software) |
Website | kivy |
Kivy is an open source Python library for developing mobile apps and other multitouch application software with a natural user interface (NUI). It can run on Android, iOS, Linux, OS X, and Windows. Distributed under the terms of the MIT license, Kivy is free and open source software.
Kivy is the main framework developed by the Kivy organization,[2] alongside Python for Android,[3] Kivy iOS,[4] and several other libraries meant to be used on all platforms. In 2012, Kivy got a $5000 grant from the Python Software Foundation for porting it to Python 3.3.[5] Kivy also supports the Raspberry Pi which was funded through Bountysource.[6]
The framework contains all the elements for building an application such as:
- extensive input support for mouse, keyboard, TUIO, and OS-specific multitouch events,
- a graphic library using only OpenGL ES 2, and based on Vertex Buffer Object and shaders,
- a wide range of widgets that support multitouch,
- an intermediate language (Kv)[7] used to easily design custom widgets.
Kivy is the evolution of the PyMT project, and is recommended for new projects.[8]
Sister projects
- Buildozer: generic Python packager for Android and iOS.
- Plyer: platform-independent Python wrapper for platform-dependent APIs.
- Pyjnius: dynamic access to the Java/Android API from Python.
- Pyobjus: dynamic access to the Objective-C/iOS API from Python.
- Python for Android: toolchain for building and packaging Python applications for Android.
- Kivy iOS: toolchain for building and packaging Kivy applications for iOS.
- Audiostream: library for direct access to the microphone and speaker.
- Kivy Designer: UI designer for Kivy.
- KivEnt: entity-based game engine for Kivy.
- Garden: widgets and libraries created and maintained by users.
- kivy-sdk-packager: Scripts for Kivy SDK generation on Windows, OS X and Linux
- kivy-remote-shell: Remote SSH+Python interactive shell application.
- KivyPie: Raspbian based distro running latest Kivy framework on the Raspberry Pi.
- OSCPy: a fast and reliable OSC implementation compatible with python2.7 and 3.6+
Code example
Here is an example of the Hello world program with just one button:
from kivy.app import App
from kivy.uix.button import Button
class TestApp(App):
def build(self):
return Button(text='Hello World')
TestApp().run()
Kv language
The Kivy language (Kv) is a language dedicated to describing user interface and interactions. As with other user interface markup languages, it is possible to easily create a whole UI and attach interaction. For example, to create a Loading dialog that includes a file browser, and a Cancel / Load button, one could first create the base widget in Python, and then construct the UI in Kv.
In main.py:
class LoadDialog(FloatLayout):
def load(self, filename): pass
def cancel(self): pass
And in the associated Kv:
#:kivy 1.4.0
<LoadDialog>:
BoxLayout:
size: root.size
pos: root.pos
orientation: "vertical"
FileChooserListView:
id: filechooser
BoxLayout:
size_hint_y: None
height: 30
Button:
text: "Cancel"
on_release: root.cancel()
Button:
text: "Load"
on_release: root.load(filechooser.path, filechooser.selection)
Google Summer of Code
Kivy participated in Google Summer of Code under Python Software Foundation.
References
- ^ a b "Kivy changelog", kivy.org, retrieved 2016-04-05
- ^ "About us", kivy.org
- ^ "Python for Android", github.com
- ^ "Kivy for iOS", github.com
- ^ "Kivy and Python 3.3, project started", Google Groups
- ^ "Kivy on Raspberry Pi", bountysource.com
- ^ "Programming Guide » Kv language", kivy.org
- ^ "FAQ: How is Kivy related to PyMT?", kivy.org, retrieved 2012-06-09
- ^ "Google Summer of Code 2014 Organization Python Software Foundation".
{{cite web}}
: Cite has empty unknown parameter:|dead-url=
(help) - ^ "Google Summer of Code 2015 Organization Python Software Foundation".
{{cite web}}
: Cite has empty unknown parameter:|dead-url=
(help) - ^ "Google Summer of Code 2016 @ the Python Software Foundation".
{{cite web}}
: Cite has empty unknown parameter:|dead-url=
(help)
See also
- Pygame, another Python game API, a layer over Simple DirectMedia Layer
- Cocos2d
- Panda3D
- Pyglet