Since it’s much-awaited launch, Flutter has caught a lot of attention, and we’re excited about it too! I’m hoping that a massive chunk of non-game apps will transition to flutter, and in anticipation, we are therefore training our team on it as well.



Since there are new, but few, resources scattered over the internet to learn flutter — we’ve compiled our Flutter tutorial to get developers off their feet and start developing apps for Flutter.

In this Flutter step by step guide for beginners, we will cover:

Flutter: What, How, and Why?

Setting up Flutter

Dart Basics

Flutter Basics

Widgets

Layouts

Interactive Widgets

Designing an app: Forms, Gestures, and Images

Lists

Navigation

Networking

JSON and Serialization

Dependency Management

State Management

Testing (Unit and Integration)

1. Flutter: What, How, and Why?

What is Flutter, and how is it different? Being Flutter app developers, you need to just remember this — Flutter was built to work for any device with a screen and works with:

iOS and Android

Web and Desktop (Mac, Windows, and Ubuntu) — Even support PWA

Auto

Raspberry Pi (POC stage)

Check out this video from Google; it’s a great place to get a grasp — comparing Native Development, Hybrid App Development, React Native Development, and finally, Flutter App Development.

Here is the latest news on the launch of the new version of Flutter and Dart programming language-

Google Launched Flutter SDK 1.2 and Dart Programming Language 2.2 Google recently launched Flutter 1.2 and Dart 2.2 during Mobile World Congress (MWC) 2019. Learn about the latest features of Flutter 1.2…

2. Setting up Flutter

Flutter is relatively straightforward to set up and depending on what OS you’re using; you can check out the steps in this official Flutter tutorial: https://flutter.dev/docs/get-started/install

But in case, you do run into something, check out here: https://github.com/flutter/flutter/wiki/Workarounds-for-common-issues#flutter-installation

The reason we ask that you setup Flutter before Dart is because when you install Flutter, you install Dart too, and while you can separately install Dart, it would be an unnecessary step. Flutter will decide which Dart version will be used, so installing different Dart version will be ambiguous as well.

Once you’ve downloaded and unzipped Flutter, you should see something like this on running the Flutter command at the console:

If you’re new to mobile development in general, you will need to download Xcode and Android Studio (and toolchain), as well. Once you’ve setup Flutter, scaffolding a new project is just one command.

3. Dart Basics

Flutter uses Dart language to build Apps. To understand why Flutter uses dart, check out my previous blog and down to the section — How Flutter was born

Flutter for your next ‘product’ idea — Everything you need to know As a startup founder, you might have/not have come across ‘Flutter.’ This post explains why it’s essential to have a 360-degree perspective when it comes to choosing the right technology for your product. https://blog.solutelabs.com/flutter-for-your-next-product-idea-everything-you-need-to-know-f5179a925524

Flutter and Chrome use the same rendering engine — SKIA. Instead of interacting with native APIs, it controls every pixel on the screen, which gives it the much necessary freedom from the legacy baggage as well as the performance it has.

Do give the official doc a read, but I found this one to be good at explaining dart

Why Flutter Uses Dart Many linguists believe that the natural language a person speaks affects how they think. Does the same concept apply to computer languages? https://hackernoon.com/why-flutter-uses-dart-dd635a054ebf

P.S. You can follow up with Dart updates on their medium account

Now, you know why Google choose Dart — so let’s get your hands dirty!

Learn Dart

Check out the official docs of Dart language, a tour, and their language samples.

Once you have an overview, head over to http://jpryan.me/dartbyexample/ and do all the examples religiously.

Practice, Practice, Practice!

Edit your code on DartPad for starters and get a better grip. I’m sure you’ll be up and running in no time!

After, you’re done with dartbyexample, head over to exercism, and complete their dart track. It’s trendy, so in case it’s full, you can do the practice track too.

Dart | Exercism Dart is a general purpose programming language which has seen a rise in popularity for its usages in mobile and web application development. https://exercism.io/tracks/dart

