SlideShare a Scribd company logo
1 of 37
Flutter 101
Introduction to Flutter
Arif Amirani
CTO & Co-Founder at MetroGuild Inc
Agenda
◦ What is Flutter?
◦ Compare to Native/OEM Widgets based
◦ Setting it up
◦ Demo application walkthrough
◦ Q&A
2
3
BEAUTIFUL APPS!
“Flutter is Google’s UI toolkit
for building beautiful,
natively compiled
applications for mobile,
web, and desktop from a
single codebase
4
Why Flutter?
◦ Beautiful UI
◦ Control every pixel on the screen
◦ Never say "no" to your designer
◦ Stand out in the marketplace
◦ Beautiful animations
◦ Standard (Tween, etc) and Physics-based
5
Why Flutter for Developers?
◦ Fast
◦ 60fps
◦ Compiled to native code
◦ Productive
◦ Sub-second reload times (JIT vs AOT)
◦ Iterate rapidly on features
◦ Single-codebase for faster collaboration
◦ Vibrant community & growing
6
Flutter is Unique
◦ Compiles to Native Code (ARM Binary code)
◦ No reliance on OEM widgets
◦ No bridge needed
◦ No mark-up language (only Dart)
7
What makes it unique?
8
Platform SDKs
Webviews
What makes it unique?
9
Reactive
(Flux)
Flutter way – Awesome!
10
Under the hood
11
Flutter Embedders
12
Google Fuchsia
Fuchsia is a capability-based, real-
time operating system (RTOS)
currently being developed by
Google.
No more Java/Dalvik/Oracle
◦ Android
◦ iOS
◦ Desktop
◦ Web
◦ Raspberry Pi
◦ Android Things
Daaaaa…Dart?
◦ Open-source web programming
language developed by Google. (By the
guy who wrote v8 – Lars Bak)
◦ Class-based, single-inheritance with
mixins, object oriented language with C-
style syntax.
◦ Supports interfaces, abstract classes,
reified generics, and strong typing
13
Dart is easy peasy lemon squeezy
14
App Structure/Widgets
15
Widgets everywhere
◦ Widgets are immutable
◦ Declarations of parts of
the UI
◦ Like a <div>
◦ A structural element like
a button, menu
◦ A stylistic element like a
font, theme
◦ Part of layout like
padding, center
16
Its all widgets
17
What kind of Widgets are there?
◦ Generic Widget
◦ Column, Row, Flex, Padding, Opacity, etc.
◦ GestureDetector, Painter, etc.
◦ Material widgets
◦ RaisedButton, FlatButton, InkWell, etc.
◦ FloatingActionButton, etc.
◦ Cupertino widgets
◦ CupertinoActionSheet, CupertinoButton, etc
◦ CupertinoTextField, etc
18
19
20
21
The widget library
The package
manager (pub.dev)
22
The Widget Tree
23
Most common widgets
◦ Text, Image, Icon – Basic widgets
◦ Container - The div of Flutter UI. It's a convenience widget
that allows you to add padding, alignment, backgrounds,
force sizes on widgets, and boatloads of other things. It also
takes up 0px space when empty, which comes in handy.
◦ Row, Column – Flex rule based
◦ Stack - A stack displays a list of children on top of one and
other.
◦ Scaffold - This is the root of every page in your app, which
gives your app a basic layout structure. It makes it easy to
implement bottom navigations, appBars, back buttons, etc.
24
Stateful vs Stateless Widgets
25
BuildContext Class is nothing else but
a reference to the location of a Widget
within the tree structure of all the
Widgets which are built.
Stateful Widget Lifecycle
26
Flutter for HTML Developers
27
State Management
◦ Scoped Model
◦ Provider (Recommended)
◦ Business Logic Component or BLoC (too
complicated)
◦ Mobx
◦ Redux
28
Oh one more thing… Physics!!
29
Real Assets
30
Skeletal Animation
31
Trim Paths – Icons/Animations
32
Setting it up
33
34
Demo time!
36
Thanks!
MetroGuild Pune is hiring!
Flutter/Python/ReactJS Developers
You can find me at:
◦ https://www.linkedin.com/in/arifamirani/
◦ @kontinuity
References
◦ https://hackernoon.com/why-flutter-uses-
dart-dd635a054ebf
◦ https://medium.com/saugo360/flutters-
rendering-engine-a-tutorial-part-1-
e9eff68b825d
◦ https://hackernoon.com/whats-
revolutionary-about-flutter-946915b09514
◦ https://medium.com/@ralfgehrer/how-
flutter-works-under-the-hood-and-why-it-
is-game-changing-2335954a5bfc
37

