SlideShare a Scribd company logo
1 of 52
Extended
Kuala Lumpur
Flutter
NOT yet another framework
TruongSinh Tran-Nguyen, Inspectorio
@truongsinhtn
About Speaker
● “Sinh”
● 10y+ working w/ European and VN
startups
● People's Choice CTO of the Year
2016 – Nordic Startup Award
Finland
● Engineering Director,
● Flutter advocate
About
● Startup, 13 quarters-old
● Quality and compliance platform, powered by AI
● B2B, serving Fortune 100 factories, brands, retailers,
such as (this might not be technically true, just to
illustrate)
Source: Lorem ipsum dolor sit amet, consectetur adipiscing elit. Duis non erat sem
About
Agenda
● What is Flutter?
● Isn’t it just YET ANOTHER cross-mobile framework?
○ Tech, Community, Strategy
● Hold on, it’s too good to be true!
What is Flutter?
● Open-sourced, made by
● Started as a cross-platform mobile SDK
● Now a SDK ”for building beautiful, natively-compiled
applications for mobile, web, and desktop from a single
codebase.”
○ Also embedded (e.g. Google Home Hub or Raspberry
Pi)
What is Flutter?
● Open-sourced, made by
● Started as a cross-platform mobile SDK
● Now a SDK ”for building beautiful, natively-compiled
applications for mobile, web, and desktop from a single
codebase.”
○ Also embedded (e.g. Google Home Hub or Raspberry
Pi)
Déjà vu?
Agenda
● What is Flutter?
● Isn’t it just YET ANOTHER cross-mobile framework?
○ Tech, Community, Strategy
● Hold on, it’s too good to be true!
Flutter’s trinity
NativeScript & ReactNative (& others)
● At Smarp, I made the wrong choice with
● Coming to , same choice had been made
● For a RISE (our new product), we almost went with
NativeScript & ReactNative (& others)
● For a RISE (our new product), we almost went with
but it fails on
○ Android performance, esp. camera
○ dependency management (to eject or not to eject)
○ computer vision and IoT support
→ went with Android (no iOS still)*
*Yeah, I did PoC w/ Xamarin and RoboVM when in Smarp too
Flutter’s trinity
Extended
Kuala Lumpur
Flutter technology
Tools – Rendering Engine – UI as Code
Tools
● Flutter is not a framework, but an SDK
● debugger, inspector, profiling, stack tracing, FPS
performance overlay, testing framework
○ Android Studio
○ VS Code
Tools
Rendering engine
● Ship with own engine, Skia
● Achieve consistent 120 fps
○ 60 fps on common device
Rendering engine
● Ship with own engine, Skia
● Achieve consistent 120 fps
○ 60 fps on common device
What The Flutter is
OEM Widget?
NOT OEM Widgets
Old OS New OS?
NOT OEM Widgets
Old OS New OS?
NOT OEM Widgets
Old OS New OS?
Rendering engine
● Similar to those game engine Unity
○ We can even write games in
Flutter
● 1st class tablet and responsive
support
● Less reason to “cross the bridge”
● Crossing is easy as well
Reactive Declarative UI as Code
● Reactive Declarative UI as code
● Trendy and healthy competition within mobile
development: Jetpack Compose, SwiftUI
Reactive Declarative UI as Code
● Together with different compilation modes
○ Debug: JIT Dart VM → subsecond hot reload
○ Production: AOT ARM code → CPU and RAM
optimized
→ Best of both world
→ Great developer experience
Technology
Tools + Rendering Engine + UI as code
= Developer experience
3 types of testing instead of 2
● Unit, Instrumentation vs Unit, Widget, Integration
Flutter’s trinity
Extended
Kuala Lumpur
The Community
Designers, Engineers, Contributors
Designers
● Heard about Flutter from a designer
○ Flutter is design-centric or even design-first
● Material design announced that Flutter is their first-class
platform.
Designers
● Sub-second hot reload + declarative widget composition
→ desired design in record time
● “Live preview” mostly displays static design, while our
designers are also picky about animation design
● Skia → easy to achieve consistent brand-identity design
Engineers
● Flutter is THE Fastest Growing Skill Among Software
Engineers¹
● Hirings are booming in around the world²
¹ LinkedIn, March 2019
² Even in VN and BY, but not that I can search in MY, maybe because I was searching in English?
Engineers
● Gentle learning curve, esp for ppl w/ background
○ native mobile
○ reactive frontend (RxJS, React)
Engineers
● The community is open, modest, respectful to other
technologies
● “The Boring Show”
○ An hour of unedited pair programming by G
engineers, including all dead ends, blunders, runtime
errors, silly typos, edge-case bugs
Contributors
● #22, GitHub’s Top 100 Most Valuable Repositories¹
¹ U°OS / https://u.community/
Contributors
● YouTube, Medium
● Twitter, Reddit, Facebook
● Stackoverflow, Quora
Contributors
● Official Flutter Youtube, Medium, @flutterdev
● MTechViral Youtube, @imthepk
● Flutter Community Medium, @FlutterComm
● r/FlutterDev Reddit and @r_FlutterDev
● Other international English speaking
● Other local/non-English
Flutter’s trinity
Extended
Kuala Lumpur
The Strategy
Among all the players, only Google has both
the resources and incentives to see Flutter
take off.
Google’s strategy
Tech stack Resources Incentives
NativeScript ❌ ✅
React Native ✅ ❌
Xamarin ❌ ❌
Flutter ✅ ✅
Why Google has incentives?
● Open-sourced, made by
● wants to consolidate their platforms/OS, and
development experience
● “Write once, render everywhere”
○ iOS, Android, Linux, Mac, Windows, Browser,
Embedded
Unified Development Experience
Unified Platform
Flutter’s trinity
Agenda
● What is Flutter?
● Why I should care? Isn’t it just yet another…?
● Hold on, it’s too good to be true!
Agenda
● What is Flutter?
● Why I should care? Isn’t it just yet another…?
● Hold on, it’s too good to be true!
What’s the catch
● ObjC < Java < Dart < Swift/Kotlin
What’s the catch
What’s the catch
What’s the catch
● ObjC < Java < Dart < Swift/Kotlin
○ Null safety, LLVM optimization, tail recursive, “when”,
etc.
● Lack of iOS bitcode → no 🍎⌚️
● No code push / hot update
● 1st party plugins are written ObjC/Java (I wish they were
in Swift/Kotlin)
Extended
Kuala Lumpur
Thank You
Extended
Kuala Lumpur
Oh, one more thing
Remember I said we can write games in Flutter?
Now remember the legendary Flappy game?
Try it yourself
https://github.com
/truongsinh
/fluttery_dash
/releases/tag/v0.0.1
Extended
Kuala Lumpur
Questions?
Follow-up
on Medium