4. Flutter Basics

Now that you’re familiar with Dart, it’s finally time to move on to Flutter

Let’s start this Flutter tutorial with the technical overview here:

Technical overview Flutter is an app SDK for building high-performance, high-fidelity apps for iOS, Android, web (beta), and desktop (technical preview) from a single codebase. https://flutter.dev/docs/resources/technical-overview

And scaffold a new Flutter app with:

flutter create app_name

And you should see something like this:

Open the project on the Android Studio, download the emulator, and an Android version if not done already and run the project — and et voila!

Understand as to how should you structure your project directory and understand which files are meant for which purpose

Flutter Project Structure As always, I’ll be very straight forward and try to keep the article short, simple and very precise. So that in no time... https://dev.to/jay_tillu/flutter-project-structure-1lhe

Now that you’ve setup flutter, another step in this Flutter Tutorial is to do what all developers do! Use other’s code 😆 — what I meant is to set up the package file: pubspec, written in YAML

The pubspec file Every pub package needs some metadata so it can specify its dependencies. Pub packages that are shared with others also need to provide some other information so users can discover them. https://dart.dev/tools/pub/pubspec

5. Widgets

Remember — Everything’s a widget in Flutter

If you’ve not read the technical overview as we asked you before, go back and read it :) You will get a fair idea of what widgets are. Widgets come in two flavors: stateless and stateful

Stateless Widgets are those whose state doesn’t change like a button or an image. As the name states, it doesn’t change its state when an action is performed on the screen.

Check out the short video series, and it’s documentation by Google to explore in-depth (I’m attaching the first video in the series).

When a widget needs to hold some state like a current page in PageView, the currently selected tab in a BottomNavigationBar, Stateful widgets are the right choice to make.

StatefulWidgets can hold the current state of a Widget. Instead of a widget build method, a Stateful widget has a State build method which calls each time we explicitly call setState.

And Similarly, check out the documentation (it has the video inside) for the stateful widgets here:

StatefulWidget class A widget that has mutable state. State is information that (1) can be read synchronously when the widget is built and... https://api.flutter.dev/flutter/widgets/StatefulWidget-class.html

Flutter 1.9 was released at GDD China with a host of new features and a mark that the community is multiplying (and that you can’t ignore China now)

6. Layouts in Flutter

As we discussed earlier in this Flutter guide, everything is a widget in Flutter — including layout models.

Check out the documentation here:

Layouts in Flutter What's the point? Widgets are classes used to build UIs. Widgets are used for both layout and UI elements. Compose... https://flutter.dev/docs/development/ui/layout

Widgets such as the rows, columns, and grid are layout widgets (which we don’t see on screen) that helps other visible widgets to arrange, constraints, and align.

And, Some more Widgets!

Flutter comes with a suite of powerful basic Widgets such as Text, Column, Row, Stack, and Container. The basic widgets will help you creating custom views as you want.

If your app follows material design guidelines, Flutter has a lot to cover by default. Flutter provides several widgets that support Material Design. It includes widgets such as MaterialApp, AppBar, Scaffold, etc.

Flutter also includes the iOS-centric Cupertino component package. It covers widgets such as CupertinoApp, CupertinoNavigationBar, etc.

7. Interactive Widgets

So far in this Flutter step by step tutorial, we have seen Widgets that display information on-screen or arrange other widgets. For the real app, it is equally essential to make the app interactive and get user’s input in various forms like Gesture, taps, etc.

To achieve this, Flutter has numbers of StatefullWidgets such as Checkbox, Radio, Slider, InkWell, Form, and TextField, etc. These widgets are capable enough to maintain their state (e.g., Text we are entering in TextField, whether a CheckList is checked or not.)

Go and check out the below example to add Favorites/Non-Favorites functionality to your app.

Adding interactivity to your Flutter app What you’ll learn How to respond to taps. How to create a custom widget. The difference between... https://flutter.dev/docs/development/ui/interactive

