š±Flutter Roadmap & Resource Guideāāā2023
- Flutter is booming after the arrival of Flutter 2.0Ā ,announced in Flutter Engage held 0n March 03 2021 in which Flutter team announced that web version and desktop versions of the Windows, Linux and MacOS were promoted to the stable channel. It means you can create desktopĀ ,web and mobile apps using single codebaseĀ .
Letās discuss in detail the roadmap that I am following in order to efficiently learn flutter development .
***************** šÆDART BASICS **************
To understand which things are important to learn in this section lets first look at the nature and programming paradigms of dart .
what is dart ?
- Dart is a āāprogramming languageāā designed for client development, such as for the web and mobile apps.
- It is developed by Google and can also be used to build server and desktop applications.
- Dart is an object-oriented, class-based, garbage-collected language with C-style syntax.
We can do dart programming mainly in 3 paradigms/ways:
1.Functional programming :
Functional programming is a programming paradigm where programs are constructed by applying and composing functions.
A function is nothing but a block of organized, reusable code that is used to perform a single, related action.
2.Object Oriented programming
Object Oriented programming (OOP) is a programming paradigm that relies on the concept of classes and objects.
It is used to structure a software program into simple, reusable pieces of code blueprints (usually called classes), which are used to create individual instances of objects.
There are many object-oriented programming languages including JavaScript, C++,C#,JAVA, Dart and Python.
The four pillars of object-oriented programming are:
- Abstraction.
- Encapsulation.
- Inheritance.
- Polymorphism.
If you are beginner and you donāt know any OOP concepts watch Mosh video about OOP concepts in general :
OOP in 7 minutes (YouTube tutorial)
3.Asynchronous programming :
In sequential programming, synchronous operations tasks are performed one at a time and only when one is completed, the following is unblocked. In other words, you need to wait for a task to finish to move to the next one.
In asynchronous operations, on the other hand, you can move to another task before the previous one finishes.
we will discuss in detail in networking section .
ā”Confusion Regarding Dart
If you are new to programming world then you have to learn some basics concepts of dart like
Basics:
- variables and data types
- Operators
- Comments
- Control flow statements
- switch statements
- Null safety
- Functions ,parameters & its types ,anonymous functions, fat arrow(=>) functions .
Object Oriented basics :
- Classes and objects
- constructors
- Getters setters
- Encapsulation, Polymorphism, Abstraction, Inheritance
- Mixins
- Abstract classes and interfaces etc.
If you know any one programming language like C# , Java then you can grasp dart with within two to three days.
Learning Resources:
- Code with Andrea dart course ( Udemy course )
- FreeCodeCamp dart course ( YouTube )
- Dart language tour (Official docs)
**************š FLUTTER BASICS***************
After some know how of Dart itās time to dive into world of Flutter .you should learn these things at this stage.
1) Basics styling widgets:
Basic widgets to style a static UI like Text, Container, Row, Column, Asset Image, Network Image, Stack etc.
Learning Resources:
- Flutter widget of the week (official flutter YouTube series )
- Widgets Catalog (Official flutter docs)
- Angela Yu flutter course (Udemy course )
- Easy Approach (YouTube channel)
2) Use of Assets:
knowledge of how to use assets(image, video, SVG, images ) and how to add using pubspec.yaml file.
Learning Resources:
- Assets and images in flutter (Official docs)
- Flutter video/audio (medium article)
3) Types Of Widgets:
Know the difference between stateless and state full widgets .Knowledge of inherited widget and data passing through inherited widgets.
Learning Resources:
- Stateless/Statefull difference (YouTube channel)
- How does inherited widget work (Medium article )
4) Navigation and Routing:
How to navigate to next screen and back top previous using navigator.push( ) and navigator.pop( ).How to create routes.
Learning Resources:
5) Design Guide lines:
As flutter is a Googleās UI kit it follows Googleās material design guidelines so its good if you have a sound knowledge of material design guidelines as well as Flat design guidelines by Apple inc for iOS apps .
Learning Resources:
- Flutter Material design (official Doc)
- Cupertino widgets for iOS UI (official Doc)
- Apple UI design guideline
At this point you can to create beautiful static user interfaces āØš
***********š DYNAMIC INTERFACES ************
Up to previous stage you can create beautiful static user interfaces but as you can see in famous apps like Facebook ,Instagram they have a splash screen with loader, dynamic lists, lazy loading ,cool headers and navigator right?
You can create dynamic lists with ListView widget, create grids using GridView widget ,flex widgets etc.
Learning Resources:
*****************š ANIMATIONS **************
At this point you can create beautiful dynamic UIs but great mobile app stands out in both appearance, ease of use and features. The use of animation adds subtle beauty, functional ease and elements of user-friendliness to the app. Animations are a great option to respond to usersā actions. They are a great way to draw usersā attention towards the essential elements of an app.
1) Animated Widgets:
Flutter gives us Animations widgets like AnimatedContainer,Hero widget,Aniimated Crossfade etc.
Learning Resources:
- Introduction to animations (official doc)
- Animation and motion widgets (official docs)
- Implicit animations (Medium article)
Flutter aims to provide 60 frames per second (fps) performance, or 120 fps performance on devices capable of 120Hz updates.
2) Animation Tool:
Using tools like Rive and flare we can create cool animations and ship on any platform.
Learning Resources:
- Filled Stacks channel for animations
- Diegoveloper YouTube channel
- Code with Andrea animations course (coming soon in may 2021)
****** š¤³RESPONSIVE AND ADAPTIVE UI *********
At this point you can create beautiful dynamic prototype of app but as know flutter is a portable framework and your can run your app on different devices and platforms.
So first up, what are the key differences between responsive and adaptive design?
Put simply,
- responsive is fluid and adapts to the size of the screen no matter what the target device
- It means re-laying out the UI if the user resizes the window, or changes the deviceās orientation. This is especially necessary when the same app can run on a variety of devices, from a watch, phone, tablet, to a laptop or desktop computer.
while adaptive means :
- Managing different behaviors of app based on which platform it is running.
- There are different expectations about the appās visual density depending on platform(i.e. mobile, web, desktop ).
There are two basic approaches to creating Flutter apps with responsive design:
- Use the
LayoutBuilder
class - Use the
MediaQuery.of()
method in your build functions
Other useful widgets and classes for creating a responsive UI:
AspectRatio
CustomSingleChildLayout
CustomMultiChildLayout
FittedBox
FractionallySizedBox
LayoutBuilder
MediaQuery
MediaQueryData
OrientationBuilder
Resources To learn:
- Layout builder YouTube tutorial
- Adaptive layouts: Boring flutter show ( a series from Flutter developers)
- Flutter responsive design guide
************** šLocal Data storage ************
Flutter is just a UI tool kit but if you want to create full-fledged mobile application with backend you have to store data some where right?
If you want to save data offline on a device or caching data you can use shared preferences and light weight databases.
Shared Preferences:
shared preferences package saves small primitive data in the form of key-value pair locally on a device.
Resources To learn:
- Use shared_preferences in flutter app (Medium article )
- Shared preferences in 5 minutes (YouTube channel)
Hive:
Hive lightweight key-value database written in Dart for Flutter applications used for caching data or storing data locally on device .
Other options are SqfLite(wrapper of SQLite database ), moor etc.
Resources To learn:
- CRUD operation using hive (YouTube video)
If you have large critical data you need a full fledged databases like
*SQL server
* MySQL
*Firebase
*PostgreSQL etc.
with/without remote servers which we will discuss later in databases section.
*************** š Networking ******************
If you want to use data live from internet within your app you need to learn
- How to consume REST APIās
- Parsing JSON data into dart objects
- asynchronous programming concepts in dart.
- HTTP requests.(post, delete, get, put).
Resources To learn:
- Fetch data from internet (Official docs)
- JSON and Serialization (official docs)
- The easiest way to call Rest APIs in Flutter (Medium article)
- REST API integration with Flutter | HttpClient || News App
***************š±āšFire Base ******************
Storage
Firebase is a Backend-as-a-Service (Baas). It provides developers with a variety of tools and services to help them develop quality apps, grow their user base, and earn profit.
It is built on Googleās infrastructure. Firebase is categorized as a NoSQL database program, which stores data in JSON-like documents. Its storage platforms comes in two flavors.
1) Firebase Realtime Database is a cloud-hosted database in which data is stored as JSON.
* The data is synchronized in real-time to every connected client.
*It is the original database of Firebase.
2) Cloud Firestore is a flexible as well as scalable NoSQL cloud database more advance and better query options than real-time data base .
* It is used to store and sync data for client and server-side development.
* It is used for mobile, web, and server development from Google Cloud Platform and Firebase.
Push Notifications:
A push notification is a message that pops up on a mobile device. App publishers can send them at any time; users donāt have to be in the app or using their devices to receive them
you should have sound knowledge of how to send push notifications using firebase cloud messaging service .
Firebase- Authentication:
- Firebase Authentication provides backend services & easy-to-use SDKs to authenticate users to your app.
- It supports authentication using passwords, phone numbers, popular federated identity providers like Google, Facebook and Twitter, and more.
Learning Resources :
- Add firebase to your flutter app (firebase official docs)
- Flutter firebase complete course by fireship
- Push notifications with Firebase messaging
- Flutter firebase authentication
***********š« State management *************
As a beginner you handle simple states using setState( ) method but in large scale apps you need proper state management in order to reduce complexity and increasing robustness of app.
Famous flutter state management libraries :
- Provider
- Riverpod(successor of provider)
- Redux
- Mobx
- Get_it and more.
Learning Resources :
- Flutter state management (Flutter official docs)
- Get started with Riverpod (Riverpod official guide)
- Flutter = Redux + Testing (YouTube video of MTECHVIRAL)
- Getting started with MobX
*********šØ BACK-END FRAMEWORK ***********
In the world of mobile development, there are typically two terms that are like a common language within the field: Frontend and backend.
Backend is the important part of a mobile app that is responsible for data storage, security, and business logic. An app backend is much like a server for mobile apps, as it stores and sorts the important information that the end user does not see.
Its not a good approach to directly connect front end to database .we need API and other protocols of server to increase security, simplicity and performance .
We have two types of servers:
- Cloud servers: AWS, Microsoft Azure..
Learning Resources :
- Custom servers: Built using backend frameworks and technologies .
- Flutter with node JS (Blog Rocket article)
**************šØ Databases ********************
There are two main types of databases used in mobile application development mainly in flutter
SQL databases: Databases that used SQL(structure query language) .Mostly SQL databases use table architecture(store data in the form rows and columns)
No-SQL databases: Databases that donāt used SQL for query data .Most popular No SQL database is mongo dB .It stores data in the form of documents.
Learning Resources:
**********Architectural Patterns*****************
.Design patterns play a significant role in developing an application as best practices
- Formalize them that are loosely combined,
- Easier to test & maintain and facilitate reusable object-oriented development.
There are three types of most commonly used architectural UI design patterns such as MVC, MVP, and MVVM
Learning Resources:
- Flutter MVP Design pattern
- Flutter architecture will save your apps(Reso Coder YouTube video)
- Flutter MVVM YouTube course
***********šNative Features and plugins *******
Although Flutter is a cross platform framework using single codebase but you have to write some platform specific code for some native features mainly for android using kotlin or java and objective C or swift for iOS.
you have to learn the usage of image picker plugin, camera access ,usage of Google map API, file upload and pick from device etc. ā¦.
Learning Resources:
- Android platform specific code
- Maximillian Course => native features section (Udemy course)
***************Testing **********************
To build user friendly, high quality & bug free app testing is a essential phase after development of app. If your app have many features so its very hard to test each feature manually. Here comes automated testing.
Automated tests help ensure that your app performs correctly before you publish it.
Automated testing falls into a few categories:
- A unit test tests a single function, method, or class.
- A widget test tests a single widget.
- An integration test tests a complete app or a large part of an app.
CI/CD:
- Continuous Integration is the practice of testing each change done to your codebase automatically and as early as possible.
- Continuous Deployment follows the testing that happens during Continuous Integration and pushes changes to a staging or production system.
Learning Resources:
- Testing flutter apps (docs)
- Flutter testing ultimate guide (YouTube video)
- Widget testing with flutter (Medium article)
- Unit testing in flutter (YouTube video)
***************Deployment *********************
After development and testing phase its time to deploy your app .So you need to have a knowledge of Google play store and Apple store for mobile apps and for web application deployment/hosting you should know about firebase hosting, digital ocean hosting and GitHub pages .
Learning Resources:
- Deploying flutter app on play Store (YouTube Video)
- Deploying flutter app on play Store (YouTube Video)
Roadmap :
š Other Resourcesš
Below are the resources which I am following to lean dart and flutter
GitHub Repos:
Medium
YouTube Channels
- Flutter Official
- Fun with Flutter
- Academind
- Tech Idara
- LivDev
- Code with Andrea
- Easy Approach
- Muhammad Ahsan Ayaz
- Tadas petra
- Happy Fluttering
- Codepur
- The Flutter way
- Flutter Explained
- Filled Stacks
- Pooja Bhaumik
- Reso coder
- CodeX
- Flutter Community
- SmartHerd
- Robert Bruhnage
- MTECHVIRAL
- Easy Approach
- Net Ninja Flutter
This article is inspired from an awesome article Flutter Roadmap and resource guide in 2020 written by by Muhammad Hamza. Kindly follow him.
Whatās Next?
Congratulationsššā Now you are flutter developer and you can create beautiful and seamless application for almost any platform but learning never ends explore new technologies .Do open source contribution create a nice portfolio, linked profile and GitHub profile and never stop learning because life never stop teachingā¦ā¦
Thatās all from my side. If you like my article give Give Some Claps!! š