Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/tito/kaki
Kivy application library on steroid
https://github.com/tito/kaki
Last synced: 1 day ago
JSON representation
Kivy application library on steroid
- Host: GitHub
- URL: https://github.com/tito/kaki
- Owner: tito
- Created: 2018-02-25T15:57:20.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2023-07-03T08:55:21.000Z (over 1 year ago)
- Last Synced: 2024-09-24T04:20:05.191Z (9 days ago)
- Language: Python
- Size: 45.9 KB
- Stars: 51
- Watchers: 7
- Forks: 16
- Open Issues: 6
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Kaki - Advanced application library for Kivy
This library enhance Kivy frameworks with opiniated features such as:
- Auto reloading kv or py (`watchdog` required, limited to some uses cases)
- Idle detection support
- Foreground lock (windows only)## Example
This is a bootstrap that will:
- automatically declare the module `live.ui` (`live/ui.py`) as a provider for the widget `UI`
- build the application widget, and show it to a windowIf the bootstrap is started with the environment variable `DEBUG=1`, it will start a watchdog, and listen for changes, according to `AUTORELOADER_PATHS`.
When something changes, the current application widget will be cleared out, and a new one will be instanciated, after reloading.```python
from kaki.app import App
from kivy.factory import Factoryclass Live(App):
CLASSES = {
"UI": "live.ui"
}
AUTORELOADER_PATHS = [
(".", {"recursive": True}),
]
def build_app(self):
return Factory.UI()Live().run()
```## Application class configuration
#: Control either we activate debugging in the app or not
#: Defaults depend if "DEBUG" exists in os.environ
DEBUG = "DEBUG" in os.environ#: If true, it will require the foreground lock on windows
FOREGROUND_LOCK = False#: List of KV files under management for auto reloader
KV_FILES = []#: List of path to watch for autoreloading
AUTORELOADER_PATHS = [
# (".", {"recursive": False}),
]#: List of extensions to ignore
AUTORELOADER_IGNORE_PATTERNS = [
"*.pyc", "*__pycache__*"]#: Factory classes managed by kaki
CLASSES = {}#: Idle detection (if True, event on_idle/on_wakeup will be fired)
#: Rearming idle can also be done with rearm_idle()
IDLE_DETECTION = False#: Auto install idle detection check when activated
IDLE_DETECTION_AUTO_START = True#: Default idle timeout
IDLE_TIMEOUT = 60#: Raise error
#: When the DEBUG is activated, it will raise any error instead
#: of showing it on the screen. If you still want to show the error
#: when not in DEBUG, put this to False
RAISE_ERROR = True## Idle Management
The idle detection feature is designed to trigger an action if the user has not touched the screen for a certain period of time. This can be used to display an attractor screen, screensaver, or other content.
To enable idle detection, set the `IDLE_DETECTION` configuration to `True`.
Kaki will then listen for touch down/move events. If no such events occur within the `IDLE_TIMEOUT` interval, or if the `rearm_idle` function has not been called, the `on_idle` event will be triggered on the application class. If a touch event occurs or `rearm_idle` is called while the system is in idle mode, the `on_wakeup` event will be triggered on the application class.If you are playing a video and do not want idle detection to be triggered, you can use the `rearm_idle` function on the application class to reset the idle timer to 0 seconds.