⏰ Time for Codelab: Write your First Flutter App : Part-2 As you have reached here, you should be clear with What is Widgets ? and Types of Widget

Now you must be curious about what are all widgets available in Flutter?

So here is a Widget Catalog, Check all the Widgets that make Flutter development relaxed and Fun 😍

Widget catalog Create beautiful apps faster with Flutter’s collection of visual, structural, platform, and interactive widgets. In addition to... https://flutter.dev/docs/development/ui/widgets

Flutter Cookbook

And here we go, it’s time to learn Flutter for real apps with the help of Flutter Cookbook. I mean Apps that have Multiple screens, Images, Network dependency, and all.

So, let’s begin.

8. Designing an App

Check the below app illustration.

This Simple looking app has these features 👇

Navigation Drawer

https://flutter.dev/docs/cookbook/design/drawer SnackBar

https://flutter.dev/docs/cookbook/design/snackbars Custom Fonts (A Text have its own Style 😉)

https://flutter.dev/docs/cookbook/design/package-fonts A Text-based on Orientation (Bigger fonts in Landscape)

https://flutter.dev/docs/cookbook/design/orientation And, Multiple Tabs

https://flutter.dev/docs/cookbook/design/tabs

Note here: OrientationBuilder is independent of the device’s orientation. Instead, It calculates the current Orientation by comparing the width and height available to the parent widget. To determine the device’s orientation you can refer MediaQuery.of(context).orientation

8.1 Forms

Flutter has a Form widget that helps to build a form that efficiently manages the essential requirement of a Form, e.g., State of a Form, Validation, etc. Check out the complete guild in the below documentation.

Cookbook This cookbook contains recipes that demonstrate how to solve common problems while writing Flutter apps. Each recipe is... https://flutter.dev/docs/cookbook#forms

8.2 Gestures

To get the user inputs and some-time to make the app super interactive, we maximize the use of Gestures. Flutter has pre-built widgets to cover this.

Adding Material Ripple Effect

https://flutter.dev/docs/cookbook/gestures/ripples Handle Taps

https://flutter.dev/docs/cookbook/gestures/handling-taps Swipe to Dismiss

https://flutter.dev/docs/cookbook/gestures/dismissible

8.3 Images

To make apps beautiful and engaging, we use Images. Flutter provides an Image widget to display an image in the Flutter app from various sources.

Display Images from Network

Display images from the internet Displaying images is fundamental for most mobile apps. Flutter provides the Image widget to display different types of images. https://flutter.dev/docs/cookbook/images/network-image

2. Display Image with Placeholder & with Fade-in Animation

Fade in images with a placeholder When displaying images using the default Image widget, you might notice they simply pop onto the screen as they’re loaded. This might feel... https://flutter.dev/docs/cookbook/images/fading-in-images

3. Sometimes it’s handy to Load image from network and cache it in local storage to make it quickly available next time.

Work with cached images In some cases, it’s handy to cache images as they’re downloaded from the web, so they can be used offline. For this purpose, use... https://flutter.dev/docs/cookbook/images/cached-images

9. Showing more data using List

To accommodate more data, we use List to show them. The list can be horizontally or linearly.

Flutter has a GridView and ListView. These are basic widgets with different contractors to identify how they can be used.

1. Create a grid list

Create a grid list In some cases, you might want to display your items as a grid rather thana normal list of items that come one after the… https://flutter.dev/docs/cookbook/lists/grid-lists

2. Create list horizontally

Create a horizontal list You might want to create a list that scrolls horizontally rather than vertically… https://flutter.dev/docs/cookbook/lists/horizontal-list

3. The list can have different types of Item. E.g., a header & items to it. Check here how you can cover such cases in ListView.

Create lists with different types of items You might need to create lists that display different types of content. For example, you might be working on a list that… https://flutter.dev/docs/cookbook/lists/mixed-list

4. Floating app bar and Nested scrolling using SliverList

