1# Tasmota and berry
2
3## What is Tasmota?
4
5[Tasmota](https://github.com/arendst/Tasmota) is a widely used open-source firmware for ESP8266 and EPS32 based devices. It supports a wide variety of devices, sensors and integrations to Home Automation and Cloud services. Tasmota firmware is downloaded more than 200,000 times each month, and has an active and growing community.
6
7Tasmota provides access to hundreds of supported devices, full support of MQTT, HTTP(S), integration with major Home Automation systems, myriad of sensors, IR, RF, Zigbee, Bluetooth, AWS IoT, Azure IoT, Alexa and many more.
8
9## What is Berry?
10
11[Berry](https://github.com/berry-lang/berry) is a ultra-lightweight dynamically typed embedded scripting language. It is designed for lower-performance embedded devices. The interpreter of Berry include a one-pass compiler and register-based VM, all the code is written in ANSI C99. Berry offers a syntax very similar to Python, and is inspired from LUA VM. It is fully integrated in Tasmota
12
13### Highlights of Berry
14
15Berry has the following advantages:
16
17- Lightweight: A well-optimized interpreter with very little resources. Ideal for use in microprocessors.
18- Fast: optimized one-pass bytecode compiler and register-based virtual machine.
19- Powerful: supports imperative programming, object-oriented programming, functional programming.
20- Flexible: Berry is a dynamic type script, and it's intended for embedding in applications. It can provide good dynamic scalability for the host system.
21- Simple: simple and natural syntax, support garbage collection, and easy to use FFI (foreign function interface).
22- RAM saving: With compile-time object construction, most of the constant objects are stored in read-only code data segments, so the RAM usage of the interpreter is very low when it starts.
23
24All features are detailed in the [Berry Reference Manual](https://github.com/berry-lang/berry/wiki/Reference)
25
26---
27
28## Why LVGL + Tasmota + Berry?
29
30In 2021, Tasmota added full support of LVGL for ESP32 based devices. It also introduced the Berry scripting language, a small-footprint language similar to Python and fully integrated in Tasmota.
31
32A comprehensive mapping of LVGL in Berry language is now available, similar to the mapping of Micropython. It allows to use +98% of all LVGL features. It is also possible to write custom widgets in Berry.
33
34Versions supported: LVGL v8.3.0, LodePNG v20201017, Freetype 2.10.4
35
36### Tasmota + Berry + LVGL could be used for:
37
38- Fast prototyping GUI.
39- Shortening the cycle of changing and fine-tuning the GUI.
40- Modelling the GUI in a more abstract way by defining reusable composite objects, taking advantage of Berry's language features such as Inheritance, Closures, Exception Handling...
41- Make LVGL accessible to a larger audience. No need to know C to create a nice GUI on an embedded system.
42
43A higher level interface compatible with [OpenHASP](https://github.com/HASwitchPlate/openHASP) is also under development.
44
45---
46
47## So what does it look like?
48
49> TL;DR:
50> Similar to MicroPython, it's very much like the C API, but Object-Oriented for LVGL components.
51
52Let's dive right into an example!
53
54### A simple example
55
56```python
57lv.start()                 # start LVGL
58scr = lv.scr_act()         # get default screen
59btn = lv.btn(scr)          # create button
60btn.center()
61label = lv.label(btn)      # create a label in the button
62label.set_text("Button")   # set a label to the button
63```
64
65## How can I use it?
66
67You can start in less than 10 minutes on a M5Stack or equivalent device in less than 10 minutes in this [short tutorial](https://tasmota.github.io/docs/LVGL_in_10_minutes/)
68
69## Where can I find more information?
70
71- [Tasmota Documentation](https://tasmota.github.io/docs/)
72- [Berry Documentation](https://github.com/berry-lang/berry/wiki/Reference)
73- [Tasmota LVGL Berry documentation](https://tasmota.github.io/docs/LVGL/)
74