FLUTTER
BASICS
MOBILE APP DEVELOPMENT
WHAT IS MOBILE APP
DEVELOPMENT?
Mobile development involves the development of
software that is intended to run on mobile devices
(smartphones, tablets, etc). While mobile
development is similar to traditional software
development, the differentiating factor is that
mobile development will utilize unique features and
hardware from mobile devices like touch,
Bluetooth, GPS, cameras, and more.
While web-based applications simply need to run
on a web browser, mobile applications depend
upon the device itself. In terms of iOS devices,
developers primarily need to support the iPhone
and iPad. However, for Android, there are many
types of hardware and operating systems for
smartphones and tablets, which makes mobile
apps more difficult to develop.
ABOUT FLUTTER
What is Flutter?
Flutter is an open-source Software Development Kit (SDK) for
“building beautiful, natively compiled applications for mobile, web,
and desktop from a single codebase.”
So, what exactly does that mean? Let’s say we have a developer
who has created an amazing application, and people love it.
However, the application is only supported on iOS. So, the
developer decides to spend numerous hours learning Android to
support more users on their application. Even after learning how to
build Android apps, they realize that their application must support
all types of Android screen resolutions, giving them even more of a
headache. That’s where Flutter comes in.
Maintained by Google, The Flutter SDK is a toolkit created to
intelligently design applications for all types of screens and
devices, allowing for cross-platform development. The toolkit
competes with other native compatibility frameworks like React
Native.
HOW IS FLUTTER DIFFERENT
EASY MAINTENANCE
SINGLE CODE BASE RAPID DEVELOPMENT
One of the most notable benefits of using
Flutter is its cross-platform functionality. Flutter offers quick compilation, which
Developers only need to write one allows you to see the results of your
codebase for multiple apps (Android, iOS, code changes in real-time. This is a
feature called Hot-Reload, which only
and web). For the most part, Flutter
takes a few milliseconds. Developers
depends on widgets and UI designs and love this benefit of using Flutter because
simply needs to compile and convert into a it allows you to make quick UI changes,
platform-supported code. This is useful meaning more productive and dynamic
because it allows developers to cut their mobile app development.
development time extensively.
BASIC CONCEPT
Flutter essentially consists of two parts:
Software Development Kit (SDK): A collection
of tools that aid you in developing your
application. For example, you will have tools
that compile your code into native code to
support iOS and Android.
Framework: A collection of widgets, or UI
elements, that you can add to develop your
application.
It’s important to know that Flutter is not a
programming language. To build your Flutter app,
you will use a programming language called Dart,
which is also created by Google. In terms of
syntax, Dart is similar to JavaScript.
BASIC CONCEPT
UNDERSTANDING WIDGETS
Widgets are the basic building blocks of the
Flutter UI. Unlike many other frameworks that
separate views, layouts, view controllers, and
other elements, Flutter offers a consistent,
unified object model: the widget.
Like components in React, widgets form a
hierarchy and can be nested within each other.
Furthermore, widgets inherit properties from
their parents.
BASIC CONCEPT
FRAMEWORK
As seen from the diagram, the low-level layer of
Flutter is its engine, which is built using C++. The
engine provides low-level rendering using Skia,
Google’s graphics library.
At the upper layer is the Framework, which is
written in the Dart programming language. It
provides a collection of libraries to support
animation, gestures, rendering, widgets, and
more. The upper layer is used much more
frequently than the lower layer.
GETTING STARTED WITH THE
MINIMAL FLUTTER APP
Breaking down the code:
This app creates a Material design. Material is a visual design language popular for mobile and web
applications. Flutter offers a wide variety of Material widgets.
The MyApp class extends StatelessWidget to make the app itself a widget.
The Scaffold widget provides a default app bar, title, and body. The title is the text “Welcome to
Flutter”, and the body is a Text child widget that says, “Hello World.”
A widget’s primary job is to provide a build() method that describes how to display sub-widgets in
terms of the hierarchical widget tree.
The runApp() function takes the given Widget and makes it the root of the widget tree. In this
example, the widget tree consists of two widgets, the Center widget and its child, the Text widget. The
framework forces the root widget to cover the screen, which means the text “Hello, world” ends up
centered on screen. The text direction needs to be specified in this instance; when the MaterialApp
widget is used, this is taken care of for you, as demonstrated later.
When writing an app, you’ll commonly author new widgets that are subclasses of either
StatelessWidget or StatefulWidget, depending on whether your widget manages any state. A widget’s
main job is to implement a build() function, which describes the widget in terms of other, lower-level
widgets. The framework builds those widgets in turn until the process bottoms out in widgets that
represent the underlying RenderObject, which computes and describes the geometry of the widget.
BASIC WIDGETS
Many Material Design widgets need to be inside of a MaterialApp to
display properly, in order to inherit theme data. Therefore, run the
application with a MaterialApp.
The MyAppBar widget creates a Container with a height of 56 device-
independent pixels with an internal padding of 8 pixels, both on the left
and the right. Inside the container, MyAppBar uses a Row layout to
organize its children. The middle child, the title widget, is marked as
Expanded, which means it expands to fill any remaining available space
that hasn’t been consumed by the other children. You can have multiple
Expanded children and determine the ratio in which they consume the
available space using the flex argument to Expanded.
The MyScaffold widget organizes its children in a vertical column. At the
top of the column it places an instance of MyAppBar, passing the app
bar a Text widget to use as its title. Passing widgets as arguments to
other widgets is a powerful technique that lets you create generic
widgets that can be reused in a wide variety of ways. Finally, MyScaffold
uses an Expanded to fill the remaining space with its body, which
consists of a centered message.
USING MATERIAL
COMPONENTS
Now that the code has switched from MyAppBar and
MyScaffold to the AppBar and Scaffold widgets, and from
material.dart, the app is starting to look a bit more Material.
For example, the app bar has a shadow and the title text
inherits the correct styling automatically. A floating action
button is also added.
Notice that widgets are passed as arguments to other
widgets. The Scaffold widget takes a number of different
widgets as named arguments, each of which are placed in
the Scaffold layout in the appropriate place. Similarly, the
AppBar widget lets you pass in widgets for the leading
widget, and the actions of the title widget. This pattern
recurs throughout the framework and is something you
might consider when designing your own widgets.
HANDLING GESTURES
The GestureDetector widget doesn’t have a visual
representation but instead detects gestures made by
the user. When the user taps the Container, the
GestureDetector calls its onTap() callback, in this case
printing a message to the console. You can use
GestureDetector to detect a variety of input gestures,
including taps, drags, and scales.
Many widgets use a GestureDetector to provide
optional callbacks for other widgets. For example, the
IconButton, ElevatedButton, and FloatingActionButton
widgets have onPressed() callbacks that are triggered
when the user taps the widget.