Place a floating app bar above a list To make it easier for users to view a list of items, you might want to hide the app bar as the user scrolls down the… https://flutter.dev/docs/cookbook/lists/floating-app-bar

Don’t forget to check out this awesome article by Emily Fortuna to understand Slivers in depth

5. Sometimes we have predefined arbitrary items to be placed in a List. e.g., Setting categories. In ListView, you can pass custom items (in the form of Widgets) to its children.

Use lists Displaying lists of data is a fundamental pattern for mobile apps. Flutter includes… https://flutter.dev/docs/cookbook/lists/basic-list

6. Sometimes a List has more items then the viewport of a screen. In such cases, it makes no sense to build all the items at once. Flutter has ListView.Builder that uses the Lazy rendering approach to create list items efficiently.

Work with long lists The standard [`ListView`]({{site.api}}/flutter/widgets/ListView-class.html)constructor works well for small lists. To… https://flutter.dev/docs/cookbook/lists/long-lists

If you have more items in a list and looking to paginate them. Here is a good article I found 👇

How to paginate your data in Flutter A simple workaround for infinite scroll in ListView in Flutter https://blog.solutelabs.com/paginate-your-data-in-flutter-7744995febd1

10. Navigating between screens aka routes

Most apps contain multiple screens to display data in a well-organized manner.

In Flutter, we can do navigation-related operations using Navigator.

Check below diagram to understand how Flutter manages multiple routes, and later, we will discuss how to navigate up and forth between them.



1. Navigate to a new screen and back

Navigate to a new screen and back Most apps contain several screens for displaying different types of information. For example, an app might have a… https://flutter.dev/docs/cookbook/navigation/navigation-basics

2. Pass data to new screens and retrieve results.

Send data to a new screen Often, you not only want to navigate to a new screen,but also pass data to the screen as well.For example, you might… https://flutter.dev/docs/cookbook/navigation/passing-data

Return data from a screen In some cases, you might want to return data from a new screen.For example, say you push a new screen that presents two… https://flutter.dev/docs/cookbook/navigation/returning-data

So far, what we have seen is Flutter suitable for small projects. But when the project grows, we want to manage all routes at a single place. Also, we might need to address below questions

1. How many routes we have?

2. How to initialize each route?

3. What data is required by each route?

etc..

3. To manage all this efficiently, Flutter has named routes.

Navigate with named routes In the [Navigate to a new screen andback](/docs/cookbook/navigation/navigation-basics) recipe,you learned how to… https://flutter.dev/docs/cookbook/navigation/named-routes

4. Pass arguments in named routes.

Pass arguments to a named route The [`Navigator`]({{site.api}}/flutter/widgets/Navigator-class.html)provides the ability to navigate to a named route… https://flutter.dev/docs/cookbook/navigation/navigate-with-arguments

And, What about this animation while navigating to a new screen?

11. Networking

Most apps we come across nowadays, are generally connected with third party server and makes requests to the server to fetch or post data.

In Flutter, we can use HTTP as a third-party pub to do such stuff.

http | Dart Package A composable, Future-based library for making HTTP requests. This package contains a set of high-level functions and… https://pub.dev/packages/http

1. Fetch data from the network

Fetch data from the internet Fetching data from the internet is necessary for most apps.Luckily, Dart and Flutter provide tools, such as the`http`… https://flutter.dev/docs/cookbook/networking/fetch-data

2. Make authenticated requests

Make authenticated requests To fetch data from many web services, you need to provide authorization. There are many ways to do this, but perhaps the… https://flutter.dev/docs/cookbook/networking/authenticated-requests

3. Work with web sockets

Work with WebSockets In addition to normal HTTP requests, you can connect to servers using WebSockets. WebSockets allow for two-way… https://flutter.dev/docs/cookbook/networking/web-sockets

Flutter has few more pubs available, which do such stuff more efficiently. Don’t forget to take a look at the below pubs.

