android仿闲鱼二级菜单,GitHub - shijia2118/flutter_bottom_navigation_bar: Flutter学习笔记--仿闲鱼底部导航栏带有中间凸起图标...

本文主要是介绍android仿闲鱼二级菜单,GitHub - shijia2118/flutter_bottom_navigation_bar: Flutter学习笔记--仿闲鱼底部导航栏带有中间凸起图标...,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

仿闲鱼底部导航栏带有中间凸起图标

刚接触Flutter,需要实现一个类似闲鱼APP的底部导航栏的实现

要实现的效果如图:

687474703a2f2f69312e6276696d672e636f6d2f3635353639322f313234666330623535356165666530612e706e67

好的,下面开始上代码了:

一. 在main.dart文件中,定义APP的入口信息

import 'package:flutter/material.dart';

import 'pages/MainPage.dart';

void main() => runApp(LightLanguageClient());

class LightLanguageClient extends StatelessWidget{

@override

Widget build(BuildContext context) {

return MaterialApp(

title: 'Demo',

theme: ThemeData(

primarySwatch: Colors.blue

),

home: MainPage(),

);

}

}

二. 我们需要定义三个页面,功能类似Android的Fragment,分别为HomePage.dart, AssistantPage.dart,MinePage.dart, 这三个页面的代码很简单:

import 'package:flutter/material.dart';

class HomePage extends StatefulWidget{

@override

State createState() {

return _HomePageState();

}

}

class _HomePageState extends State{

@override

Widget build(BuildContext context) {

return MaterialApp(

home: Scaffold(

body: Center(

child: Text('这是首页'),

),

),

);

}

}

这个三个页面的代码都一样就没有都贴出来

三.现在我们就需要去创建我们的主页了,"MainPage.dart"文件

第一步,我们先去实现一个最简单的底部导航栏

import 'package:flutter/material.dart';

import 'HomePage.dart';

import 'AssistantPage.dart';

import 'MinePage.dart';

class MainPage extends StatefulWidget {

@override

State createState() {

return _MainPage();

}

}

class _MainPage extends State with SingleTickerProviderStateMixin {

PageController pageController;

int page = 0;

@override

Widget build(BuildContext context) {

return MaterialApp(

home: Scaffold(

body: new PageView(

children: [HomePage(), AssistantPage(), MinePage()],

controller: pageController,

onPageChanged: onPageChanged,

),

bottomNavigationBar: BottomNavigationBar(

items: [

BottomNavigationBarItem(icon: Icon(Icons.home), title: Text('首页')),

BottomNavigationBarItem(icon: Icon(Icons.assessment), title: Text('助手')),

BottomNavigationBarItem(icon: Icon(Icons.person), title: Text('我的')),

],

onTap: onTap,

currentIndex: page,

),

));

}

@override

void initState() {

super.initState();

pageController = PageController(initialPage: this.page);

}

@override

void dispose() {

pageController.dispose();

super.dispose();

}

void onTap(int index) {

pageController.animateToPage(index,

duration: const Duration(milliseconds: 300), curve: Curves.ease);

}

void onPageChanged(int page) {

setState(() {

this.page = page;

});

}

}

在MainPage.dart中我们用到了几个控件:

1. PageView : 此控件类似Android的ViewPager,把之前创建的3个页面一次添加进去,之后需要给PageView设置一个控制器-PageController,给PageView设置一个onPageChanged页面切换监听方法,此方法的功能类似与Android中ViewPager中的OnPageChangeListener里的监听方法

2. BottomNavigationBar :此控件主要用于配置底部导航栏,详细用法请参见官方文档,在此控件的使用中,我们需要设置三个属性,

items: 添加底部导航栏的每个Item

onTap: 为底部导航栏设置点击事件

currentIndex: 为底部导航设置当前选中项

3. BottomNavigationBarItem: 此控件是底部导航栏的Item

至此,我们实现了最基本的底部导航栏的实现,效果图如下:

687474703a2f2f69322e6276696d672e636f6d2f3635353639322f626464316431393362363539633563302e676966

四.我们要实现仿闲鱼的底部导航栏,需要重构一下底部导航栏,