More Related Content

What's hot

What's hot (20)

Flutter
FlutterFlutter
Flutter
 
Flutter beyond hello world
Flutter beyond hello worldFlutter beyond hello world
Flutter beyond hello world
 
Mobile development with Flutter
Mobile development with FlutterMobile development with Flutter
Mobile development with Flutter
 
What is flutter and why should i care?
What is flutter and why should i care?What is flutter and why should i care?
What is flutter and why should i care?
 
Flutter
FlutterFlutter
Flutter
 
Flutter
FlutterFlutter
Flutter
 
Introduction to Flutter.pptx
Introduction to Flutter.pptxIntroduction to Flutter.pptx
Introduction to Flutter.pptx
 
Flutter introduction
Flutter introductionFlutter introduction
Flutter introduction
 
What is Flutter
What is FlutterWhat is Flutter
What is Flutter
 
Flutter workshop
Flutter workshopFlutter workshop
Flutter workshop
 
Flutter Intro
Flutter IntroFlutter Intro
Flutter Intro
 
Hello Flutter
Hello FlutterHello Flutter
Hello Flutter
 
Flutter Tutorial For Beginners | Edureka
Flutter Tutorial For Beginners | EdurekaFlutter Tutorial For Beginners | Edureka
Flutter Tutorial For Beginners | Edureka
 
Flutter
FlutterFlutter
Flutter
 
Flutter introduction
Flutter introductionFlutter introduction
Flutter introduction
 
Introduction to flutter(1)
 Introduction to flutter(1) Introduction to flutter(1)
Introduction to flutter(1)
 
DSC IIITL Flutter Workshop
DSC IIITL Flutter WorkshopDSC IIITL Flutter Workshop
DSC IIITL Flutter Workshop
 
INTRODUCTION TO FLUTTER.pdf
INTRODUCTION TO FLUTTER.pdfINTRODUCTION TO FLUTTER.pdf
INTRODUCTION TO FLUTTER.pdf
 
Flutter
FlutterFlutter
Flutter
 
Flutter
Flutter Flutter
Flutter
 

Similar to Pune Flutter Presents - Flutter 101

Google Developer Group(GDG) DevFest Event 2012 Android talk
Google Developer Group(GDG) DevFest Event 2012 Android talkGoogle Developer Group(GDG) DevFest Event 2012 Android talk
Google Developer Group(GDG) DevFest Event 2012 Android talk
Imam Raza
 

Similar to Pune Flutter Presents - Flutter 101 (20)

Flutter Leap of Faith
Flutter Leap of FaithFlutter Leap of Faith
Flutter Leap of Faith
 
Cross Platform Mobile Development using Flutter by Wei Meng Lee at Mobile foc...
Cross Platform Mobile Development using Flutter by Wei Meng Lee at Mobile foc...Cross Platform Mobile Development using Flutter by Wei Meng Lee at Mobile foc...
Cross Platform Mobile Development using Flutter by Wei Meng Lee at Mobile foc...
 
Introduction to flutter's basic concepts
Introduction to flutter's basic conceptsIntroduction to flutter's basic concepts
Introduction to flutter's basic concepts
 
Introduzione a flutter
Introduzione a flutterIntroduzione a flutter
Introduzione a flutter
 
Getting Started with Cross-Platform Mobile Development with Flutter and Dart
Getting Started with Cross-Platform Mobile Development with Flutter and DartGetting Started with Cross-Platform Mobile Development with Flutter and Dart
Getting Started with Cross-Platform Mobile Development with Flutter and Dart
 
Flutter vs ReactNative
Flutter vs ReactNativeFlutter vs ReactNative
Flutter vs ReactNative
 
Flutter Introduction and Architecture
Flutter Introduction and ArchitectureFlutter Introduction and Architecture
Flutter Introduction and Architecture
 
