Abdullah Fathi
FLUTTER
TRAINING
data:image/s3,"s3://crabby-images/66893/668931ffa5e09d0392976cf6a80b00e7223d383c" alt=""
INTRODUCTION
What is Flutter?
A "tools" that allows you to build native cross-platform (IOS, Android) apps with one programming language and codebase
SDK(Software Development Kit)
Tools to compile your code to native machine code + develop with ease
Re-usable UI building blocks (=widgets), utility functions, packages
Framework / Widget Library
Dart
data:image/s3,"s3://crabby-images/caa93/caa93b35ec85d6e1714a6d8a39ed497bf5196e9d" alt=""
Focused on frontend (mobile apps, web) user interface (UI) development
Object-oriented & Strongly Typed
Syntax is like a mixture of Java, Javascript, c#
Programming language developed by Google
Flutter Architecture
data:image/s3,"s3://crabby-images/4610e/4610e39df8fccb39fd6eec005b120bae7c31c3f8" alt=""
UI as code: build a widget tree
data:image/s3,"s3://crabby-images/ffeaf/ffeaf964a4aeb1af3f8d88bf9f2e56615ab09eba" alt=""
Embrace platform differences
data:image/s3,"s3://crabby-images/e06f5/e06f5dcdbe8d4804b07fd7215990c3fc28d9d6c8" alt=""
One Codebase
data:image/s3,"s3://crabby-images/ed80a/ed80a29a2bc3504a83bf4edb7abe1e16c91ac55e" alt=""
Everything's a Widget
Flutter Setup
Flutter (Windows)
Update Flutter PATH
- User Variables -> Path
- <path to flutter folder>\bin
Install Android Studio
- Makesure to choose "Android Virutal Device"
- "Android Studio Setup Wizard" -> Custom -> Choose AVD
External Android SDK
- Open Environment Variables
- User Variable -> new
- name: ANDROID_HOME
- value: <PATH TO ANDROID SDK>
- Edit Path
- %ANDROID_HOME%\tools
- %ANDROID_HOME%\platform-tools
IDE (VISUAL STUDIO CODE)
data:image/s3,"s3://crabby-images/b3132/b3132488d0a378b374fbc1f6316412743e22090d" alt=""
Install VSC Extension
flutter
Material Design
data:image/s3,"s3://crabby-images/a2f6a/a2f6af19dba85b954a989c7787398fffb2d57dda" alt=""
- Material is a Design System created (and heavily used) by Google
- Highly customizable (works on IOS devices, too)
- Material Design is built into Flutter but you also find Apple-styled (Cupertino) widgets
Flutter vs React Native vs Ionic
Javascript / React.js
Dart + Flutter
React Native
Flutter
Ionic
Javascript (Any or no Framework)
WebView-hosted Web Apps
Compiled Native Apps
Partly compiled (UI Components) Native Apps
Does compile to IOS / Android UI Components
Does not compile to IOS / Android UI Components
Does not compile to IOS / Android UI Components
Developed by Ionic
Developed by Google
Developed by Facebook
Flutter Basics
Building a quiz app (hands-on training)
Create New Project
flutter create <project name>
Create Android Emulator
- Open Android Studio
- Choose "Open an existing android project"
- Tools -> AVD Manager
- Create/Choose Virtual Device
- Choose hardware with playstore feature
- Choose latest stable system image
Run Project
- Using Terminal: flutter run
- Using VSC: Start Debugging / Start without debugging (a bit faster)
Overview Generated Files and Folder
- .idea: Hold some configuration for Android Studio
- android: Hold a complete Android project
- build: Hold the output of Flutter application
- ios: Hold a complete IOS project
- lib: Important folder. All of our dart code/file will be in here
- test: Allow us to write a test for our application, automated test, etc
- pubspec.yaml: Allos us to manage dependency of project
Dart Basics
Data Types
- String => "Hello" or 'Hello' => Text
- int => 20 or -54 => Numbers without decimal
- double => -3.99 or 85.9421 => Numbers WITH decimal places
- num => the 'parent type' of double and int
Class Constructor
Building a Widget Tree
Different Types of Widgets
Output & Input (Visible)
Layout & Control (Invisible)
RaisedButton(), Text(), Card(), ...
Drawn ont the screen:"What the user sees"
Row(), Column(), ListView(), ...
Give your app structure and control how visible widgets are drown onto the screen (indirectly visible)
Container()
Adding Layout Widgets
Connecting Functions & Buttons
Anonymous Functions
Updating Widget Data
What is "State"?
State is Data/Information used by your app
In General
App State
Authenticated Users
Loaded Jobs
...
Current User Input
Is a Loading Spinner being shown?
...
Widget State
Stateless vs Stateful
Input Data
Stateful
Stateless
Widget
Renders UI
Data can change (externally)
Gets (re)-rendered when input Data changes
Renders UI
Widget
Input Data
Internal State
Data can change (externally)
Gets (re)-rendered when input Data or local State changes
Private Properties
Create New Custom Widget
The Container()
child (=Content)
Padding
Border
Margin
Container
Enums & Multiple Constructor
Passing callback functions around
MAP
Final VS Const
"if" Statements
Splitting App into Widgets
Getters & "else-if"
Running apps on different devices & debugging apps
Devices
&
Debugging
Running App on Android Device
Working with Emulators
Error Messages
&
Fixing Errors
Debugger
Dart DevTools
Repaint Rainbow
Build a Real App
Widgets, Styling, Adding Logic
Most Important Widgets
data:image/s3,"s3://crabby-images/04e2c/04e2c37e3d2b20cadcc566420d84d3a379a539dd" alt=""
data:image/s3,"s3://crabby-images/48ef2/48ef2d5450461e701fbbb5ec677dbff966be6f55" alt=""
Details
data:image/s3,"s3://crabby-images/663ea/663ea309efe77589fe5eb93295cefc92db3af311" alt=""
Most Important Widgets
data:image/s3,"s3://crabby-images/a1dd2/a1dd2a5eaf710caad2827cec8cb771e6a8785e1a" alt=""
data:image/s3,"s3://crabby-images/1eeac/1eeacfd783be2f0897f5ec455cabe4c63a9ed87f" alt=""
Details
data:image/s3,"s3://crabby-images/16bda/16bda972f4a47690246db0c56e596c48fd72dd59" alt=""
data:image/s3,"s3://crabby-images/b4422/b44226fb9c3d1d632b59b6b96c82d12f68d854c9" alt=""
Most Important Widgets
data:image/s3,"s3://crabby-images/81d75/81d7593e1f1a09e5ab862c33f933d4f62e04bcbc" alt=""
data:image/s3,"s3://crabby-images/c03b4/c03b4d7fda93d0acc5e0616fcc0ab23645bc5aa6" alt=""
data:image/s3,"s3://crabby-images/622d3/622d39ee2db5b4a8f637dbb76c0998d88171b898" alt=""
Most Important Widgets
data:image/s3,"s3://crabby-images/6b0a4/6b0a458a39fcd2d8ef1b0732d28b6163c523ac32" alt=""
Details
data:image/s3,"s3://crabby-images/494d9/494d9840ff61e41fa3ca1b48f2abf3026be5301c" alt=""
Columns & Rows
data:image/s3,"s3://crabby-images/2334b/2334bb8d0494c8a17447995abb2fe798fb98bdd6" alt=""
Column & Row
Alignment
data:image/s3,"s3://crabby-images/7fa30/7fa301e79260ebd4eaa018d46f30d929739e993a" alt=""
Flexible & Expanded
data:image/s3,"s3://crabby-images/60d88/60d88d24c9f8b502c76f7452f65e79645dea83ed" alt=""
Flexible & Expanded
data:image/s3,"s3://crabby-images/18fa3/18fa3b58fb82214896a6e33ef3c8fccb397e2647" alt=""
Container vs
Column / Row
data:image/s3,"s3://crabby-images/56f0e/56f0e4f85535f7b9f1389308cb09c24acb0fe572" alt=""
ListView
data:image/s3,"s3://crabby-images/5031f/5031f947b3de4617c6befde52f690347c3d94b1e" alt=""
There are no secrets to success. It is the result of preparation, hard work, and learning from failure. - Colin Powell
THANK YOU
Flutter Training (Basic)
By Abdullah Fathi
Flutter Training (Basic)
- 332