More Related Content

What's hot

What's hot (20)

Mobile DevOps pipeline using Google Flutter
Mobile DevOps pipeline using Google FlutterMobile DevOps pipeline using Google Flutter
Mobile DevOps pipeline using Google Flutter
 
Flutter vs React Native
Flutter vs React NativeFlutter vs React Native
Flutter vs React Native
 
Flutter 2.8 features and updates
Flutter 2.8 features and updatesFlutter 2.8 features and updates
Flutter 2.8 features and updates
 
[Alexandria Devfest] the magic of flutter
[Alexandria Devfest] the magic of flutter[Alexandria Devfest] the magic of flutter
[Alexandria Devfest] the magic of 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?
 
Intro to Flutter SDK
Intro to Flutter SDKIntro to Flutter SDK
Intro to Flutter SDK
 
Building Beautiful Apps using Google Flutter
Building Beautiful Apps using Google FlutterBuilding Beautiful Apps using Google Flutter
Building Beautiful Apps using Google Flutter
 
A good intro to Flutter and its magic
A good intro to Flutter and its magicA good intro to Flutter and its magic
A good intro to Flutter and its magic
 
Flutter workshop
Flutter workshopFlutter workshop
Flutter workshop
 
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)
 
The magic of flutter
The magic of flutterThe magic of flutter
The magic of flutter
 
