Flutter (Software)

aus Wikipedia, der freien Enzyklopädie
Zur Navigation springen Zur Suche springen
Flutter

Google-flutter-logo.png
Basisdaten

Entwickler Google
Erscheinungsjahr 2017[1]
Aktuelle Version 1.22.6[2]
(26. Januar 2021)
Betriebssystem Android, iOS, Windows, Linux, macOS, Google Fuchsia[3][4]
Programmiersprache Dart
Kategorie Framework
Lizenz BSD
https://flutter.dev

Flutter ist ein Open-Source-UI-Entwicklungs-Kit von Google. Mit Flutter können Cross-Platform Apps in der Programmiersprache Dart entwickelt werden. Ein Flutter-Programm soll ohne größere Anpassungen auf folgenden Zielplattformen lauffähig sein: WebApp, Android, iOS, Windows, Linux, macOS und Google Fuchsia.[5][3][4] Laut Hersteller liegt der Fokus von Flutter auf kurzen Entwicklungszeiten, schneller Ausführungsgeschwindigkeit und "nativer User Experience".[6]

Aufbau[Bearbeiten | Quelltext bearbeiten]

Flutter selbst ist in C++ geschrieben und verwendet die Dart Virtual Machine (Dart-VM), sowie die Grafikbibliothek Skia.[7] Bei der Ausführung von Programmen versucht Flutter zumindest eine Bildrate von 60 fps zu erreichen, bzw. 120 fps wenn die Hardware dies zulässt.[8]

Flutter-Programme für Android, iOS, Windows, Linux und macOS werden entweder per JIT-Compiler auf einer Dart VM oder mittels AOT-Compiler direkt für die Zielplattform kompiliert.[9] Flutter-Webanwendungen werden nach JavaScript übersetzt und sind so direkt in modernen Webbrowsern lauffähig.[10]

Widget[Bearbeiten | Quelltext bearbeiten]

Die grundlegende Komponente in einem Flutter-Programm ist ein Widget, wobei ein Widget wiederum aus Widgets bestehen kann. Ein Widget bündelt die Logik, Interaktion und Darstellung innerhalb eines Objekts und erinnert im Aufbau an die JavaScript-Softwarebibliothek React.[11] Es gibt eine Reihe vorgefertigter Widgets, die bekannte und oft benötigte Interaktionen abbilden, wie zum Beispiel Buttons, Listen, Checkboxes, Tabs etc. Dabei verwendet Flutter nicht die Widgets der jeweiligen Plattform, sondern implementiert diese in Flutter nach.[12][13] Widgets für Android folgen den Material-Design-Richtlinien[14] während Widgets für andere Betriebssystem wie iOS, Windows, Linux oder macOS den jeweiligen Richtlinien folgen. Obwohl Widgets eine wesentliche Rolle bei Flutter einnehmen, können Programme auch (fast) ohne Widgets programmiert werden, indem man direkt auf einen Canvas zeichnet.[15][16][17]

Hello-World-Beispiel[Bearbeiten | Quelltext bearbeiten]

Ein Hallo-Welt-Programm in Flutter könnte folgendermaßen aussehen. In diesem Fall werden die Material-Widgets verwendet.

import 'package:flutter/material.dart';

void main() => runApp(HelloWorldApp());

class HelloWorldApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Hello World App',
      home: Scaffold(
        appBar: AppBar(
          title: Text('Hello World App'),
        ),
        body: Center(
          child: Text('Hello World'),
        ),
      ),
    );
  }
}

Einzelnachweise[Bearbeiten | Quelltext bearbeiten]

  1. Chris Bracken: v0.0.6: Rev alpha branch. In: github.com. 12. Mai 2017, abgerufen am 14. November 2020 (englisch).
  2. flutter.dev. (abgerufen am 27. Januar 2021).
  3. a b Tim Sneath: Flutter and Desktop Apps. In: medium.com. 17. Juni 2020, abgerufen am 29. August 2020 (englisch).
  4. a b Chris Sells: Canonical enables Linux desktop app support with Flutter. In: medium.com. 9. Juli 2020, abgerufen am 26. August 2020 (englisch).
  5. Open-Source Clues to Google's Mysterious Fuchsia OS. Abgerufen am 30. Januar 2020 (englisch).
  6. Flutter - Beautiful native apps in record time. Abgerufen am 30. Januar 2020 (englisch).
  7. Skia in Flutter & Fuchsia. Abgerufen am 1. März 2020 (englisch).
  8. Flutter performance profiling. Abgerufen am 1. März 2020 (englisch).
  9. Dart.dev Platforms. Abgerufen am 4. Februar 2021 (englisch).
  10. Web support for Flutter. Abgerufen am 30. Januar 2020 (englisch).
  11. Flutter - 60 FPS UI of the Future - Everything is a widget. Abgerufen am 1. März 2020 (englisch).
  12. Introduction to widgets. Abgerufen am 30. Januar 2020 (englisch).
  13. StatefulWidget class - widgets library - Dart API. Abgerufen am 30. Januar 2020.
  14. Material Components widgets. Abgerufen am 30. Januar 2020 (englisch).
  15. Canvas class. Abgerufen am 1. März 2020 (englisch).
  16. Zerker - a lightweight and powerful flutter graphic animation library. Abgerufen am 1. März 2020 (englisch).
  17. 2D game engine made on top of Flutter. Abgerufen am 1. März 2020 (englisch).