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

相关文章

python处理带有时区的日期和时间数据

《python处理带有时区的日期和时间数据》这篇文章主要为大家详细介绍了如何在Python中使用pytz库处理时区信息,包括获取当前UTC时间,转换为特定时区等,有需要的小伙伴可以参考一下... 目录时区基本信息python datetime使用timezonepandas处理时区数据知识延展时区基本信息

Android使用ImageView.ScaleType实现图片的缩放与裁剪功能

《Android使用ImageView.ScaleType实现图片的缩放与裁剪功能》ImageView是最常用的控件之一,它用于展示各种类型的图片,为了能够根据需求调整图片的显示效果,Android提... 目录什么是 ImageView.ScaleType?FIT_XYFIT_STARTFIT_CENTE

Java学习手册之Filter和Listener使用方法

《Java学习手册之Filter和Listener使用方法》:本文主要介绍Java学习手册之Filter和Listener使用方法的相关资料,Filter是一种拦截器,可以在请求到达Servl... 目录一、Filter(过滤器)1. Filter 的工作原理2. Filter 的配置与使用二、Listen

Android实现在线预览office文档的示例详解

《Android实现在线预览office文档的示例详解》在移动端展示在线Office文档(如Word、Excel、PPT)是一项常见需求,这篇文章为大家重点介绍了两种方案的实现方法,希望对大家有一定的... 目录一、项目概述二、相关技术知识三、实现思路3.1 方案一:WebView + Office Onl

Android实现两台手机屏幕共享和远程控制功能

《Android实现两台手机屏幕共享和远程控制功能》在远程协助、在线教学、技术支持等多种场景下,实时获得另一部移动设备的屏幕画面,并对其进行操作,具有极高的应用价值,本项目旨在实现两台Android手... 目录一、项目概述二、相关知识2.1 MediaProjection API2.2 Socket 网络

Android实现悬浮按钮功能

《Android实现悬浮按钮功能》在很多场景中,我们希望在应用或系统任意界面上都能看到一个小的“悬浮按钮”(FloatingButton),用来快速启动工具、展示未读信息或快捷操作,所以本文给大家介绍... 目录一、项目概述二、相关技术知识三、实现思路四、整合代码4.1 Java 代码(MainActivi

Android Mainline基础简介

《AndroidMainline基础简介》AndroidMainline是通过模块化更新Android核心组件的框架,可能提高安全性,本文给大家介绍AndroidMainline基础简介,感兴趣的朋... 目录关键要点什么是 android Mainline?Android Mainline 的工作原理关键

如何解决idea的Module:‘:app‘platform‘android-32‘not found.问题

《如何解决idea的Module:‘:app‘platform‘android-32‘notfound.问题》:本文主要介绍如何解决idea的Module:‘:app‘platform‘andr... 目录idea的Module:‘:app‘pwww.chinasem.cnlatform‘android-32

Android实现打开本地pdf文件的两种方式

《Android实现打开本地pdf文件的两种方式》在现代应用中,PDF格式因其跨平台、稳定性好、展示内容一致等特点,在Android平台上,如何高效地打开本地PDF文件,不仅关系到用户体验,也直接影响... 目录一、项目概述二、相关知识2.1 PDF文件基本概述2.2 android 文件访问与存储权限2.

Android Studio 配置国内镜像源的实现步骤

《AndroidStudio配置国内镜像源的实现步骤》本文主要介绍了AndroidStudio配置国内镜像源的实现步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,... 目录一、修改 hosts,解决 SDK 下载失败的问题二、修改 gradle 地址,解决 gradle