Building beautiful apps using google flutter
Building beautiful apps using google flutterBuilding beautiful apps using google flutter
Building beautiful apps using google flutter
 
Build beautiful native apps in record time with flutter
Build beautiful native apps in record time with flutterBuild beautiful native apps in record time with flutter
Build beautiful native apps in record time with flutter
 
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...
 
Build responsive applications with google flutter
Build responsive applications with  google flutterBuild responsive applications with  google flutter
Build responsive applications with google flutter
 
What's new in flutter and dart in 2020
 What's new in flutter and dart in 2020   What's new in flutter and dart in 2020
What's new in flutter and dart in 2020
 
Google flutter the easy and practical way
Google flutter the easy and practical wayGoogle flutter the easy and practical way
Google flutter the easy and practical way
 
Flutter
FlutterFlutter
Flutter
 
Why companies like Google, Alibaba and UOL choose Flutter
Why companies like Google, Alibaba and UOL choose FlutterWhy companies like Google, Alibaba and UOL choose Flutter
Why companies like Google, Alibaba and UOL choose Flutter
 
Mobile App Development Tools of 2018
Mobile App Development Tools of 2018Mobile App Development Tools of 2018
Mobile App Development Tools of 2018
 

Similar to Flutter not yet another mobile cross-platform framework - i ox-kl19

Flutter Developer Journey - GDSC Indore (1).pdf
Flutter Developer Journey - GDSC Indore (1).pdfFlutter Developer Journey - GDSC Indore (1).pdf
Flutter Developer Journey - GDSC Indore (1).pdf
SarikaPurohit1
 
Python Django Intro V0.1
Python Django Intro V0.1Python Django Intro V0.1
Python Django Intro V0.1
Udi Bauman
 
Programming for non tech entrepreneurs
Programming for non tech entrepreneursProgramming for non tech entrepreneurs
Programming for non tech entrepreneurs
Rodrigo Gil
 

Similar to Flutter not yet another mobile cross-platform framework - i ox-kl19 (20)

A flight with Flutter
A flight with FlutterA flight with Flutter
A flight with Flutter
 
Flutter Developer Journey - GDSC Indore (1).pdf
Flutter Developer Journey - GDSC Indore (1).pdfFlutter Developer Journey - GDSC Indore (1).pdf
Flutter Developer Journey - GDSC Indore (1).pdf
 
LAS16-108: JerryScript and other scripting languages for IoT
LAS16-108: JerryScript and other scripting languages for IoTLAS16-108: JerryScript and other scripting languages for IoT
LAS16-108: JerryScript and other scripting languages for IoT
 
Mobile app development with Flutter: The Need for Speed!
Mobile app development with Flutter: The Need for Speed!Mobile app development with Flutter: The Need for Speed!
Mobile app development with Flutter: The Need for Speed!
 
Python Django Intro V0.1
Python Django Intro V0.1Python Django Intro V0.1
Python Django Intro V0.1
 
Cross-Platform Mobile Development with PhoneGap-Vince Bullinger
Cross-Platform Mobile Development with PhoneGap-Vince BullingerCross-Platform Mobile Development with PhoneGap-Vince Bullinger
Cross-Platform Mobile Development with PhoneGap-Vince Bullinger
 
GDSC Unsri 2023 - Flutterflow Presentation.pptx
GDSC Unsri 2023 - Flutterflow Presentation.pptxGDSC Unsri 2023 - Flutterflow Presentation.pptx
GDSC Unsri 2023 - Flutterflow Presentation.pptx
 
Programming for non tech entrepreneurs
Programming for non tech entrepreneursProgramming for non tech entrepreneurs
Programming for non tech entrepreneurs
 
Ploneide
PloneidePloneide
Ploneide
 
Voxxed Days Villnius 2015 - Burning Marshmallows
Voxxed Days Villnius 2015 - Burning MarshmallowsVoxxed Days Villnius 2015 - Burning Marshmallows
Voxxed Days Villnius 2015 - Burning Marshmallows
 
Android Study Jam
Android Study Jam Android Study Jam
Android Study Jam
 
