首頁 > 軟體

Flutter開發實現底部留言板

2022-03-23 19:01:07

本文範例為大家分享了Flutter實現底部留言板的具體程式碼,供大家參考,具體內容如下

前言

現在大家基本上都會去接觸抖音那款app,其中抖音中的留言區域的效果也是要前幾天工作的需求,看了網上對這塊並沒有什麼部落格介紹。只能自己封裝編寫了。

主要技術

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

範例程式碼分析

初始化封裝

 /*初始化狀態*/
  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('留言列表'),
                )
              ],
            ),
          )
        ),
        ],
      )
    );
  }
}

現在這個大部分的功能是現在的,不過還是差一個手勢的問題。我有一個初步的想法是結合狀態管理可以做的,不過有一個bug,就是用手勢來改變留言板的高度的時候,動畫狀態沒有初始化。希望知道的小夥伴跟我探討探討。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援it145.com。


IT145.com E-mail:sddin#qq.com