《Flutter攻略》之按鈕那些事1

在Flutter中界面的代碼通常是和邏輯代碼在一塊的,沒有android中的xml布局文件兼蕊,所以布局模型的難度相對大于控件模型果正,所以這里我們先來學(xué)習(xí)一下比較簡單的按鈕。

《Flutter攻略》之環(huán)境搭建中介紹了如何使用IntelliJ 插件的插件來新建Flutter工程并運(yùn)行忆谓。

我們新建一個(gè)工程后裆装,插件已經(jīng)給我們寫了一個(gè)簡單的app運(yùn)行如下:

點(diǎn)擊右下方按鈕后,中間的0會一直被+1,但這里我們先不管這是怎么實(shí)現(xiàn)的哨免,我們今天要學(xué)習(xí)的是按鈕茎活。

在Flutter的官網(wǎng)的Widgets Overview中,我們可以看到有以下三個(gè)按鈕:

  • Floating action buttton
  • Raised button
  • Flat button

其中第一個(gè)Floating action button就是上圖中右下角有個(gè)加號的按鈕琢唾。它的形狀默認(rèn)是圓形载荔。切他有固定的用法如下:

floatingActionButton: new FloatingActionButton(
        onPressed: _incrementCounter,
        tooltip: 'Increment',
        child: new Icon(Icons.add),
 )

我們先看??的構(gòu)造方法,其中onPressed是按鈕點(diǎn)擊事件采桃,類型為:

/// Signature of callbacks that have no arguments and return no data.
typedef void VoidCallback();

就是一個(gè)沒有參數(shù)切沒有返回值的方法身辨。具體參考dart語法。

tooltip一個(gè)提示字符串芍碧,在長按按鈕時(shí)彈出:

參數(shù)child的類型是Widget,是一個(gè)需要被顯示在FloatingActionButton中間的一個(gè)控件煌珊,這里使用的是Icon,那既然類型是Widget泌豆,那我們試試除了Icon定庵,是不是其他的也行,這里用Text來試試踪危。

 floatingActionButton: new FloatingActionButton(
        onPressed: _incrementCounter,
        tooltip: 'Increment',
        child: new Text('Hello'),
  ),

??可行蔬浙。

下面來說說第二個(gè)按鈕Raised button,官方的解釋是:

A typically rectangular material button that lifts and displays ink reactions on press. The RaisedButton widget implements this component.

其實(shí)就是一個(gè)有抬起效果和按壓有墨水效果的按鈕,我們看下具體是什么樣子的:

代碼如下:

 body: new Center(
        child: new RaisedButton(onPressed: (){},
           color: Colors.blue[400],
           child: new Text('RaisedButton',style: new TextStyle(color: Colors.white))),
  ),

而第三種Flat button沒有RaisedButton的抬起效果贞远,其他一致畴博。

總結(jié)

這里只是介紹了三種按鈕以及簡單寫法,沒有深究其點(diǎn)擊事件和布局等功能的用法蓝仲。

整個(gè)文件內(nèi)容如下:

import 'package:flutter/material.dart';
import 'dart:isolate';
import 'dart:async';
void main() {
  runApp(new MyApp());
}

class MyApp extends StatelessWidget {
  // This widget is the root of your application.
  @override
  Widget build(BuildContext context) {
    return new MaterialApp(
      title: 'Flutter Demo',
      theme: new ThemeData(
        // This is the theme of your application.
        //
        // Try running your application with "flutter run". You'll see
        // the application has a blue toolbar. Then, without quitting
        // the app, try changing the primarySwatch below to Colors.green
        // and press "r" in the console where you ran "flutter run".
        // We call this a "hot reload". Notice that the counter didn't
        // reset back to zero -- the application is not restarted.
        primarySwatch: Colors.blue,
      ),
      home: new MyHomePage(title: 'Flutter Demo Home Page'),
    );
  }
}

class MyHomePage extends StatefulWidget {
  MyHomePage({Key key, this.title}) : super(key: key);

  // This widget is the home page of your application. It is stateful,
  // meaning that it has a State object (defined below) that contains
  // fields that affect how it looks.

  // This class is the configuration for the state. It holds the
  // values (in this case the title) provided by the parent (in this
  // case the App widget) and used by the build method of the State.
  // Fields in a Widget subclass are always marked "final".

  final String title;

  @override
  _MyHomePageState createState() => new _MyHomePageState();
}

