笔录Flutter(十) 侧边栏(Drawer)、UserAccountsDrawerHeader

2023-10-24 19:10

本文主要是介绍笔录Flutter(十) 侧边栏(Drawer)、UserAccountsDrawerHeader,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Flutter练习Demo

Drawer、UserAccountsDrawerHeader常用属性

  1. Drawer
 const Drawer({Key key,this.elevation = 16.0,this.child,this.semanticLabel,}) : assert(elevation != null && elevation >= 0.0),super(key: key);
  1. UserAccountsDrawerHeader
const UserAccountsDrawerHeader({Key key,this.decoration,this.margin = const EdgeInsets.only(bottom: 8.0),this.currentAccountPicture,// 当前账户头像this.otherAccountsPictures,//  其他账户头像@required this.accountName,// 账户名字@required this.accountEmail,// 账户邮箱this.onDetailsPressed,}) : super(key: key)

使用

效果图:
在这里插入图片描述
功能:

  1. 只在Home页面有侧边栏
  2. 自定义leading图片展示,实现点击展开侧边栏
  3. UserAccountsDrawerHeader的使用
  4. 点击侧边栏item跳转页面
功能一 Home页面有侧边栏

配置侧边栏:

 drawer: LeftDrawerPage()),// 编写一个侧边栏页面
功能二 leading点击打开侧边栏

在这里插入图片描述

功能三 UserAccountsDrawerHeader的使用
 UserAccountsDrawerHeader(//其他账户头像  会显示右上角
//            otherAccountsPictures: <Widget>[
//              ClipOval(
//                child: Image.asset(
//                  "images/x.jpg",
//                  width: 50,
//                  height: 50,
//                  fit: BoxFit.cover,
//                ),
//              ),
//              ClipOval(
//                child: Image.asset(
//                  "images/s.jpg",
//                  width: 50,
//                  height: 50,
//                  fit: BoxFit.cover,
//                ),
//              ),
//            ],currentAccountPicture: Center(//当前账户头像//要想控制头像的大小需要用Center包裹child: ClipOval(child: Image.asset("images/z.jpg",width: 70,height: 70,fit: BoxFit.cover,),),),accountName: Text("Six某人"),accountEmail: Text("1828088521@qq.com"),decoration: BoxDecoration(image: DecorationImage(//设置UserAccountsDrawerHeader背景图image: AssetImage("images/hy.jpg"), fit: BoxFit.cover),),),
功能四 点击侧边栏item跳转页面
//点击跳转前先关闭侧边栏onTap: () {// 跳转之前先把侧边栏关闭掉Navigator.of(context).pop();Navigator.pushNamed(context, "/routeDrawerItemPage");},

这篇关于笔录Flutter(十) 侧边栏(Drawer)、UserAccountsDrawerHeader的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/277177

相关文章

鸿蒙开发搭建flutter适配的开发环境

《鸿蒙开发搭建flutter适配的开发环境》文章详细介绍了在Windows系统上如何创建和运行鸿蒙Flutter项目,包括使用flutterdoctor检测环境、创建项目、编译HAP包以及在真机上运... 目录环境搭建创建运行项目打包项目总结环境搭建1.安装 DevEco Studio NEXT IDE

Flutter 进阶:绘制加载动画

绘制加载动画:由小圆组成的大圆 1. 定义 LoadingScreen 类2. 实现 _LoadingScreenState 类3. 定义 LoadingPainter 类4. 总结 实现加载动画 我们需要定义两个类:LoadingScreen 和 LoadingPainter。LoadingScreen 负责控制动画的状态,而 LoadingPainter 则负责绘制动画。

Flutter Button使用

Material 组件库中有多种按钮组件如ElevatedButton、TextButton、OutlineButton等,它们的父类是于ButtonStyleButton。         基本的按钮特点:         1.按下时都会有“水波文动画”。         2.onPressed属性设置点击回调,如果不提供该回调则按钮会处于禁用状态,禁用状态不响应用户点击。

flutter开发实战-flutter build web微信无法识别二维码及小程序码问题

flutter开发实战-flutter build web微信无法识别二维码及小程序码问题 GitHub Pages是一个直接从GitHub存储库托管的静态站点服务,‌它允许用户通过简单的配置,‌将个人的代码项目转化为一个可以在线访问的网站。‌这里使用flutter build web来构建web发布到GitHub Pages。 最近通过flutter build web,通过发布到GitHu

Flutter 中的低功耗蓝牙概述

随着智能设备数量的增加,控制这些设备的需求也在增加。对于多种使用情况,期望设备在需要进行控制的同时连接到互联网会受到很大限制,因此是不可行的。在这些情况下,使用低功耗蓝牙(也称为 Bluetooth LE 或 BLE)似乎是最佳选择,因为它功耗低,在我们的手机中无处不在,而且无需连接到更广泛的网络。因此,蓝牙应用程序的需求也在不断增长。 通过阅读本文,您将了解如何开始在 Flutter 中开

flutter开发多端平台应用的探索 下 (跨模块、跨语言通信之平台通道)

前文 Flutter 是一个跨平台的开发框架,它允许开发者使用相同的代码库来构建 iOS、Android、Web 和桌面应用程序。 上文flutter开发多端平台应用的探索 上(基本操作)-CSDN博客列举了一些特定平台的case(桌面端菜单,鼠标快捷键)的使用方法,有些是flutter提供了对应能力,只需要学习如何调API,有些事三方库支持,本文要探讨的平台通道是更为强大的工具,很多三方插件

Flutter-使用dio插件请求网络(get ,post,下载文件)

引入库:dio: ^2.1.13可直接运行的代码:包含了post,get 下载文件import 'package:flutter/material.dart';import 'package:dio/dio.dart';void main() {runApp(new MaterialApp(title: 'Container demo',home: new visitNetPage(),)

Flutter-选择附件,图片,视频。file_picker

仅供参考: 引入插件: file_picker: ^1.3.8 按照返回值,分了三组: // Single file path String filePath;第一组:返回文件地址 //选择任何文件 filePath = await FilePicker.getFilePath(type: FileType.ANY); // will let you pick one file path, fr

Flutter-图表显示charts_flutter

引入插件: charts_flutter: ^0.4.0 ChartFlutterBean import 'package:charts_flutter/flutter.dart';import 'package:myself_project/OrdinalSales%20.dart';class ChartFlutterBean {static List<Series<TimeSer