最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • Flutter 初学者之带动画的TabBar及仿知乎APP首页实战

    正文概述 掘金(掘金宝宝_)   2020-11-24   653

    前言

    作为Flutter的初学者,不得不依靠网络的各种Flutter 资源来进行学习,今天这篇博客是狗哥看的B站马友发大佬的视频资源进行的总结与实战!

    www.bilibili.com/video/BV1jJ…

    今天实战的是打造带动画的TabBar 及其仿知乎APP 首页布局的开发,狗哥觉得,作为初学者,还是有必要找一些小项目进行实战的,帮助还是挺大的哦。老规矩,先来看效果图吧!

    效果图

    • Flutter 初学者之带动画的TabBar及仿知乎APP首页实战

    代码

    import 'package:flutter/cupertino.dart';
    import 'package:flutter/gestures.dart';
    import 'package:flutter/material.dart';
    
    void main() {
      runApp(MyApp());
    }
    
    class MyApp extends StatelessWidget {
      @override
      Widget build(BuildContext context) {
        return MyHome();
      }
    }
    
    ///Flutter 制作带动画效果的 TabBar
    class MyHome extends StatefulWidget {
      @override
      _MyHomeState createState() => _MyHomeState();
    }
    
    class _MyHomeState extends State<MyHome> with TickerProviderStateMixin {
      TabController _tabController;
    
      TextStyle smlStyle = TextStyle(fontSize: 12);
      TextStyle bigStyle = TextStyle(fontSize: 20);
    
      @override
      void initState() {
        super.initState();
        _tabController = TabController(length: 3, vsync: this, initialIndex: 1);
      }
    
      @override
      Widget build(BuildContext context) {
        return MaterialApp(
          title: "TabBar Demo",
          home: Scaffold(
            appBar: AppBar(
              bottom: TabBar(
                tabs: <Widget>[
                  Tab(
                    child: Text("页面1"),
                  ),
                  Tab(
                    child: Text("页面2"),
                  ),
                  Tab(
                    child: Text("页面3"),
                  ),
                ],
                controller: _tabController,
                //TabBar指针的宽度
                indicatorWeight: 1,
                //设置指针的内边距使其横向缩短
                indicatorPadding: EdgeInsets.symmetric(horizontal: 20),
                //选中后的style
                labelStyle: bigStyle,
                //未选中的style
                unselectedLabelStyle: smlStyle,
                //选中后的颜色
                labelColor: Colors.white,
                unselectedLabelColor: Colors.white,
              ),
              // leading: Icon(Icons.arrow_back,),
              title: Container(
                padding: EdgeInsets.only(left: 10),
                decoration: BoxDecoration(
                    color: Colors.grey[300],
                    borderRadius: BorderRadius.circular(10)),
                child: TextField(
                  decoration: InputDecoration(
                      hintText: "仿知乎APP首页书写",
                      //去掉搜索框默认的线
                      border: InputBorder.none,
                      icon: Icon(
                        Icons.search,
                        color: Colors.grey[500],
                      )),
                ),
              ),
              actions: <Widget>[
                IconButton(
                  icon: Icon(Icons.add_circle),
                  color: Colors.grey[300],
                  onPressed: () {},
                )
              ],
            ),
            //添加TabBarView
            body: TabBarView(
              children: <Widget>[
                Center(
                    child: Container(
                  child: genContentList(),
                )),
                Center(
                    child: Container(
                  child: Text(
                    "2",
                    style: TextStyle(fontSize: 40),
                  ),
                )),
                Center(
                    child: Container(
                  child: Text(
                    "3",
                    style: TextStyle(fontSize: 40),
                  ),
                ))
              ],
              controller: _tabController,
            ),
          ),
        );
      }
    }
    
    class Content {
      String title;
    
      String subTitle;
    
      String avatarUrl;
    
      String userName;
    
      String userDesc;
    
      Content() {
        this.title = "在闲鱼上买什么东西比较赚钱?";
        this.subTitle = "这个问题我会!让我来回答!这个问题我会!让我来回答!这个问题我会!让我来回答!这个问题我会!让我来回答!";
        this.avatarUrl =
            "https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1605789263727&di=41514512a2e7b0c594d6e1e4fcb45f32&imgtype=0&src=http%3A%2F%2Fww1.sinaimg.cn%2Fmw690%2F5301ff11ly1gb58jwjhikj20p00p0q4l.jpg";
        this.userName = "掘金宝宝_";
        this.userDesc = "像狗哥一样放荡不羁的潇洒生活";
      }
    }
    
    //ListView 布局
    genContentList() {
      Content content = Content();
    
      List<Content> list = List();
      List.generate(10, (index) => list.add(content));
      return ListView.builder(
        padding: EdgeInsets.only(top: 20),
        itemBuilder: (BuildContext context, int dex) {
          return Container(
            margin: EdgeInsets.only(top: 5),
            child: Column(
              children: <Widget>[
                ListTile(
                  title: Text(content.title),
                  subtitle: Container(
                      padding: EdgeInsets.only(top: 6),
                      child: Column(
                        children: <Widget>[
                          Row(
                            children: <Widget>[
                              CircleAvatar(
                                  backgroundImage: NetworkImage(content.avatarUrl)),
                              SizedBox(
                                width: 8,
                              ),
                              Text(
                                content.userName,
                                style: TextStyle(
                                    color: Colors.black87,
                                    fontWeight: FontWeight.bold,
                                    fontSize: 16),
                              ),
                              SizedBox(
                                width: 6,
                              ),
                              Text(content.userDesc),
                            ],
                          ),
                          SizedBox(height: 8),
                          Text(
                            content.subTitle,
                            style: TextStyle(height: 1.2),
                            maxLines: 2,
                            overflow: TextOverflow.ellipsis,
                          ),
                          SizedBox(height: 6),
                          Row(
                            mainAxisAlignment: MainAxisAlignment.spaceBetween,
                            children: <Widget>[
                              Text("520点赞  1314评论"),
                              Icon(Icons.more_horiz),
                            ],
                          ),
                        ],
                      )),
                ),
                Container(height: 10, color: Color(0xFFF0F5F4))
              ],
            ),
          );
        },
        itemCount: list.length,
      );
    }
    

    核心代码都已经标明注释,这里就不一一解释了。

    GitHub地址:

    github.com/SmartTwoDog…

    代码已奉上,如果有朋友发现不合适的地方或者迷惑的地方可以留言!感谢支持!


    起源地下载网 » Flutter 初学者之带动画的TabBar及仿知乎APP首页实战

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元