文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Flutter开发实现底部留言板

2024-04-02 19:55

关注

本文实例为大家分享了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,就是用手势来改变留言板的高度的时候,动画状态没有初始化。希望知道的小伙伴跟我探讨探讨。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程网。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-移动开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