Skip to content

Latest commit

 

History

History
38 lines (29 loc) · 1.83 KB

README.md

File metadata and controls

38 lines (29 loc) · 1.83 KB

Kivy Lazy Loading - Template

Enhance the performance of your Kivy app 🚀 with lazy loading.

By implementing this template, you can enhance the performance of your Kivy app through the technique of lazy loading screens. Rather than loading all the screens at startup, this approach ensures that screens are loaded only when they are actively switched to. As a result, the startup time of your app can be significantly reduced.

This template also features a screen navigation system that simplifies handling the back button.

Navigation

The Root is based on ScreenManager and additionally provides a few navigation methods: push(screen_name, side), push_replacement(screen_name, side) and pop().

Also load_screen(screen_name) method can be used to load the screen and the kv file without setting it as the current screen.

To incorporate additional screens into your app, follow these steps:

  1. Create screen_file.py in the libs/uix/baseclass/ directory.
  2. Create screen_file.kv in the libs/uix/kv/ directory.
  3. Add the screen details to screens.json as shown below:
{
    ...,
    "screen_name": {
        "import": "from libs.uix.baseclass.screen_file import ScreenObjectName",
        "object": "ScreenObjectName()",
        "kv": "libs/uix/kv/screen_file.kv"
    }
}

This template already contains three screens as example which uses all the navigation methods.

Buildozer

To use this template for mobile devices, make sure to add json to your buildozer.spec file, such as

# (list) Source files to include (let empty to include all the files)
source.include_exts = py,png,jpg,kv,atlas,gif,json

Further details are documented within the code itself.