重构方案:

1.把中间的文字去掉

2.在BottomNavigationBar控件的中上的位置放入一个图片

3.重构底部导航的事件方法

4.禁止PageView的滑动事件

现在开始重构:

1.要在BottomNavigationBar上面覆盖一个图片,我们需要用到一个布局Widget---Stack,类似于Framelayout

class _MainPage extends State with SingleTickerProviderStateMixin {

PageController pageController;

int page = 0;

//添加图片地址,需要动态更换图片

String bigImg = 'images/home_green.png';

@override

Widget build(BuildContext context) {

return MaterialApp(

home: Scaffold(

body: new PageView(

children: [HomePage(), AssistantPage(), MinePage()],

controller: pageController,

onPageChanged: onPageChanged,

),

//重构bottomNavigationBar

bottomNavigationBar: Stack(

children: [

Align(

alignment: Alignment.bottomCenter,

child: BottomNavigationBar(

items: [

BottomNavigationBarItem(icon: Icon(Icons.home), title: Text('首页')),

BottomNavigationBarItem(icon: Icon(Icons.assessment), title: Text('')),

BottomNavigationBarItem(icon: Icon(Icons.person), title: Text('我的')),

],

onTap: onTap,

currentIndex: page,

),

),

Align(

alignment: Alignment.bottomCenter,

child: InkWell(

child: new Image.asset(bigImg,width: 80.0,height: 80.0,),

onTap:onBigImgTap,

),

)

],

)

));

}

@override

void initState() {

super.initState();

pageController = PageController(initialPage: this.page);

}

@override

void dispose() {

pageController.dispose();

super.dispose();

}

//修改bottomNavigationBar的点击事件

void onTap(int index) {

if (index != 1) {

setState(() {

this.bigImg = 'images/home_green.png';

});

}

pageController.animateToPage(index,

duration: const Duration(milliseconds: 300), curve: Curves.ease);

}

//添加图片的点击事件

void onBigImgTap() {

setState(() {

this.page = 1;

this.bigImg = 'images/icon_home.png';

onTap(1);

});

}

void onPageChanged(int page) {

setState(() {

this.page = page;

});

}

}

重构完成之后,效果图如下,我们发现这并不是我们想要的,底部导航栏我们是实现了,但是PageView被遮盖了

687474703a2f2f69342e6276696d672e636f6d2f3635353639322f383639643661333934653661643336632e676966

PageView被遮盖的解决办法,我们给Stack添加一个可以指定高度的父级--Container,修改的代码如下:

bottomNavigationBar: Container(

height: 100.0,

child: Stack(

children: [

Align(

alignment: Alignment.bottomCenter,

child: BottomNavigationBar(

items: [

BottomNavigationBarItem(

icon: Icon(Icons.home), title: Text('首页')),

BottomNavigationBarItem(

icon: Icon(Icons.accessibility_new), title: Text('')),

BottomNavigationBarItem(

icon: Icon(Icons.person), title: Text('我的')),

],

onTap: onTap,

currentIndex: page,

),

),

Align(

alignment: Alignment.bottomCenter,

child: Padding(

padding: const EdgeInsets.only(bottom: 10.0),

child: InkWell(

child: new Image.asset(

bigImg,

width: 80.0,

height: 80.0,

),

onTap: onBigImgTap,

),

)),

],

),

)

然后我们需要禁止PageView的滑动,我们只需要在给PageView设置一个属性就好了

physics: NeverScrollableScrollPhysics(),

在运行Flutter项目的时候出现了一个问题,运行时会出现一段时间的白屏,解决办法:

解决方案很简单,Android原生的白屏问题可以通过为 Launcher Activity 设置 windowBackground 解决,而 Flutter 也是基于此办法,同时优化了 Flutter 初始化阶段的白屏问题(覆盖一个launchView),只用两步设置便能解决 Flutter 中白屏问题。

在项目的 android/app/src/main/res/mipmap-xhdpi/ 目录下添加闪屏图片;

打开 android/app/src/main/res/drawable/launch_background.xml 文件,这个文件就是闪屏的背景文件,具体如何设置可以查阅 Android Drawable,我在 demo 中的设置如下:

