Save 37% off PRO during our Black Friday Sale! »

DartとFlutterでアプリ開発

7ce6ac050a103c4e939c5b06f6f6d847?s=47 ken
July 05, 2019

 DartとFlutterでアプリ開発

2019/07/05
「宮城アプリ開発勉強会 #1」の資料です。

Dart/Flutterに興味はあるけどやった事無い、という皆さんに向けて、
こんな感じだよー、という雰囲気の資料です。

7ce6ac050a103c4e939c5b06f6f6d847?s=128

ken

July 05, 2019
Tweet

Transcript

  1. DartとFlutterで アプリ開発 宮城アプリ開発勉強会 2019/07/05

  2. ⾃⼰紹介 ๏ 佐藤健(さとうけん) • フリーランスのプログラマ ๏ ⾔語 • Flash/ActionScript •

    TypeScript ๏ 趣味 • スラックライン(楽しいよ) • トランポリン(ハマるよ)
  3. Dart? JavaScriptの代替になりたかった プログラミング⾔語

  4. Flutter? iOS/Androidアプリ開発の Dart⽤フレームワーク

  5. Dart、誕⽣ ๏ Googleが開発 ๏ 2011年初公開 • JavaScriptの代替として新規開発 • DartVMで動作する •

    DartVMはいずれChromeに統合される • …はずだったのだが…
  6. Dart、⽅向転換 ๏ 2015年 DartVMのChrome統合を断念 • JavaScriptへコンパイルする形へ ๏ 2017年 TypeScriptがGoogle社内標準⾔語に Ͳ͏ߟ͑ͯ΋ɺ


    %BSUɺ͜ͷ··ফ͑ΔͩΖɻɻɻ
  7. ๏ 2018年2⽉ 突然の再起動 • 22⽇ Dart2の発表 • 27⽇ Flutter(Beta)の発表 ๏

    2018年12⽉ • 4⽇ Flutter1.0 リリース ๏ 2019年7⽉現在 • Dart2.4.0(2019-06-27) • Flutter 1.5.4-hotfix.2 • 開発版は1.7.11が最新 Dart、再起動 ٸʹ׆ൃʹͳͬͨʜ
  8. ๏ Androidアプリが作れる ๏ iOSアプリが作れる ๏ 同じソースコードで両⽅作れる • iOSっぽいUIパーツも⽤意されている Flutter、概要 ಉ͡ιʔείʔυͰ࡞ΕΔΑɻ

    ΋ͪΖΜͦΕͳΓͷखؒ͸ඞཁ͚ͩͲͶɻ w w w
  9. Flutter、余談 ๏ Fuchsia(フクシア、フクシャ、フューシャ) • Googleが開発中の新しいOS(謎) • UIとアプリはDart/Flutterで作成

  10. Dart/Flutter、開発環境 ๏ Dartを試すだけなら • https://dartpad.dartlang.org/ ๏ きちんと環境を構築するなら • AndroidStudio もしくは

    VSCode • https://flutter.dev/ • 「Get Started」の通り
 1.FlutterSDKを落としてパス通す
 2.flutter doctorコマンドの⾔う事聞く
  11. Dart/Flutter Don't Think. Feel.

  12. Flutter、画⾯構築 ๏ 画⾯の全てはWidget ๏ Widgetは基本的には2種類 • StatelessWidget • StatefulWidget ๏

    全てのWidgetは上記2種の継承クラス
  13. サンプルコード import 'package:flutter/material.dart'; void main() { return runApp(MyApp()); } class

    MyApp extends StatelessWidget { @override Widget build(BuildContext context) { return MaterialApp( home: Scaffold( appBar: AppBar( title: Text('Hello World App'), ), body: Center( child: Text( 'Hello World', style: TextStyle( color: Colors.green, fontSize: 90, ), ), ), ), ); } }
  14. サンプルコード(1) import 'package:flutter/material.dart'; void main() { return runApp(MyApp()); } class

    MyApp extends StatelessWidget { @override Widget build(BuildContext context) { return (লུ) } } ๏ main関数が最初に呼ばれる ๏ ‘new’は省略可能 ๏ runApp関数にWidgetのインスタンスを渡す ๏ アプリルートのWidgetに
  15. サンプルコード(2) class MyApp extends StatelessWidget { @override Widget build(BuildContext context)

    { return MaterialApp( home: Scaffold( appBar: AppBar( title: Text('Hello World App'), ), body: (লུ) ), ); } } ๏ MaterialAppWidget ๏ ScaffoldWidget ๏ AppBarWidget ๏ TextWidget
  16. サンプルコード(3) class MyApp extends StatelessWidget { @override Widget build(BuildContext context)

    { return MaterialApp( home: Scaffold( appBar: (লུ), body: Center( child: Text( 'Hello World', style: TextStyle( color: Colors.green, fontSize: 90, ), ), ), ), ); } }
  17. レイアウト(配置の調整) Center( child: Text( 'Hello World', style: TextStyle((লུ)), ), )

    Align( alignment: Alignment.bottomRight, child: Text( 'Hello World', style: TextStyle((লུ)), ), )
  18. レイアウト(縦に並べる) Center( child: Text( 'Hello World', style: TextStyle((লུ)), ), )

    Column( children: <Widget>[ Text( 'Hello World', style: TextStyle((লུ)), ), Text( 'Hello World', style: TextStyle((লུ)), ), ], ),
  19. レイアウト(横に並べる) Center( child: Text( 'Hello World', style: TextStyle((লུ)), ), )

    Row( children: <Widget>[ Text( 'Hello World', style: TextStyle((লུ)), ), Text( 'Hello World', style: TextStyle((লུ)), ), ], ),
  20. 画像を表⽰ Center( child: Image.network( 'http://jinten.net/logo.jpg', ), )

  21. ボタン Center( child: RaisedButton( child: Text( 'Ϙλϯ', style: TextStyle(fontSize: 20),

    ), onPressed: () { print('Button pressed!!'); }, ), ),
  22. ダイアログ onPressed: () { showDialog( context: context, builder: (BuildContext context)

    { return AlertDialog( title: Text('λΠτϧ'), content: Text('ຊจຊจຊจຊจ'), actions: <Widget>[ FlatButton( child: Text('Cancel'), onPressed: () {}, ), FlatButton( child: Text('OK'), onPressed: () {}, ), ], ); }, ); },
  23. ダイアログ(iOS⾵) onPressed: () { showDialog( context: context, builder: (BuildContext context)

    { return CupertinoAlertDialog( title: Text('λΠτϧ'), content: Text('ຊจຊจຊจຊจ'), actions: <Widget>[ CupertinoButton( child: Text('Cancel'), onPressed: () {}, ), CupertinoButton( child: Text('OK'), onPressed: () {}, ), ], ); }, ); },
  24. Dartパッケージの追加 ๏ https://pub.dev

  25. Dart/Flutterの 良い所・悪い所

  26. 良い! ๏ 並べる系レイアウトなら⾮常に簡単 ๏ よくあるUIパーツなら⽤意されてる • pub.dev探せばそこそこのモノは⾒つかる ๏ Googleが開発している •

    Googleサービス/プロダクトとの⾼い親和性 • firebaseとか ๏ (少なくとも今は)とても活発 ๏ AndroidとiOSのどちらにも対応できる • 将来的にはWeb, Desktop, RaspberryPi, 他 w w (PPE
  27. 悪い… ๏ ⾃由なレイアウトには対応しづらい • ゲームとか ๏ まだまだ新しい • 情報が少ない •

    知名度が低い ๏ 「AndroidとiOSをワンソースで」の暴⾛ ๏ iOS⾵のUIという罠 ๏ ネストが深くなりがち ๏ スタンダートな設計などが確⽴されていない w #BE
  28. まとめ %BSU'MVUUFS͸ɺ ࠓɺ·͞ʹա౉ظʹ͋Δͷͩʂ ৽͍͠Ϟϊ޷͖ͳΒ ৮ͬͯΈΔՁ஋ΞϦʂ