Flutter ships applications with its own rendering engine which directly outputs pixel data to the screen.[15][16] This is in contrast to many other UI frameworks that rely on the target platform to provide a rendering engine, such as native Android apps which rely on the device-level Android SDK or React Native which dynamically uses the target platform's built-in UI stack. Flutter's control of its rendering pipeline simplifies multi-platform support as identical UI code can be used for all target platforms.[16]
Architecture
The basic component in a Flutter program is a "widget", which can in turn consist of other widgets.[17] A widget describes the logic, interaction, and design of a UI element with an implementation similar to React.[17] Unlike other cross-platform toolkits such as React Native and Xamarin which draw widgets using native platform components, Flutter renders widgets itself on a per-pixel basis. Flutter has two types of widgets: stateless and stateful. Stateless widgets only update if their inputs change, meaning they otherwise won't need to be rebuilt when other elements of the screen change, while stateful widgets can call the setState() method to update an internal state and redraw.[17][18] Although widgets are the primary method of constructing Flutter applications, they can also be bypassed in favor of directly drawing on a canvas. This feature has been occasionally used to implement game engines in Flutter.[19]
The Flutter framework contains two sets of widgets that conform to specific design languages: Material Design widgets implement Google's design language of the same name, and Cupertino widgets implement Apple's iOSHuman interface guidelines.[20][21] Flutter allows the developer to use either set of widgets on either platform. Developers can use Cupertino widgets on Android.
Flutter apps are written in the Dart language. Release versions of Flutter apps on all platforms use ahead-of-time (AOT) compilation[22] except for on the Web where code is transpiled to JavaScript or WebAssembly.[23][24] Flutter inherits Dart's Pubpackage manager and software repository, which allows users to publish and use custom packages as well as Flutter-specific plugins.[25] The Foundation library, written in Dart, provides basic classes and functions that are used to construct applications using Flutter, such as APIs to communicate with the engine.[21][26]
Flutter's engine, written primarily in C++, provides low-level rendering support using either Google's Skia graphics library or the custom "Impeller" graphics layer, which is enabled by default on iOS and is in beta on Android.[27][28][29] The engine interfaces with platform-specificSDKs such as those provided by Android and iOS to implement features like accessibility, file and network I/O, native plugin support, etc.[21]
History
The first version of Flutter was known as "Sky" and ran on the Androidoperating system.[30] It was unveiled at the 2015 Dart developer summit with the stated intent of being able to render consistently at 120 frames per second.[30] On December 4, 2018, Flutter 1.0 was released at the Flutter conference in London.[31]
On May 6, 2020, the Dart software development kit (SDK) version 2.8 and Flutter 1.17.0 were released, adding support for the MetalAPI.[32]
On March 3, 2021, Google released Flutter 2 during an online Flutter Engage event.[7][33] It added a Canvas-based renderer for web in addition to the HTML-based renderer and early-access desktop application support for Windows, macOS, and Linux.[33][7] It also shipped with Dart 2.0 which included support for null-safety.[7][34] Null safety was initially optional as it was a breaking change and was made mandatory in Dart 3 released in 2023.[34][35]
On May 12, 2022, Flutter 3 and Dart 2.17 were released with support for all desktop platforms as stable.[36]
On October 27, 2024, a number of Flutter community developers announced Flock, a fork of Flutter intended to be easier to contribute to while still keeping in sync with all changes made in the upstream code base.[37][38]
^"Flame". flame-engine.org. Archived from the original on 2022-09-27. Retrieved 2022-10-06.
^Anderson, Tim (5 Aug 2020). "Google reports 80% spike of Flutter-built apps in Play Store as 1.20 is released". theregister.com. In general the design style follows Google's Material Design guidelines, making it particularly at home on Android (as you would expect from Google), but there is also support for Cupertino widgets for a native iOS look and feel.