Flutter, Firebase & Fastlane
#Orlando CC 2019
Agenda
📱 Introduction to Flutter
Build beautiful apps in record time
🔥 Firebase Features
Run Mobile Backend Server without managing
⚒ Fastlane Tools
App automation done right
🚀 Demo
Demo of Flutter, Firebase & Fastlane
Hello👋
I'm Siva
Architect @ Computer Enterprises Inc
#Mobile #AI #IoT #Cloud
Orlando
@ksivamuthu
data:image/s3,"s3://crabby-images/c974d/c974d166a163b011bd40eff9cfe1dd15f294c962" alt=""
data:image/s3,"s3://crabby-images/9954e/9954e917f9f27a4ee78e086a07e8bc23f661fb87" alt=""
Flutter allows you to build beautiful native apps on iOS and Android from a single codebase.
Javascript ??
data:image/s3,"s3://crabby-images/0a2e4/0a2e4a8bbb2c93ecaa16b9e4124764f6646ea455" alt=""
Dart
Dynamic scripting language (runs in a Dart VM)
Object Orientation
Better performance & Better Tooling
Intended as successor to Javascript
Both AOT and JIT compilations
void main() {
print('Hello, World!');
}
class Spacecraft {
String name;
DateTime launchDate;
Spacecraft(this.name, this.launchDate) {
// Initialization code goes here.
}
int get launchYear =>
launchDate?.year;
void describe() {
print('Spacecraft: $name');
if (launchDate != null) {
int years =
DateTime.now().difference(launchDate).inDays ~/
365;
print('Launched: $launchYear ($years years ago)');
} else {
print('Unlaunched');
}
}
}
var voyager = Spacecraft('Voyager I', DateTime(1977, 9, 5));
voyager.describe();
data:image/s3,"s3://crabby-images/76c87/76c8791b2a72aad9477532abcab14b4aced8340d" alt=""
data:image/s3,"s3://crabby-images/a8c6f/a8c6f7038e36758d361dfac7b51243b9a5ec68bc" alt=""
data:image/s3,"s3://crabby-images/56891/568916feb8ec09c2702e27e43b9c04d408256c9f" alt=""
data:image/s3,"s3://crabby-images/f778a/f778a1057a4e9bd7442a18c30e91c68e62314321" alt=""
data:image/s3,"s3://crabby-images/c3b46/c3b468ad50db610f310fe471dab82a35d55c86cf" alt=""
Everything within a Flutter application is a Widget in Flutter, from a simple “Text” to “Buttons” to “Screen Layouts”.
import 'package:flutter/material.dart';
void main() {
runApp(
Center(
child: Text(
'Hello, world!',
),
),
);
}
data:image/s3,"s3://crabby-images/209d6/209d66742002e177a2f1cbde2c3760c9a2d963af" alt=""
Stateless Widgets - Immutable
data:image/s3,"s3://crabby-images/fc8ee/fc8ee220ade406089312f98c2ea6344279c80aae" alt=""
Stateful Widgets - Mutable
Hot Reload
data:image/s3,"s3://crabby-images/aefce/aefce72c9122a42bb82219c37f9a24b3b810febf" alt=""
data:image/s3,"s3://crabby-images/6611f/6611fe2bc590bb05b1c070bc41a3949e7d7592e7" alt=""
Paint your app to life in milliseconds with stateful Hot Reload. Use a rich set of fully-customizable widgets to build native interfaces in minutes.
Fast Development
Delight your users with Flutter's built-in beautiful Material Design and Cupertino (iOS-flavor) widgets, rich motion APIs, smooth natural scrolling, and platform awareness.
Expressive, beautiful UIs
Flutter’s widgets incorporate all critical platform differences such as scrolling, navigation, icons and fonts to provide full native performance on both iOS and Android.
Native Performance
data:image/s3,"s3://crabby-images/ebcab/ebcab2b7bf8b10d5425330b3394e635d3cdd04cb" alt=""
data:image/s3,"s3://crabby-images/1d58c/1d58c164a2bd6a9cb755e4057fdb1c30abdabbd1" alt=""
data:image/s3,"s3://crabby-images/5641c/5641c35b01c5344afefbe125d90d76a7f88a662c" alt=""
Firebase Authentication
Firebase Cloud Messaging
data:image/s3,"s3://crabby-images/c9b8d/c9b8dc24063735c285a131dc86a528b398e354b7" alt=""
Firebase A/B Testing
data:image/s3,"s3://crabby-images/e1af9/e1af98e0c678e05351cb1023ed9a89a2e7a98088" alt=""
Firebase Remote Config
data:image/s3,"s3://crabby-images/f4501/f45019b46263914f5ff0fe0fb15995c2da173021" alt=""
Cloud Firestore
data:image/s3,"s3://crabby-images/25508/255080f1372f0c5de0022b591370d03b3adda1ca" alt=""
~Demo~
Developer Emotion Tracker
data:image/s3,"s3://crabby-images/413cc/413cca839b42de009859973c393c84e0909e57e5" alt=""
data:image/s3,"s3://crabby-images/42162/42162d3d25a854b9a1e4821399f74e9bf8869944" alt=""
data:image/s3,"s3://crabby-images/527d4/527d49fb7900ba08debcd67bee56a4ec67c9ac70" alt=""
data:image/s3,"s3://crabby-images/eb292/eb292457dc0b1bc78166c46e9c2d76d30724980d" alt=""
Buzz Word !!
data:image/s3,"s3://crabby-images/0e9ab/0e9ab5905bd11f7c9fc014fc790862c434151613" alt=""
Artificial Intelligence
data:image/s3,"s3://crabby-images/3ab43/3ab43d05dbe45ad03e6aa5142d1a4f476f6f47bb" alt=""
Common use cases
data:image/s3,"s3://crabby-images/fd45f/fd45ffda5f1779d323a611db7a69c3764a798074" alt=""
On Device or in the Cloud
data:image/s3,"s3://crabby-images/19acb/19acb70223c778575fdf02cf5678a67443ce1134" alt=""
Deploy Custom Models
data:image/s3,"s3://crabby-images/2bd42/2bd422af1328044ad9202bd035b58272767c595f" alt=""
data:image/s3,"s3://crabby-images/ef7b9/ef7b95f75aa9dde8f5d277d997c204bf6d930a1e" alt=""
data:image/s3,"s3://crabby-images/125c1/125c12344159719dee0d8cfef9a676c547fa3c97" alt=""
lane :beta do
increment_build_number
build_app
upload_to_testflight
end
lane :release do
capture_screenshots
build_app
upload_to_app_store
slack
end
Reference
Action Items
- Learn and explore Flutter
- Feel free to reach me if you've any questions
- Be Kind & Spread Your Awesomeness ...
ksivamuthu
data:image/s3,"s3://crabby-images/3eb79/3eb79dfbe24fec1a5e5c506e9d7f4b706c28fcbe" alt=""
ksivamuthu
data:image/s3,"s3://crabby-images/660e2/660e2ca86a4fac31016791427c5fc435f1c936e4" alt=""
Flutter, Firebase & Fastlane
By Sivamuthu Kumar
Flutter, Firebase & Fastlane
Flutter Firebase & Fastlane
- 1,381