Flutter - Pixel by Pixel
Flutter - Pixel by PixelFlutter - Pixel by Pixel
Flutter - Pixel by Pixel
 
Flutter App Development- Why Should You Choose It .
Flutter App Development- Why Should You Choose It .Flutter App Development- Why Should You Choose It .
Flutter App Development- Why Should You Choose It .
 
Introduction Flutter for Create Multiplatform Apps
Introduction Flutter for Create Multiplatform AppsIntroduction Flutter for Create Multiplatform Apps
Introduction Flutter for Create Multiplatform Apps
 
Introduction to hybrid application development
Introduction to hybrid application developmentIntroduction to hybrid application development
Introduction to hybrid application development
 
Titanium appcelerator kickstart
Titanium appcelerator kickstartTitanium appcelerator kickstart
Titanium appcelerator kickstart
 
Fluttering
FlutteringFluttering
Fluttering
 
The Story of SNCF Connect - biggest Flutter app in Europe (@FlutterHeroes 2023)
The Story of SNCF Connect - biggest Flutter app in Europe (@FlutterHeroes 2023)The Story of SNCF Connect - biggest Flutter app in Europe (@FlutterHeroes 2023)
The Story of SNCF Connect - biggest Flutter app in Europe (@FlutterHeroes 2023)
 
How does flutter cuts app development cost?
How does flutter cuts app development cost?How does flutter cuts app development cost?
How does flutter cuts app development cost?
 
Game development using Flutter
Game development using FlutterGame development using Flutter
Game development using Flutter
 
Google Developer Group(GDG) DevFest Event 2012 Android talk
Google Developer Group(GDG) DevFest Event 2012 Android talkGoogle Developer Group(GDG) DevFest Event 2012 Android talk
Google Developer Group(GDG) DevFest Event 2012 Android talk
 
Green Custard Friday Talk 22: Flutter
Green Custard Friday Talk 22: FlutterGreen Custard Friday Talk 22: Flutter
Green Custard Friday Talk 22: Flutter
 
Native mobile application development with Flutter (Dart)
Native mobile application development with Flutter (Dart)Native mobile application development with Flutter (Dart)
Native mobile application development with Flutter (Dart)
 
Going native - Taking desktop applications to mobile devices
Going native - Taking desktop applications to mobile devicesGoing native - Taking desktop applications to mobile devices
Going native - Taking desktop applications to mobile devices
 

Recently uploaded

Cloud Frontiers: A Deep Dive into Serverless Spatial Data and FME
Cloud Frontiers:  A Deep Dive into Serverless Spatial Data and FMECloud Frontiers:  A Deep Dive into Serverless Spatial Data and FME
Cloud Frontiers: A Deep Dive into Serverless Spatial Data and FME
Safe Software
 
Modular Monolith - a Practical Alternative to Microservices @ Devoxx UK 2024
Modular Monolith - a Practical Alternative to Microservices @ Devoxx UK 2024Modular Monolith - a Practical Alternative to Microservices @ Devoxx UK 2024
Modular Monolith - a Practical Alternative to Microservices @ Devoxx UK 2024
Victor Rentea
 

Recently uploaded (20)

Cloud Frontiers: A Deep Dive into Serverless Spatial Data and FME
Cloud Frontiers:  A Deep Dive into Serverless Spatial Data and FMECloud Frontiers:  A Deep Dive into Serverless Spatial Data and FME
Cloud Frontiers: A Deep Dive into Serverless Spatial Data and FME
 
TrustArc Webinar - Unlock the Power of AI-Driven Data Discovery
TrustArc Webinar - Unlock the Power of AI-Driven Data DiscoveryTrustArc Webinar - Unlock the Power of AI-Driven Data Discovery
TrustArc Webinar - Unlock the Power of AI-Driven Data Discovery
 
DEV meet-up UiPath Document Understanding May 7 2024 Amsterdam
DEV meet-up UiPath Document Understanding May 7 2024 AmsterdamDEV meet-up UiPath Document Understanding May 7 2024 Amsterdam
DEV meet-up UiPath Document Understanding May 7 2024 Amsterdam
 
