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闹钟功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-01-01
  • Android SurfaceView运行机制剖析--处理切换到后台再重新进入程序时的异常

    Android SurfaceView运行机制剖析--处理切换到后台再重新进入程序时的异常

    本文主要介绍Android SurfaceView运行机制,这里整理了详细的资料来讲解SurfaceView的运行原理,并附示例代码参考,有需要的小伙伴可以参考下
    2016-08-08
  • android播放器实现歌词显示功能

    android播放器实现歌词显示功能

    这篇文章主要为大家详细介绍了android播放器实现歌词显示功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-11-11
  • Android编程动态按钮实现方法

    Android编程动态按钮实现方法

    这篇文章主要介绍了Android编程动态按钮实现方法,分享了onTouch方法及xml调用两种实现技巧,需要的朋友可以参考下
    2016-10-10
  • android基础总结篇之一:Activity生命周期

    android基础总结篇之一:Activity生命周期

    本篇文章主要介绍了android基础总结篇之一:Activity生命周期,想要学习的可以了解一下。
    2016-11-11
  • Win10下Android App安装配置开发环境

    Win10下Android App安装配置开发环境

    这篇文章主要为大家详细介绍了Win10下Android App安装配置开发环境,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-07-07
  • Android自定义九宫格输入框

    Android自定义九宫格输入框

    这篇文章主要为大家详细介绍了Android自定义九宫格输入框,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-06-06
  • 如何解决android Toast重复显示

    如何解决android Toast重复显示

    Toast是一种简易的消息提示框,它无法获取焦点,按设置的时间来显示完以后会自动消失,一般用于帮助或提示,本文给大家介绍android Toast重复显示的解决办法,涉及到android toast 相关知识,有需要的朋友参考下
    2016-01-01
  • Android编程实现在一个程序中启动另一个程序的方法

    Android编程实现在一个程序中启动另一个程序的方法

    这篇文章主要介绍了Android编程实现在一个程序中启动另一个程序的方法,结合实例形式分析了Android通过ResolveInfo类来取得启动Acitivty类名的方法来启动另一个程序的方法,需要的朋友可以参考下
    2017-02-02
  • android RecycleView实现多级树形列表

    android RecycleView实现多级树形列表

    这篇文章主要为大家详细介绍了android RecycleView实现多级树形列表,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-05-05

最新评论