class _MyHomePageState extends State<MyHomePage> {
  int _counter = 0;
  ReceivePort receivePort = new ReceivePort();
  void _incrementCounter() {
    setState(() {
      // This call to setState tells the Flutter framework that
      // something has changed in this State, which causes it to rerun
      // the build method below so that the display can reflect the
      // updated values. If we changed _counter without calling
      // setState(), then the build method would not be called again,
      // and so nothing would appear to happen.
      _counter++;
    });
  }

  @override
  Widget build(BuildContext context) {
    // This method is rerun every time setState is called, for instance
    // as done by the _incrementCounter method above.
    // The Flutter framework has been optimized to make rerunning
    // build methods fast, so that you can just rebuild anything that
    // needs updating rather than having to individually change
    // instances of widgets.
    return new Scaffold(
      appBar: new AppBar(
        // Here we take the value from the MyHomePage object that
        // was created by the App.build method, and use it to set
        // our appbar title.
        title: new Text(config.title),
      ),
      body: new Center(
        child: new RaisedButton(onPressed: (){},
           color: Colors.blue[400],
           child: new Text('RaisedButton',style: new TextStyle(color: Colors.white))),
      ),
      floatingActionButton: new FloatingActionButton(
        onPressed: _incrementCounter,
        tooltip: 'Increment',
        child: new Text('Hello'),
      ), // This trailing comma tells the Dart formatter to use
      // a style that looks nicer for build methods.
    );
  }

  @override
  void initState() {
    receivePort.listen((data){
      print("from main : $data");
    });
    Isolate.spawn(foo,receivePort.sendPort);
  }


}

foo(message){
 foo1(1,message);
}

foo1(var i,var sendPort){
  Future f = new Future.delayed(new Duration(seconds: 2),(){
    i++;
    print("${i}");
    Isolate.current.ping(sendPort,response: "i = ${i}");
    foo1(i,sendPort);
  });
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末俱病,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子袱结,更是在濱河造成了極大的恐慌亮隙,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,185評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件垢夹,死亡現(xiàn)場離奇詭異溢吻,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)果元,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,652評論 3 393
  • 文/潘曉璐 我一進(jìn)店門促王,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人而晒,你說我怎么就攤上這事蝇狼。” “怎么了欣硼?”我有些...
    開封第一講書人閱讀 163,524評論 0 353
  • 文/不壞的土叔 我叫張陵题翰,是天一觀的道長恶阴。 經(jīng)常有香客問我,道長豹障,這世上最難降的妖魔是什么冯事? 我笑而不...
    開封第一講書人閱讀 58,339評論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮血公,結(jié)果婚禮上昵仅,老公的妹妹穿的比我還像新娘。我一直安慰自己累魔,他們只是感情好摔笤,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,387評論 6 391
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著垦写,像睡著了一般吕世。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上梯投,一...
    開封第一講書人閱讀 51,287評論 1 301
  • 那天命辖,我揣著相機(jī)與錄音,去河邊找鬼分蓖。 笑死尔艇,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的么鹤。 我是一名探鬼主播终娃,決...
    沈念sama閱讀 40,130評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼蒸甜!你這毒婦竟也來了棠耕?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,985評論 0 275
  • 序言:老撾萬榮一對情侶失蹤迅皇,失蹤者是張志新(化名)和其女友劉穎昧辽,沒想到半個(gè)月后衙熔,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體登颓,經(jīng)...
    沈念sama閱讀 45,420評論 1 313
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,617評論 3 334
  • 正文 我和宋清朗相戀三年红氯,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了框咙。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,779評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡痢甘,死狀恐怖喇嘱,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情塞栅,我是刑警寧澤者铜,帶...
    沈念sama閱讀 35,477評論 5 345
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響作烟,放射性物質(zhì)發(fā)生泄漏愉粤。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,088評論 3 328
  • 文/蒙蒙 一拿撩、第九天 我趴在偏房一處隱蔽的房頂上張望衣厘。 院中可真熱鬧,春花似錦压恒、人聲如沸影暴。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,716評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽课梳。三九已至,卻和暖如春员咽,著一層夾襖步出監(jiān)牢的瞬間焰檩,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,857評論 1 269
  • 我被黑心中介騙來泰國打工讨勤, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留箭跳,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,876評論 2 370
  • 正文 我出身青樓潭千,卻偏偏與公主長得像谱姓,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子刨晴,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,700評論 2 354

推薦閱讀更多精彩內(nèi)容