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

相关文章

Android数据库Room的实际使用过程总结

《Android数据库Room的实际使用过程总结》这篇文章主要给大家介绍了关于Android数据库Room的实际使用过程,详细介绍了如何创建实体类、数据访问对象(DAO)和数据库抽象类,需要的朋友可以... 目录前言一、Room的基本使用1.项目配置2.创建实体类(Entity)3.创建数据访问对象(DAO

Android WebView的加载超时处理方案

《AndroidWebView的加载超时处理方案》在Android开发中,WebView是一个常用的组件,用于在应用中嵌入网页,然而,当网络状况不佳或页面加载过慢时,用户可能会遇到加载超时的问题,本... 目录引言一、WebView加载超时的原因二、加载超时处理方案1. 使用Handler和Timer进行超

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

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

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

学习hash总结

2014/1/29/   最近刚开始学hash,名字很陌生,但是hash的思想却很熟悉,以前早就做过此类的题,但是不知道这就是hash思想而已,说白了hash就是一个映射,往往灵活利用数组的下标来实现算法,hash的作用:1、判重;2、统计次数;

禁止平板,iPad长按弹出默认菜单事件

通过监控按下抬起时间差来禁止弹出事件,把以下代码写在要禁止的页面的页面加载事件里面即可     var date;document.addEventListener('touchstart', event => {date = new Date().getTime();});document.addEventListener('touchend', event => {if (new

如何在页面调用utility bar并传递参数至lwc组件

1.在app的utility item中添加lwc组件: 2.调用utility bar api的方式有两种: 方法一,通过lwc调用: import {LightningElement,api ,wire } from 'lwc';import { publish, MessageContext } from 'lightning/messageService';import Ca

Android实现任意版本设置默认的锁屏壁纸和桌面壁纸(两张壁纸可不一致)

客户有些需求需要设置默认壁纸和锁屏壁纸  在默认情况下 这两个壁纸是相同的  如果需要默认的锁屏壁纸和桌面壁纸不一样 需要额外修改 Android13实现 替换默认桌面壁纸: 将图片文件替换frameworks/base/core/res/res/drawable-nodpi/default_wallpaper.*  (注意不能是bmp格式) 替换默认锁屏壁纸: 将图片资源放入vendo