笔录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打包APK的几种方式小结

《Flutter打包APK的几种方式小结》Flutter打包不同于RN,Flutter可以在AndroidStudio里编写Flutter代码并最终打包为APK,本篇主要阐述涉及到的几种打包方式,通... 目录前言1. android原生打包APK方式2. Flutter通过原生工程打包方式3. Futte

Flutter监听当前页面可见与隐藏状态的代码详解

《Flutter监听当前页面可见与隐藏状态的代码详解》文章介绍了如何在Flutter中使用路由观察者来监听应用进入前台或后台状态以及页面的显示和隐藏,并通过代码示例讲解的非常详细,需要的朋友可以参考下... flutter 可以监听 app 进入前台还是后台状态,也可以监听当http://www.cppcn

四种Flutter子页面向父组件传递数据的方法介绍

《四种Flutter子页面向父组件传递数据的方法介绍》在Flutter中,如果父组件需要调用子组件的方法,可以通过常用的四种方式实现,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录方法 1:使用 GlobalKey 和 State 调用子组件方法方法 2:通过回调函数(Callb

鸿蒙开发搭建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(),)