dio | Dart Package Language: English | 中文简体 A powerful Http client for Dart, which supports Interceptors, Global configuration, FormData… https://pub.dev/packages/dio

chopper | Dart Package Chopper is an http client generator using source_gen and inspired by Retrofit. https://pub.dev/packages/chopper

13. Using JSON and Serialization

In Flutter, we generally have two strategies for JSON serialization. Manual parsing and automated serialization using code generation.

Runtime reflection is disabled in Flutter, resulting we cannot have libraries like GSON , Jackson or Moshi

Check out the full guide with both strategies here

JSON and serialization It is hard to think of a mobile app that doesn’t need to communicate with a web server or easily store structured data… https://flutter.dev/docs/development/data-and-backend/json

For manual parsing, don’t forget to check out this online tool to auto-generate boilerplate for the model class.

Instantly parse JSON in any language | quicktype Whether you’re using C#, Swift, TypeScript, Go, C++ or other languages, quicktype generates models and helper code for… https://app.quicktype.io/

Data Persistence

Sometimes we need to persist data in local memory to quickly available whenever we need them.

1. If you have a relatively small amount of data to be stored in a key-value pair. Consider using shared-preferences. Below is the detailed guide to achieving the same using Flutter.

Store key-value data on disk If you have a relatively small collection of key-valuesto save, you can use… https://flutter.dev/docs/cookbook/persistence/key-value

2. You can also read and write files on disk.

Read and write files In some cases, you need to read and write files to disk.For example, you may need to persist data across app… https://flutter.dev/docs/cookbook/persistence/reading-writing-files

3. If an app needs to persist a large amount of data and also it requires to query them. It is advised to use an SQLite database

Flutter app can use the SQLite database via sqflite pub.

Persist data with SQLite If writing an app that needs to persist and query larger amounts of data on the local device, consider using a database… https://flutter.dev/docs/cookbook/persistence/sqlite

For easy to use, reactive persistence, check out below pub. Moor is a wrapper around sqflite.

moor_flutter | Flutter Package Moor is an easy to use, reactive persistence library for Flutter apps. Define your database tables in pure Dart and… https://pub.dev/packages/moor_flutter

14. Dependency Management

We use so many pubs in the Flutter app. It’s a great way to work collectively and share code across apps without having to develop everything from scratch.

You can find all the useful packages from here.

Dart packages Packages are sorted by the overall score. More information on ranking. A composable, cross-platform, Future-based API… https://pub.dev/

With multiple pubs, you might faces issues like conflicts in the version resolving. You can find all the best practices here to be followed while using pubs.

Using packages Flutter supports using shared packages contributed by other developers to the Flutter and Dart ecosystems. This allows… https://flutter.dev/docs/development/packages-and-plugins/using-packages

. . .

And, with all this, you now have completed Flutter cookbook. 👏

15. An Art of State Management

Introduction

In a typical app, it is a common use-case that a change made at Point-A reflects some changes at Point-B. That is called State management. It can also be understood by the below illustration.

Flutter has multiple approaches that can efficiently manage the State of the app. Based on project size we can decide the appropriate techniques.

Here we will discuss a few of the possible techniques for State management.

1. setState way

Adding interactivity to your Flutter app What you’ll learn How to respond to taps. How to create a custom widget. The difference between stateless and stateful… https://flutter.dev/docs/development/ui/interactive

Basic State Management in Google Flutter How I Met Google Flutter https://medium.com/@agungsurya/basic-state-management-in-google-flutter-6ee73608f96d

2. Inherited Widget

Check out the below video to understand, What is Inherited Widgets?

Also, Check out the complete list of articles here

List of state management approaches State management is a complex topic. If you feel that some of your questions haven’t been answered, or that the approach… https://flutter.dev/docs/development/data-and-backend/state-mgmt/options#inheritedwidget--inheritedmodel

Remember “Theme.of(context);” and “Navigator.of(context);” you used earlier? That is using the same Inherited Widget concept to access data down in the widget tree.

3. The Provider Package