Tooling Matters - Development tools
Tooling Matters - Development toolsTooling Matters - Development tools
Tooling Matters - Development tools
 
HOW TO START (ANYTHING ABOUT CODE).pptx
HOW TO START (ANYTHING ABOUT CODE).pptxHOW TO START (ANYTHING ABOUT CODE).pptx
HOW TO START (ANYTHING ABOUT CODE).pptx
 
Computer Programming Overview
Computer Programming OverviewComputer Programming Overview
Computer Programming Overview
 
Dynatech presentation for TSI Career Day
Dynatech presentation for TSI Career DayDynatech presentation for TSI Career Day
Dynatech presentation for TSI Career Day
 
Game Development in VR
Game Development in VR Game Development in VR
Game Development in VR
 
Google flutter
Google flutterGoogle flutter
Google flutter
 
Info Session GDSC USICT
Info Session GDSC USICTInfo Session GDSC USICT
Info Session GDSC USICT
 
Open source, What | Why | How
Open source, What | Why | How Open source, What | Why | How
Open source, What | Why | How
 
7 reasons why flutter might be the best choice for your next project
7 reasons why flutter might be the best choice for your next project7 reasons why flutter might be the best choice for your next project
7 reasons why flutter might be the best choice for your next project
 

Recently uploaded

+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...
+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...
+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...
Health
 
CALL ON ➥8923113531 🔝Call Girls Kakori Lucknow best sexual service Online ☂️
CALL ON ➥8923113531 🔝Call Girls Kakori Lucknow best sexual service Online  ☂️CALL ON ➥8923113531 🔝Call Girls Kakori Lucknow best sexual service Online  ☂️
CALL ON ➥8923113531 🔝Call Girls Kakori Lucknow best sexual service Online ☂️
anilsa9823
 
TECUNIQUE: Success Stories: IT Service provider
TECUNIQUE: Success Stories: IT Service providerTECUNIQUE: Success Stories: IT Service provider
TECUNIQUE: Success Stories: IT Service provider
mohitmore19
 

Recently uploaded (20)

The Real-World Challenges of Medical Device Cybersecurity- Mitigating Vulnera...
The Real-World Challenges of Medical Device Cybersecurity- Mitigating Vulnera...The Real-World Challenges of Medical Device Cybersecurity- Mitigating Vulnera...
The Real-World Challenges of Medical Device Cybersecurity- Mitigating Vulnera...
 
The Ultimate Test Automation Guide_ Best Practices and Tips.pdf
The Ultimate Test Automation Guide_ Best Practices and Tips.pdfThe Ultimate Test Automation Guide_ Best Practices and Tips.pdf
The Ultimate Test Automation Guide_ Best Practices and Tips.pdf
 
Unveiling the Tech Salsa of LAMs with Janus in Real-Time Applications
Unveiling the Tech Salsa of LAMs with Janus in Real-Time ApplicationsUnveiling the Tech Salsa of LAMs with Janus in Real-Time Applications
Unveiling the Tech Salsa of LAMs with Janus in Real-Time Applications
 
Software Quality Assurance Interview Questions
Software Quality Assurance Interview QuestionsSoftware Quality Assurance Interview Questions
Software Quality Assurance Interview Questions
 
call girls in Vaishali (Ghaziabad) 🔝 >༒8448380779 🔝 genuine Escort Service 🔝✔️✔️
call girls in Vaishali (Ghaziabad) 🔝 >༒8448380779 🔝 genuine Escort Service 🔝✔️✔️call girls in Vaishali (Ghaziabad) 🔝 >༒8448380779 🔝 genuine Escort Service 🔝✔️✔️
call girls in Vaishali (Ghaziabad) 🔝 >༒8448380779 🔝 genuine Escort Service 🔝✔️✔️
 
Unlocking the Future of AI Agents with Large Language Models
Unlocking the Future of AI Agents with Large Language ModelsUnlocking the Future of AI Agents with Large Language Models
Unlocking the Future of AI Agents with Large Language Models
 
Optimizing AI for immediate response in Smart CCTV
Optimizing AI for immediate response in Smart CCTVOptimizing AI for immediate response in Smart CCTV
Optimizing AI for immediate response in Smart CCTV
 
