Embedded Linux embedding for Flutter

  Flutter App

Embedded Linux (eLinux) embedding for Flutter

image

This project was created to develop non-official embedded Linux embeddings of Flutter. This embedder is focusing on embedded Linux system use cases. It is also implemented based on Flutter desktop for Windows and has some unique features to use it in embedded systems.

flutter-elinux

Note that this project is the source code of the embedder. If you develop your flutter app for eLinux, use flutter-elinux, which is a non-official extension to the Flutter SDK to build and debug Flutter apps for embedded Linux devices.

Objective & Goal

Our objective is to use Flutter in embedded systems. We’re developing this embedder to use Flutter in embedded products. Ultimately we would like to propose and contribute this software to the mainline of Flutter Engine, which means we would like to add an embedded systems version into the Flutter repo for all embedded developers. Please note that this is just our ideal, not the official opinion of the Flutter community.

We would be grateful if you could give us feedback on bugs and new feature requests. We would like to cover the specifications of general-purpose embedded systems.

Features

  • Flutter embedder optimized for Embedded Systems
    • Lightweight than Flutter desktop for Linux (Not using X11 and GTK)
    • Minimal dependent libraries
    • The main target of this embedder is Arm64 devices. We haven’t confirmed in Arm 32bit (ARMv7, armhf) devices
  • Display backend support
  • Always single window fullscreen
    • You can choose always-fullscreen or flexible-screen (any size) only when using Wayland/X11 backend
  • Keyboard, mouse and touch inputs support
  • Equivalent quality to Flutter desktops
  • API compatibility with Flutter desktop for Windows and GLFW
    • APIs such as MethodChannel and EventChannel are completely the same with them

Companion repos

RepoPurpose
flutter-elinuxFlutter tools for eLinux
flutter-elinux-pluginsFlutter plugins for eLinux
meta-flutterYocto recipes of eLinux embedding for Flutter

Documentation

Documentation for this software can be found at Wiki.

Supported platforms

This embedder supports x64 and Arm64 (aarch64, ARMv8) architectures on Linux which supports either Wayland backend or DRM backend.

Tested devices

Board / SoCVendorOS / BSPBackendStatus
Jetson NanoNVIDIAJetPack 4.3Waylandheavy_check_mark
Jetson NanoNVIDIAJetPack 4.3DRMheavy_check_mark (#1)
Raspberry Pi 4 Model BRaspberry Pi FoundationUbuntu 20.10Waylandheavy_check_mark
Raspberry Pi 4 Model BRaspberry Pi FoundationUbuntu 20.10DRMheavy_check_mark (#9)
i.MX 8MQuad EVKNXPSumo (kernel 4.14.98)Waylandheavy_check_mark
i.MX 8M Mini EVKBNXPZeus (kernel 5.4.70)Waylandheavy_check_mark
RB5 Development KitQualcommUbuntu 18.04.05DRMheavy_check_mark
ZynqXilinxNot tested
Desktop (x86_64)IntelUbuntu 20.04Waylandheavy_check_mark
Desktop (x86_64)IntelUbuntu 20.04DRMheavy_check_mark
Desktop (x86_64)IntelUbuntu 20.04X11heavy_check_mark
QEMU (x86_64)QEMUAGL (Automotive Grade Linux) koiWaylandheavy_check_mark
QEMU (x86_64)QEMUAGL (Automotive Grade Linux) koiDRMheavy_check_mark

Note

  • i.MX 8M platforms don’t support applications using EGL on GBM, which means the DRM-GBM backend won’t work on i.MX 8M devices.

Tested Wayland compositors

Westonheavy_check_markSwayheavy_check_markWayfireheavy_check_markGnomeheavy_check_markPhoshheavy_check_mark
Cageheavy_check_markLomiriheavy_check_markPlasma Waylandheavy_check_markPlasma Mobileheavy_check_markGlacierUXheavy_check_mark

Contributing

Now, we cannot accept any Pull Request (PR). Because We are building a system (e.g. CLA) to accept PRs, so please wait for a while the system is getting ready! However, we are always welcome to report bugs and request new features by creating issues.

With the assumption, our final goal of this software openly is to be merged this embedder into Flutter Engine after getting feedbacks. And Google CLA will be required when we do that in the future. Therefore, we cannot easily accept an external PR. However, you can free to create issues for reporting bugs and requesting new features.

Contribute on GitHub

https://github.com/sony/flutter-embedded-linux