Flutter质感设计之持久底部面板

 更新时间:2018年08月23日 10:00:05   作者:何小有  
这篇文章主要为大家详细介绍了Flutter质感设计之持久底部面板,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

持久性底部面板可以用于补充应用主要内容的信息,即使用户与应用程序的其他控件进行互动,也仍然可以看到持久的底部面板。可以使用Scaffold.showBottomSheet函数创建和显示持久性底部面板。

import 'package:flutter/material.dart';

class MyApp extends StatefulWidget {
 @override
 _MyApp createState() => new _MyApp();
}
class _MyApp extends State<MyApp> {
 /**
 *GlobalKey:整个应用程序中唯一的键
 ScaffoldState:Scaffold框架的状态
 解释:_scaffoldKey的值是Scaffold框架状态的唯一键
 */
 final GlobalKey<ScaffoldState> _scaffoldKey = new GlobalKey<ScaffoldState>();

 // VoidCallback:没有参数并且不返回数据的回调
 VoidCallback _showBottomSheetCallback;

 @override
 void initState() {
 super.initState();
 _showBottomSheetCallback = _showBottomSheet;
 }

 void _showBottomSheet() {
 setState(() {
  // 禁用按钮
  _showBottomSheetCallback = null;
 });
 /**
  *currentState:获取具有此全局键的树中的控件状态
  showBottomSheet:显示持久性的质感设计底部面板
  解释:联系上文,_scaffoldKey是Scaffold框架状态的唯一键,因此代码大意为,
   在Scaffold框架中显示持久性的质感设计底部面板
  */
 _scaffoldKey.currentState.showBottomSheet<Null>((BuildContext context){
  final ThemeData themeData = Theme.of(context);
  return new Container(
  decoration: new BoxDecoration(
   border: new Border(top: new BorderSide(color: themeData.disabledColor))
  ),
  child: new Padding(
   padding: const EdgeInsets.all(32.0),
   child: new Text(
   '这是一个持久性的底部面板,向下拖动即可将其关闭',
   textAlign: TextAlign.center,
   style: new TextStyle(
    color: themeData.accentColor,
    fontSize: 24.0
   )
   )
  )
  );
 })
 /**
  *closed:当此对象控制的元素不再可见时完成
  whenComplete:注册将在此未来完成时调用的函数
  解释:联系上文,closed控制的元素是新构建的质感设计底部面板,因此代码大意为,
   注册底部面板不再可见时调用的函数
  */
 .closed.whenComplete((){
  // mounted:bool值,这个State对象当前是否在树中
  if (mounted) {
  setState(() {
   // 重新启用按钮
   _showBottomSheetCallback = _showBottomSheet;
  });
  }
 });
 }

 void _showMessage() {
 // showDialog<T>:显示应用程序当前内容上方的对话框
 showDialog<Null>(
  context: context,
  // AlertDialog:质感设计中的告警对话框
  child: new AlertDialog(
  // content:对话框的可选内容,以浅色字体显示在对话框的中心
  content: new Text('你点击了浮动按钮'),
  // actions:显示在对话框底部的可选操作
  actions: <Widget>[
   // FlatButton:质感设计中的平面按钮
   new FlatButton(
   onPressed: () { Navigator.pop(context); },
   child: new Text('确定')
   )
  ]
  ),
 );
 }
 @override
 Widget build(BuildContext context) {
 return new Scaffold(
  key: _scaffoldKey,
  appBar: new AppBar(
  title: new Text('底部面板')
  ),
  floatingActionButton: new FloatingActionButton(
  onPressed: _showMessage,
  backgroundColor: Colors.redAccent[200],
  child: new Icon(Icons.add)
  ),
  body: new Center(
  child: new RaisedButton(
   onPressed: _showBottomSheetCallback,
   child: new Text('显示底部面板')
  )
  )
 );
 }
}

void main() {
 runApp(new MaterialApp(
 title: 'Flutter Demo',
 home: new MyApp()
 ));
}

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

相关文章

  • Android背景图下拉回弹效果实例

    Android背景图下拉回弹效果实例

    大家好,本篇文章主要讲的是Android背景图下拉回弹效果实例,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下
    2022-01-01
  • 智能指针与弱引用详解

    智能指针与弱引用详解

    智能指针有很多实现方式,android 中的sp 句柄类实际上就是google 实现的一种强引用的智能指针。我没有仔细看android sp 的实现方式,但其基本原理是固定的,现在我们从一个相对简单的例子来看智能指针的实现
    2013-09-09
  • 直接拿来用的Android刮奖控件

    直接拿来用的Android刮奖控件

    这篇文章主要为大家分享了可以直接拿来用的Android刮奖控件,非常棒的刮奖控件,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-09-09
  • Android自定义水波纹底部导航的实现

    Android自定义水波纹底部导航的实现

    TabLayout作为导航组件来说,使用场景非常的多,也意味着要满足各种各样的需求,这篇文章主要介绍了Android自定义水波纹底部导航的实现
    2022-08-08
  • android自定义滚轴选择器

    android自定义滚轴选择器

    这篇文章主要为大家详细介绍了android自定义滚轴选择器,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-07-07
  • Android Compose实现伸缩ToolBar的思路详解

    Android Compose实现伸缩ToolBar的思路详解

    这篇文章主要介绍了Android Compose之伸缩ToolBar的实现,本文给大家分享主要实现思路及实现过程,通过实例代码给大家介绍的非常详细,需要的朋友可以参考下
    2021-10-10
  • android监听器实例代码

    android监听器实例代码

    在本篇中小编给大家整理了一篇关于android监听器的相关知识点文章,需要的朋友们可以学习下。
    2019-10-10
  • Android编程之Sdcard相关代码集锦

    Android编程之Sdcard相关代码集锦

    这篇文章主要介绍了Android编程之Sdcard相关代码集锦,包括Android针对sd卡的存取、检测、相关信息获取等操作技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-11-11
  • unity5.6 导出gradle工程 Android Studio 导入问题及处理方法

    unity5.6 导出gradle工程 Android Studio 导入问题及处理方法

    这篇文章主要介绍了unity5.6 导出gradle工程 Android Studio 导入问题及处理方法,需要的朋友可以参考下
    2017-12-12
  • Android App设计规范深入讲解

    Android App设计规范深入讲解

    随着安卓智能手机不停的更新换代,安卓手机系统越来越完美,屏幕尺寸也越来越大啦,下面这篇文章主要给大家介绍了关于Android App设计规范的相关资料,需要的朋友可以参考下
    2022-10-10

最新评论