Diamond Application Development Crafting Solutions with Precision
Diamond Application Development Crafting Solutions with PrecisionDiamond Application Development Crafting Solutions with Precision
Diamond Application Development Crafting Solutions with Precision
 
+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...
+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...
+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...
 
Vip Call Girls Noida ➡️ Delhi ➡️ 9999965857 No Advance 24HRS Live
Vip Call Girls Noida ➡️ Delhi ➡️ 9999965857 No Advance 24HRS LiveVip Call Girls Noida ➡️ Delhi ➡️ 9999965857 No Advance 24HRS Live
Vip Call Girls Noida ➡️ Delhi ➡️ 9999965857 No Advance 24HRS Live
 
5 Signs You Need a Fashion PLM Software.pdf
5 Signs You Need a Fashion PLM Software.pdf5 Signs You Need a Fashion PLM Software.pdf
5 Signs You Need a Fashion PLM Software.pdf
 
How To Use Server-Side Rendering with Nuxt.js
How To Use Server-Side Rendering with Nuxt.jsHow To Use Server-Side Rendering with Nuxt.js
How To Use Server-Side Rendering with Nuxt.js
 
W01_panagenda_Navigating-the-Future-with-The-Hitchhikers-Guide-to-Notes-and-D...
W01_panagenda_Navigating-the-Future-with-The-Hitchhikers-Guide-to-Notes-and-D...W01_panagenda_Navigating-the-Future-with-The-Hitchhikers-Guide-to-Notes-and-D...
W01_panagenda_Navigating-the-Future-with-The-Hitchhikers-Guide-to-Notes-and-D...
 
CALL ON ➥8923113531 🔝Call Girls Kakori Lucknow best sexual service Online ☂️
CALL ON ➥8923113531 🔝Call Girls Kakori Lucknow best sexual service Online  ☂️CALL ON ➥8923113531 🔝Call Girls Kakori Lucknow best sexual service Online  ☂️
CALL ON ➥8923113531 🔝Call Girls Kakori Lucknow best sexual service Online ☂️
 
Learn the Fundamentals of XCUITest Framework_ A Beginner's Guide.pdf
Learn the Fundamentals of XCUITest Framework_ A Beginner's Guide.pdfLearn the Fundamentals of XCUITest Framework_ A Beginner's Guide.pdf
Learn the Fundamentals of XCUITest Framework_ A Beginner's Guide.pdf
 
Try MyIntelliAccount Cloud Accounting Software As A Service Solution Risk Fre...
Try MyIntelliAccount Cloud Accounting Software As A Service Solution Risk Fre...Try MyIntelliAccount Cloud Accounting Software As A Service Solution Risk Fre...
Try MyIntelliAccount Cloud Accounting Software As A Service Solution Risk Fre...
 
Tech Tuesday-Harness the Power of Effective Resource Planning with OnePlan’s ...
Tech Tuesday-Harness the Power of Effective Resource Planning with OnePlan’s ...Tech Tuesday-Harness the Power of Effective Resource Planning with OnePlan’s ...
Tech Tuesday-Harness the Power of Effective Resource Planning with OnePlan’s ...
 
Shapes for Sharing between Graph Data Spaces - and Epistemic Querying of RDF-...
Shapes for Sharing between Graph Data Spaces - and Epistemic Querying of RDF-...Shapes for Sharing between Graph Data Spaces - and Epistemic Querying of RDF-...
Shapes for Sharing between Graph Data Spaces - and Epistemic Querying of RDF-...
 
A Secure and Reliable Document Management System is Essential.docx
A Secure and Reliable Document Management System is Essential.docxA Secure and Reliable Document Management System is Essential.docx
A Secure and Reliable Document Management System is Essential.docx
 
TECUNIQUE: Success Stories: IT Service provider
TECUNIQUE: Success Stories: IT Service providerTECUNIQUE: Success Stories: IT Service provider
TECUNIQUE: Success Stories: IT Service provider
 

Flutter not yet another mobile cross-platform framework - i ox-kl19