91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Flutter開發怎么實現底部留言板

發布時間:2022-03-24 14:59:49 來源:億速云 閱讀:162 作者:iii 欄目:開發技術

這篇文章主要介紹“Flutter開發怎么實現底部留言板”,在日常操作中,相信很多人在Flutter開發怎么實現底部留言板問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”Flutter開發怎么實現底部留言板”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

主要技術

其實這個技術就是運用了動畫這個功能封裝實現的

實例代碼分析

初始化封裝

 /*初始化狀態*/
  initState() {
    super.initState();

    /*創建動畫控制類對象*/
    controller = new AnimationController(
        duration: const Duration(milliseconds: 1000),
        vsync: this);

    /*創建補間對象*/
    tween = new Tween(begin: 0.0, end: 1.0)
        .animate(controller)    //返回Animation對象
      ..addListener(() {        //添加監聽
        setState(() {
          Provide.value<IndexProvide>(context).changHeight(tween.value);
         // print(tween.value);   //打印補間插值
        });
      });
    // controller.forward();       //執行動畫
  }

全部代碼

import 'package:flutter/material.dart';

void main(){

  runApp(
    MaterialApp(
      debugShowCheckedModeBanner: false,
      home: cityContent(),
    )
  );
}


class cityContent extends StatefulWidget {
  cityContent({Key key}) : super(key: key);

  _cityContentState createState() => _cityContentState();
}

class _cityContentState extends State<cityContent> with SingleTickerProviderStateMixin{

  Animation<double> tween;
  AnimationController controller;

  /*初始化狀態*/
  initState() {
    super.initState();

    /*創建動畫控制類對象*/
    controller = new AnimationController(
        duration: const Duration(milliseconds: 1000),
        vsync: this);

    /*創建補間對象*/
    tween = new Tween(begin: 0.0, end: 1.0)
        .animate(controller)    //返回Animation對象
      ..addListener(() {        //添加監聽
        setState(() {
          Provide.value<IndexProvide>(context).changHeight(tween.value);
         // print(tween.value);   //打印補間插值
        });
      });
    // controller.forward();       //執行動畫
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
        body: Stack(
        children: <Widget>[
          InkWell(
              onTap: (){
                // 動作反方向執行,即關閉留言板
                controller.reverse();
              },
            child:  ListView(
              children: <Widget>[
                Center(
                child: InkWell(
                  onTap: (){
                    controller.forward();       //執行動畫,即打開留言板
                  },
                  child: Text(
                    '打開底部抽屜'
                  ),
                )
              ),
              ],
            ),
          ),
          Positioned(
            bottom: 0,
            child: Container(
              margin: EdgeInsets.fromLTRB(20, 0, 20, 0),
              height: 400*controller.value,
              width: 300,
              color: Colors.grey.shade300,
              child: ListView(
              // physics: NeverScrollableScrollPhysics(),
              children: <Widget>[
                Container(
                  margin: EdgeInsets.only(left: 240),
                  child: InkWell(
                    onTap: (){
                      // 動作反方向執行,即關閉留言板
                      controller.reverse();
                    },
                    child: Icon(Icons.clear),
                  )
                ),
                Center(
                  child: Text('留言列表'),
                )
              ],
            ),
          )
        ),
        ],
      )
    );
  }
}

到此,關于“Flutter開發怎么實現底部留言板”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

大关县| 台北县| 怀宁县| 克东县| 随州市| 灵宝市| 海淀区| 腾冲县| 青岛市| 玛曲县| 沂南县| 安塞县| 张北县| 贵港市| 呈贡县| 济阳县| 云梦县| 奉节县| 亚东县| 治多县| 晋宁县| 瑞丽市| 阳东县| 雷波县| 水富县| 成武县| 周宁县| 巴里| 壶关县| 吉林市| 鄯善县| 从江县| 丽水市| 大邑县| 博湖县| 望江县| 水城县| 普洱| 濉溪县| 潮安县| 靖远县|