android:bottom="84dp">

android:src="@mipmap/launch_image" />

如此一来,我们就完成了,文章开始提出的需求了.

刚开始接触Flutter,代码写的有些混乱,可能有些问题考虑不是很深入,有不足之处,还请各位大佬指出

推荐阅读

这篇关于android仿闲鱼二级菜单,GitHub - shijia2118/flutter_bottom_navigation_bar: Flutter学习笔记--仿闲鱼底部导航栏带有中间凸起图标...的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

苹果macOS 26 Tahoe主题功能大升级:可定制图标/高亮文本/文件夹颜色

《苹果macOS26Tahoe主题功能大升级:可定制图标/高亮文本/文件夹颜色》在整体系统设计方面,macOS26采用了全新的玻璃质感视觉风格,应用于Dock栏、应用图标以及桌面小部件等多个界面... 科技媒体 MACRumors 昨日(6 月 13 日)发布博文,报道称在 macOS 26 Tahoe 中

Go学习记录之runtime包深入解析

《Go学习记录之runtime包深入解析》Go语言runtime包管理运行时环境,涵盖goroutine调度、内存分配、垃圾回收、类型信息等核心功能,:本文主要介绍Go学习记录之runtime包的... 目录前言:一、runtime包内容学习1、作用:① Goroutine和并发控制:② 垃圾回收:③ 栈和

github打不开的问题分析及解决

《github打不开的问题分析及解决》:本文主要介绍github打不开的问题分析及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、找到github.com域名解析的ip地址二、找到github.global.ssl.fastly.net网址解析的ip地址三

Android学习总结之Java和kotlin区别超详细分析

《Android学习总结之Java和kotlin区别超详细分析》Java和Kotlin都是用于Android开发的编程语言,它们各自具有独特的特点和优势,:本文主要介绍Android学习总结之Ja... 目录一、空安全机制真题 1:Kotlin 如何解决 Java 的 NullPointerExceptio

重新对Java的类加载器的学习方式

《重新对Java的类加载器的学习方式》:本文主要介绍重新对Java的类加载器的学习方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、介绍1.1、简介1.2、符号引用和直接引用1、符号引用2、直接引用3、符号转直接的过程2、加载流程3、类加载的分类3.1、显示

Android NDK版本迭代与FFmpeg交叉编译完全指南

《AndroidNDK版本迭代与FFmpeg交叉编译完全指南》在Android开发中,使用NDK进行原生代码开发是一项常见需求,特别是当我们需要集成FFmpeg这样的多媒体处理库时,本文将深入分析A... 目录一、android NDK版本迭代分界线二、FFmpeg交叉编译关键注意事项三、完整编译脚本示例四

Android与iOS设备MAC地址生成原理及Java实现详解

《Android与iOS设备MAC地址生成原理及Java实现详解》在无线网络通信中,MAC(MediaAccessControl)地址是设备的唯一网络标识符,本文主要介绍了Android与iOS设备M... 目录引言1. MAC地址基础1.1 MAC地址的组成1.2 MAC地址的分类2. android与I

Android 实现一个隐私弹窗功能

《Android实现一个隐私弹窗功能》:本文主要介绍Android实现一个隐私弹窗功能,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 效果图如下:1. 设置同意、退出、点击用户协议、点击隐私协议的函数参数2. 《用户协议》、《隐私政策》设置成可点击的,且颜色要区分出来res/l

Android实现一键录屏功能(附源码)

《Android实现一键录屏功能(附源码)》在Android5.0及以上版本,系统提供了MediaProjectionAPI,允许应用在用户授权下录制屏幕内容并输出到视频文件,所以本文将基于此实现一个... 目录一、项目介绍二、相关技术与原理三、系统权限与用户授权四、项目架构与流程五、环境配置与依赖六、完整

Android 12解决push framework.jar无法开机的方法小结

《Android12解决pushframework.jar无法开机的方法小结》:本文主要介绍在Android12中解决pushframework.jar无法开机的方法,包括编译指令、框架层和s... 目录1. android 编译指令1.1 framework层的编译指令1.2 替换framework.ja