Flutter General Report
Flutter General Report
Flutter General Report
Chapter-1
INTRODUCTION
1
lOMoARcPSD|20610818
2
lOMoARcPSD|20610818
Chapter-2
HISTORY
Flutter was first announced 4 years ago in 2015 at the Dart Developer Summit. It was
initially called “SKY”. I think that would have been cooler. Flutter alpha (V-0.06) was
released in May 2017.Later, Google launched the 2nd preview of Flutter back in
September 2018.That’s when the developers around the world started to feel the heat.
Even before the Flutter 1.0 was announced, many Flutter apps came into the stores.
Apps like – Alibaba, Google Ads, Tencent, reflect were proof that Flutter could be so
Awesome. Finally, Google launched Flutter 1.0, the stable version of Flutter on 5th of
December 2018.
At this launch, Google released ‘The History of Everything”. A timeline of the world
from the Big Bang to the age of WWW. An app built with Flutter with a single code
base that can run in any Android or IOS device smoothly. This app has smooth
animations because Flutter can run apps with a of 120 Frames Per Second. (Others
only can achieve a maximum of 60 FPS).
To build apps with Flutter, you need to know Dart as flutter runs on the Dart virtual
machine and flutter uses Dart as the Programming Language. Dart – A object oriented
programming language developed by Google Dart was first released in 2011 and the
latest stable version (Dart 2.2.0) was released in February 2019.Many sources
mentions that Google initially released Dart as a alternative to Java-Script. But, in the
official Dart website, they deny it. For dart beginners, dart devs say “You probably
already know Dart, you just don’t realize it”. Why? because dart is a lot like java, C#
or js. If you know any of those languages, you only need to study a few syntax
changes.
3
lOMoARcPSD|20610818
Chapter-3
4
lOMoARcPSD|20610818
5
lOMoARcPSD|20610818
Chapter-4
Flutter engineered for high development velocity. Stateful hot reload allows you to
change your code and see it come to life is less than a second without losing the state
of the app. Flutter also ships with a rich set of customizable widgets, all built from
modem reactive framework.
Flutter moves to a widget, rendering, animation and gestures into this framework to
give you to complete control over every pixel on the screen. It means you have the
flexibility to build a custom design.
Flutter apps follow platform conventions and interface details such as scrolling,
navigation, icons, fonts, etc. That why apps built with Flutter features on both APP
STORE and GOOGLE PLAY STORE.
In flutter, very save on the app and just as you do on the web just hit a refresh and your
codes also refresh. Imaging that Facebook SDK it would be so humongous if it would
have been designing android and you hit a recompile. So many things to have
recompile and it would take probably days. Unmistakably, Hot reloading is tech which
is kind of necessary when your applications or product goes like incense crazy like
Facebook.
6
lOMoARcPSD|20610818
7
lOMoARcPSD|20610818
Flutter doesn’t require a Javascript bridge and the speed is much faster.
Dart is an object-oriented programming language that which used for writing mobile
application code for Flutter and which contributes to the efficiency and effectiveness of
app development flow. It is a comfortable language and uses a lot of CSS parts as well.
Dart uses for generational garbage collection which helps in creating frames for short-
lived objects. It also helps to allocate the objects with a single pointer bump to avoid
UI jank and shutter.
When using flutter, you can get complete IOS experience or Android Experience. So they
are reducing the Third parties.
Flutter has built with a rich and customizable set of widgets for Android, IOS and
Material Design. The collaboration between Flutter and Google’s material design has
rendered and easily create powerful UI experience. This help to create smooth, crisp
and refined app experience as are available with a native app.
8
lOMoARcPSD|20610818
9
lOMoARcPSD|20610818
Traditional conventions, as long as the article about the principle of Flutter, this picture
will be placed at the beginning. Regardless of whether it is good or not, it is first put
forward, and most of them still rely on their own understanding. Because this picture is
so easy to use.
Putting this picture out, it is still simple to understand what is Flutter from the whole,
otherwise it is easy to fall into the "blind person to touch the elephant" situation.
The Flutter architecture uses a layered design, which is divided into three layers from
bottom to top, in this order: Embedder, Engine, Framework.
10
lOMoARcPSD|20610818
11
lOMoARcPSD|20610818
As for more details, this picture will be better with the source code eating experience.
But because this article is not a source code analysis, this work will not start. Next, I
will use the Flutter drawing process as an example to explain how Flutter works. This
can also help you better understand the source code.
12
lOMoARcPSD|20610818
13
lOMoARcPSD|20610818
6. Drawing principle of
Flutter
The first is the user operation, which triggers the update of the Widget Tree, and then
builds the Element Tree, calculates the redraw area and synchronizes the information
to the RenderObject Tree, and then implements component layout, component
drawing, layer composition, and engine rendering.
As a pre-knowledge, let's take a look at the data structure involved in the rendering
process, and then analyze the specific aspects of rendering.
The key data structures involved in the rendering process include three trees and a layer,
where RenderObject holds the Layer. Let's focus on the relationship between the three
trees.
14
lOMoARcPSD|20610818
15
lOMoARcPSD|20610818
Then the relationship between the corresponding three trees is shown below:
The first tree is the Widget Tree. It is the basic logical unit of control implementation,
and is how users describe the interface UI.
16
lOMoARcPSD|20610818
17
lOMoARcPSD|20610818
have to be aware of is, Widget is immutable When the view configuration information
changes, Flutter will rebuild the Widget to update it, and it is simple and efficient to
build in a data-driven UI.
The second tree, Element Tree. It is the instantiated object of Widget (as shown below,
Widget providescreateElementFactory method to create Element), which persists in the
Dart context at runtime. It carries the constructed context data and is the bridge
connecting the structured configuration information to the final rendering.
The reason why it persists in the context of Dart instead of rebuilding like Widget,
because the cost of re-creating and re-rendering of Element Tree will be very large, so
Element Tree to RenderObject Tree also has a Diff link to calculate the minimum
redraw area .
18
lOMoARcPSD|20610818
19
lOMoARcPSD|20610818
It should be noted that Element holds both Widget and RenderObject, but neither
Widget nor Element is actually responsible for the final rendering, they are just
"ordering", and it is the RenderObject that actually renders the configuration
information.
The third tree, RenderObject Tree, is the render object tree. RenderObject is created by
Element and linked toElement.renderObjectOn (as shown below), it accepts Element's
information synchronization. Similarly, it is also persistently stored in the context of
Dart Runtime, and is mainly responsible for implementing view rendering.
20
lOMoARcPSD|20610818
21
lOMoARcPSD|20610818
The display process of RenderObject Tree in Flutter is divided into four stages:
1. layout
2. draw
3. synthesis
4. Rendering
Among them, the layout and drawing are done in RenderObject. Flutter uses a depth-
first mechanism to traverse the rendering object tree, determine the position and size of
each object in the tree, and draw them to different layers. After drawing, the task of
compositing and rendering is left to Skia.
So the question is, why are three trees instead of two? Why do I need the Element Tree
in the middle, is it not possible to construct the RenderObject Tree directly from the
Widget Tree?
It is possible in theory, but not practical. Because if you build the RenderObject Tree
directly, it will greatly increase the performance loss caused by rendering. Because
Widget Tree is immutable, but Element is mutable. In fact, the Element layer abstracts
the changes of the Widget tree (similar to React/Vue's VDOM Diff), and only
synchronizes the parts that really need to be modified into the RenderObject Tree,
22
lOMoARcPSD|20610818
thereby minimizing the redraw area and improving rendering effectiveness. It can be
found that Flutter's ideas are largely based on the front-end reactive framework React /
Vue.
23
lOMoARcPSD|20610818
In addition, expand and add VDOM. We know that several advantages of Virtual DOM
are:
24
lOMoARcPSD|20610818
25
lOMoARcPSD|20610818
6.1.4. Layers
As shown in the code above, there are two attributes on the base class of
Layer_needsAddToScene with _ subtreeNeedsAddToSceneThe former indicates that the scene
needs to be added, and the latter indicates that the subtree needs to be added to the
scene. Usually, only when the state is updated, it needs to be added to the scene, so
these two attributes can be intuitively understood as "I need to update" and "Subtree
needs to be updated."
26
lOMoARcPSD|20610818
27
lOMoARcPSD|20610818
The advantage of Flutter is not only in making one application instead of two. With
this framework, you will also have fewer problems when adapting your app to each of
the platforms. Most frameworks can cope, but that’s only if to consider them in the
context of simple applications. The real problems begin when an application becomes
“overgrown” with functions and inevitably gets complicated (it is about most products
during the development stage).
28
lOMoARcPSD|20610818
While a Flutter app is built directly into the machine code, that will exclude any
performance bugs during interpretation. A Flutter application will be ultimately
indistinguishable from the
29
lOMoARcPSD|20610818
The problem with many cross-platform solutions is that they look the same on iPhone
and Android. But what about the companies that need to use Material Design for
Android and Human Interface for iOS? For such companies, Flutter is the most
suitable solution. It is equipped with packages that contain a set of custom widgets for
both operating systems.
Flutter provides advanced OS features like GPS coordinates, sensor data collection,
permission handling, Bluetooth, credentials, and other features in ready-to-use plugins
that are supported by Google.
If your app is reliant on an OS-level feature not available as a plugin, Flutter can
establish communication between its Dart programming language and the native code
using platform channels.
30
lOMoARcPSD|20610818
Two powerful things were originally laid in the foundation of Flutter: an excellent
programming language (Dart) and a fast, high-performance rendering engine (Skia).
Such a choice was a well-thought-out solution that saves users from further long
searches.
31
lOMoARcPSD|20610818
The result is an excellent platform that helps developers of all skill levels to create
applications using appropriate design patterns and best practices. You can forget about
contradictions to the standards or some technical flaws caused by the imperfections in
the programming language. Flutter provides beautiful and customizable widgets that
make Flutter apps look and feel great.
You can use practically all the advantages of Firebase in Flutter app development, as
you would a native one. Moreover, Flutter allows the creation of reactive apps, and
Firebase plugins offer reactive streams to work with data. That will allow you to
quickly integrate certain solutions into Flutter applications.
In Flutter development, the programming language Dart is utilized. It is also one of the
Google languages created in October 2011 and has improved significantly in recent
years. Dart is statically typed and allows you to write a much more structured code,
meaning you can create more complex applications and hierarchical structures.
The language has a clean and incredibly powerful syntax. That provides the ideal
conditions for creating a clear architecture and design of any application. It is also
worth mentioning that it ensures work consistency among programmers, durability,
low maintenance and common standards. Much more than most other frameworks for
cross-platform development can offer. For those who have already worked with such
popular languages as C#, Java, and TypeScript, it will be easy to switch to Dart and
start using it right away.
Widgets are the basic blocks used to build a user interface of a Flutter application. Its
layering makes it easy to create applications of any complexity. You can use ready-
made widgets from Material-UI or implement specific components based on basic
widgets.
32
lOMoARcPSD|20610818
33
lOMoARcPSD|20610818
8. Efficient Tooling
$ flutter doctor
$ flutter upgrade
$ flutter format
$ flutter analyze
pubspec.yaml
name:
flutter_project
flutter:
sdk: flutter
34
lOMoARcPSD|20610818
35
lOMoARcPSD|20610818
9. What is Widget?
If you are familiar with the Android or iOS development, then you might make
the immediate connection with the views (on Android) or UIViews (on iOS).
But dear just like view, Widget is not just a piece of UI. Widget is a lot more
than just structural elements like buttons, text, image, list or slider. A widget
might display Something, it might help define design, it might help with layout,
it may handle user interaction, etc.
So you can consider that a widget is a blueprint. Flutter uses these blueprints to
create views.
If you already have fun with flutter code then you might notice that infinite
Parent- Child tree. Yaa I agree, first time it just scares out any beginner, but
dear we all passes from the same stage in which you are right now. Just give it
some time, do a lot of practice and Just believe, just like others, you can do it as
well. 😉
The Entire widget tree forms a layout that you see on the screen.
36
lOMoARcPSD|20610818
37
lOMoARcPSD|20610818
Flutter has a rich set of in-built widgets like text, buttons, slider, lists, layouts,
gesture detector, animations, etc. Flutter team works really hard to create a set
of widgets that helps you in almost every situation. And they are continuously
adding more widgets as developers needs.
But apart from built-in widgets, you can create your own widgets according to
your needs.
Stateless Widgets
38
lOMoARcPSD|20610818
39
lOMoARcPSD|20610818
Stateful Widgets
Stateless widgets don’t store any state. That means they don’t store values that
might
change.
You can also say that stateless widgets are “DATALESS” widgets. As they don’t
store
any real-time data.
For example, if you have a simple Text widget on the screen, but it doesn’t do
anything
then its Stateless Widget.
A Stateful widget is dynamic in nature. That means it can keep track of changes
and update the UI based on those changes.
The user can interact with a stateful widget. For example, If you press a button
and it performs any task it’s a Stateful Widget, If you are moving a slider and it
does anything then its a Stateful Widget, If you swipe item from a list and item
gets deleted then that list a Stateful Widget.
40
lOMoARcPSD|20610818
41
lOMoARcPSD|20610818
Step 4: Flutter provides a tool, flutter doctor to check that all the requirement of flutter
development is met.
$ flutter doctor
Step 5: Running the above command will analyze the system and show its
The report says that all development tools are available but the device is not
42
lOMoARcPSD|20610818
flutter doctor
43
lOMoARcPSD|20610818
Step 8: Start an android emulator or connect a real android device to the system.
Step 9: Install Flutter and Dart plugin for Android Studio. It provides start-up template to
create new Flutter application, an option to run and debug Flutter application in the
Android studio itself, etc.,
44
lOMoARcPSD|20610818
45
lOMoARcPSD|20610818
To install Flutter on MacOS, you will have to follow the following steps:
latest Flutter SDK. As of April 2019, the version is 1.2.1 and the file is
flutter_macos_v1.2.1- stable.zip.
Step 3: Update the system path to include flutter bin directory (in ~/.bashrc file).
Step 4: Enable the updated path in the current session using below command and
source ~/.bashrc
source
$HOME/.bash_profile
echo $PATH
Flutter provides a tool, flutter doctor to check that all the requirement of flutter
46
lOMoARcPSD|20610818
by flutter doctor
Step 8: Start an android emulator or connect a real android device to the system
47
lOMoARcPSD|20610818
Step 9: Open iOS simulator or connect a real iPhone device to the system to develop iOS
application.
Step 10: Install Flutter and Dart plugin for Android Studio. It provides the
startup template to create a new Flutter application, option to run and debug
Flutter application
48
lOMoARcPSD|20610818
49
lOMoARcPSD|20610818
12.What is Dart?
Google had its first ever release of Flutter 1.0 last December, after having it in beta
mode for over 18 months. Dart is the programming language used to code Flutter apps.
Dart is another product by Google and released version 2.1, before Flutter, in
November. As it is starting out, the Flutter community is not as extensive as React
Native, Ionic, or Xamarin.
Dart is not only used for mobile app development but is a programming language.
Approved as a standard by Ecma (ECMA-408), it’s used to build just about anything
on the web, servers, desktop and of course, mobile applications (Yes, the same people
who standardized our favorites ES5 and ES6.)
Dart, when used in web applications, is transpiled to JavaScript so it runs on all web
browsers. The Dart installation comes with a VM as well to run the .dart files from a
command-line interface. The Dart files used in Flutter apps are compiled and packaged
into a binary file (.apk or .ipa) and uploaded to app stores.
1. The entry point of a Dart class is the main() method. This method acts as a
starting point for Flutter apps as well.
2. The default value of most data types is null.
50
lOMoARcPSD|20610818
3. Dart classes only support single inheritance. There can be only one superclass
for a particular class but it can have many implementations of Interfaces.
51
lOMoARcPSD|20610818
4. The flow control of certain statements, like if conditions, loops (for, while
and do- while), switch-case, break and continue statements are the same.
1. Dart has type inference. The data type of a variable need not be explicitly
declared, as Dart will “infer ”what it is. In Java, a variable needs to have its
type explicitly given during declaration. For example, String something;. But in
Dart, the keyword is used instead like so, var something;. The code treats the
variable according to whatever it contains, be it a number, string, bool or
object.
2. All data types are objects, including numbers. So, if left uninitialized, their
default value is not a 0 but is instead null.
4. The type num declares any numeric element, both real and integer.
5. The super() method call is only at the end of a subclass’s constructor.
6. The keyword new used before the constructor for object creation is optional.
7. Method signatures can include a default value to the parameters passed. So, if
one is not included in the method call, the method uses the default values
instead.
8. It has a new inbuilt data type called Runes, that deal with UTF-32 code
points in a string. For a simple example, see emojis and similar icons.
Dart also has inbuilt libraries installed in the Dart SDK, the most commonly used being:
52
lOMoARcPSD|20610818
53
lOMoARcPSD|20610818
54
lOMoARcPSD|20610818
55
lOMoARcPSD|20610818
13. Conclusion
Flutter framework does a great job by providing an excellent framework to build
mobile applications in a truly platform independent way. By providing simplicity in the
development process, high performance in the resulting mobile application, rich and
relevant user interface for both Android and iOS platform, Flutter framework will
surely enable a lot of new developers to develop high performance and feature-full
mobile application in the near future.
56
lOMoARcPSD|20610818
57
lOMoARcPSD|20610818
14. References
& flutter.io
58
lOMoARcPSD|20610818
59