The provider is a mixture of DI (dependency injection) and State management built with widgets for widgets.

Official documentation of provider is too good to understand it in depth.

provider — Dart API docs A mixture between dependency injection (DI) and state management, built with widgets for widgets. It purposefully uses… https://pub.dev/documentation/provider/latest/

4. BLoC Pattern

BLoC is a Simple, Lightweight, and highly testable a predictable state management library for Dart.

Bloc Bloc library documentation https://bloclibrary.dev/#/

I also found this good video series explaining BLoC pattern (with Accompanying article series)

There are also other popular State management techniques in the industry. Like Redux and Mobx.

. . .

16. Testing

That’s another step in this Flutter Tutorial. When the app grows, it becomes hard to test every feature, and then it comes regression too. In such cases, automation testing is the way to go. It helps ensure that the app performs as expected before we release it.

And so we don’t fall in such situations. 😆

Automation testing falls under three categories

A unit test tests a single function, method, or class.

A widget test (in other UI frameworks referred to as component test) tests a single widget.

An integration test tests a complete app or a large part of an app.

Check out the introduction to testing in Flutter her

Testing Flutter apps The more features your app has, the harder it is to test manually. Automated tests help ensure that your app performs… https://flutter.dev/docs/testing

16.1 Unit Testing

The goal of Unit testing is to test a particular Unit of code with Stub/mock dependencies. Verify the code works as expected in different scenarios. A unit test is very fast and doesn’t require an actual device to execute.

An introduction to unit testing How can you ensure that your app continues to work as you add more features or change existing functionality? By writing… https://flutter.dev/docs/cookbook/testing/unit/introduction

While doing Unit tests, any dependent classes should be injectable, so that we can inject a mock or fake implementation of dependency and verify if everything working as expected. Flutter has a mockito framework that helps to create a mock or fake implementation.

mockito | Dart Package Mock library for Dart inspired by Mockito. import ‘package:mockito/mockito.dart’; // Real class class Cat { String… https://pub.dev/packages/mockito

16.2 Widget Testing

Widget Testing (in Flutter) is a UI testing technique.

The goal of widget testing is to test if particular Widget UI looks as expected, and it’s interactive. Widget testing doesn’t require a physical device.

We could also test the properties of Widget, like Color, Size, Font Family, etc..

We can also perform user events like tap, gestures, entering text, etc

An introduction to widget testing In the introduction to the unit testing recipe, you learned how to test Dart classes using the test package. To test widget… https://flutter.dev/docs/cookbook/testing/widget/introduction

16.3 Integration Testing

Integration test work in a pair. The goal here is to test how multiple units work together. Integration testing happens on a real device or emulators.

We can fire a series of User interaction events and expect UI rendering or unit codes to be executed properly

An introduction to integration testing Unit tests and widget tests are handy for testing individual classes, functions, or widgets. However, they generally… https://flutter.dev/docs/cookbook/testing/integration/introduction

Again, Check this Video series for detailed implementation of real App with TDD.

16.4 BDD: Behavior-driven development

TDD or Unit Tests helps when a stakeholder has strong technical skills. BDD is all about writing a test case from the end user’s perspective. This is written in a natural English language.

Testcase can be written in the below format:

Given: the initial context at the beginning of the scenario, in one or more clauses;

when: the event that triggers the scenario;

then: the expected outcome, in one or more clauses.

Internally, a behavior test cases can be a Unit test, widget test, or a combination of both.

BDD helps to understand software functionality from an end-user perspective and becomes a sort of functional documentation.

Flutter has a gherkin that helps us writing Behaviour Test cases.

gherkin | Dart Package A fully featured Gherkin parser and test runner. Works with Flutter and Dart 2. This implementation of the Gherkin… https://pub.dev/packages/gherkin

. . .

This Flutter guide for beginners covers all the basics that you would need to know to start with flutter and develop your apps! We hope this step by step Flutter tutorial helps you on your journey to Flutter.