How to Troubleshoot Apps for the Modern Connected Worker
How to Troubleshoot Apps for the Modern Connected WorkerHow to Troubleshoot Apps for the Modern Connected Worker
How to Troubleshoot Apps for the Modern Connected Worker
 
Polkadot JAM Slides - Token2049 - By Dr. Gavin Wood
Polkadot JAM Slides - Token2049 - By Dr. Gavin WoodPolkadot JAM Slides - Token2049 - By Dr. Gavin Wood
Polkadot JAM Slides - Token2049 - By Dr. Gavin Wood
 
MINDCTI Revenue Release Quarter One 2024
MINDCTI Revenue Release Quarter One 2024MINDCTI Revenue Release Quarter One 2024
MINDCTI Revenue Release Quarter One 2024
 
DBX First Quarter 2024 Investor Presentation
DBX First Quarter 2024 Investor PresentationDBX First Quarter 2024 Investor Presentation
DBX First Quarter 2024 Investor Presentation
 
Navigating the Deluge_ Dubai Floods and the Resilience of Dubai International...
Navigating the Deluge_ Dubai Floods and the Resilience of Dubai International...Navigating the Deluge_ Dubai Floods and the Resilience of Dubai International...
Navigating the Deluge_ Dubai Floods and the Resilience of Dubai International...
 
2024: Domino Containers - The Next Step. News from the Domino Container commu...
2024: Domino Containers - The Next Step. News from the Domino Container commu...2024: Domino Containers - The Next Step. News from the Domino Container commu...
2024: Domino Containers - The Next Step. News from the Domino Container commu...
 
Ransomware_Q4_2023. The report. [EN].pdf
Ransomware_Q4_2023. The report. [EN].pdfRansomware_Q4_2023. The report. [EN].pdf
Ransomware_Q4_2023. The report. [EN].pdf
 
Cyberprint. Dark Pink Apt Group [EN].pdf
Cyberprint. Dark Pink Apt Group [EN].pdfCyberprint. Dark Pink Apt Group [EN].pdf
Cyberprint. Dark Pink Apt Group [EN].pdf
 
Boost Fertility New Invention Ups Success Rates.pdf
Boost Fertility New Invention Ups Success Rates.pdfBoost Fertility New Invention Ups Success Rates.pdf
Boost Fertility New Invention Ups Success Rates.pdf
 
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemke
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemkeProductAnonymous-April2024-WinProductDiscovery-MelissaKlemke
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemke
 
ICT role in 21st century education and its challenges
ICT role in 21st century education and its challengesICT role in 21st century education and its challenges
ICT role in 21st century education and its challenges
 
Axa Assurance Maroc - Insurer Innovation Award 2024
Axa Assurance Maroc - Insurer Innovation Award 2024Axa Assurance Maroc - Insurer Innovation Award 2024
Axa Assurance Maroc - Insurer Innovation Award 2024
 
Emergent Methods: Multi-lingual narrative tracking in the news - real-time ex...
Emergent Methods: Multi-lingual narrative tracking in the news - real-time ex...Emergent Methods: Multi-lingual narrative tracking in the news - real-time ex...
Emergent Methods: Multi-lingual narrative tracking in the news - real-time ex...
 
Modular Monolith - a Practical Alternative to Microservices @ Devoxx UK 2024
Modular Monolith - a Practical Alternative to Microservices @ Devoxx UK 2024Modular Monolith - a Practical Alternative to Microservices @ Devoxx UK 2024
Modular Monolith - a Practical Alternative to Microservices @ Devoxx UK 2024
 
CNIC Information System with Pakdata Cf In Pakistan
CNIC Information System with Pakdata Cf In PakistanCNIC Information System with Pakdata Cf In Pakistan
CNIC Information System with Pakdata Cf In Pakistan
 
Spring Boot vs Quarkus the ultimate battle - DevoxxUK
Spring Boot vs Quarkus the ultimate battle - DevoxxUKSpring Boot vs Quarkus the ultimate battle - DevoxxUK
Spring Boot vs Quarkus the ultimate battle - DevoxxUK
 
Apidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, Adobe
Apidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, AdobeApidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, Adobe
Apidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, Adobe
 

Pune Flutter Presents - Flutter 101