Android最火的框架系列(二)BottomBar

2023-10-28 22:30

本文主要是介绍Android最火的框架系列(二)BottomBar,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Android最火的框架系列(二)BottomBar

今天,来总结一下一款轻量级的底部菜单控件,叫“BottomBar”。我不花太多的篇幅去介绍它的背景,但凡能找到这篇博客的,我敢肯定你们已经通过某些途径知道了BottomBar这个框架。因此,我不多废话,我只讲一下它的一些用法。在这丢一下GitHub的地址:GitHub - roughike/BottomBar: (Deprecated) A custom view component that mimics the new Material Design Bottom Navigation pattern.。截止到我写这篇博客,BottomBar的star数是8094,很不错的一款框架。

第一  导入BottomBar框架到项目

导入BottomBar框架到项目,介绍两种方法。一种是联网环境下在线导入,一种是下载后离线配置。其实,大多数公司是给开放外网的,但也有一些公司因为保密不给开放外网(我就是这样的),因此,掌握离线配置还是很不错的。

第一种  gradle文件在线导入

这种方式很简单,只需要在app目录下的build.gradle文件中添加:

implementation 'com.roughike:bottom-bar:2.3.1'

完整的build.gradle文件如下(在这里我习惯性地删除了test相关的dependencies),:

apply plugin: 'com.android.application'android {compileSdkVersion 26defaultConfig {minSdkVersion 24targetSdkVersion 26versionCode 1versionName "1.0"}buildTypes {release {minifyEnabled falseproguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'}}
}dependencies {implementation fileTree(dir: 'libs', include: ['*.jar'])implementation 'com.android.support:appcompat-v7:26.1.0'implementation 'com.android.support.constraint:constraint-layout:1.1.3'implementation 'com.roughike:bottom-bar:2.3.1'
}

通过这种方式导入后的源代码在External Libraries目录下可以看到:

第二种  下载后以Module的形式导入

1、GitHub下载最新的项目,地址:GitHub - roughike/BottomBar: (Deprecated) A custom view component that mimics the new Material Design Bottom Navigation pattern.

2、File——>New——>Import Module:

3、选择目录下项目里的Module,我是放在F/AndroidModule目录下,选中bottom-bar,点击OK,finish:

4、修改bottom-bar这个Module的build.gradle文件,除了最上面的那一行以外(标志着这是个library),其他的可以直接把app的build.gradle文件复制过来,由于BottomBar使用到support:design,因此,我们在最后面添加一行。文件如下:

apply plugin: 'com.android.library'android {compileSdkVersion 26defaultConfig {minSdkVersion 24targetSdkVersion 26versionCode 1versionName "1.0"}buildTypes {release {minifyEnabled falseproguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'}}
}dependencies {implementation fileTree(dir: 'libs', include: ['*.jar'])implementation 'com.android.support:appcompat-v7:26.1.0'implementation 'com.android.support.constraint:constraint-layout:1.1.3'implementation 'com.android.support:design:26.1.0'
}

5、Sync Now以后,查看settings.gradle文件,如果最后面没有':bottom-bar',自己在后面添加,添加完后,Sync Now一下,搞定:

include ':app', ':bottom-bar'

第二  BottomBar框架的简单使用

1、布局xml文件:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:tools="http://schemas.android.com/tools"android:layout_width="match_parent"android:layout_height="match_parent"tools:context="blog.zhao.tudu.tudu.MainActivity"><com.roughike.bottombar.BottomBarandroid:layout_width="match_parent"android:layout_height="56dp"android:id="@+id/bottombar"android:layout_alignParentBottom="true"app:bb_behavior="shifting"app:bb_tabXmlResource="@xml/bottom_bar"></com.roughike.bottombar.BottomBar></RelativeLayout>

(1)app:bb_behavior:设置点击时的几种形式:

(2)app:bb_tabXmlResource:设置bottombar的xml资源

2、新建xml文件夹,在里面新建bottom_bar文件:

<?xml version="1.0" encoding="utf-8"?>
<tabs><tabid="@+id/tab1"barColorWhenSelected="@color/gold"icon="@drawable/ic_recents"title="@string/tab1" /><tabid="@+id/tab2"barColorWhenSelected="@color/lightsalmon"icon="@drawable/ic_favorites"title="@string/tab2" /><tabid="@+id/tab3"barColorWhenSelected="@color/hotpink"icon="@drawable/ic_nearby"title="@string/tab3" /><tabid="@+id/tab4"barColorWhenSelected="@color/lightblue"icon="@drawable/ic_friends"title="@string/tab4" /><tabid="@+id/tab5"barColorWhenSelected="@color/springgreen"icon="@drawable/ic_restaurants"title="@string/tab5" />
</tabs>

(1)barColorWhenSelected:设置点击时bottombar的背景颜色

3、MainActivity:

package blog.zhao.tudu.tudu;import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import com.roughike.bottombar.BottomBar;
import com.roughike.bottombar.OnTabSelectListener;public class MainActivity extends AppCompatActivity {private BottomBar bottomBar;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);bottomBar = findViewById(R.id.bottombar);bottomBar.setOnTabSelectListener(new OnTabSelectListener() {@Overridepublic void onTabSelected(int tabId) {switch (tabId) {case R.id.tab1:break;case R.id.tab2:break;case R.id.tab3:break;case R.id.tab4:break;case R.id.tab5:break;}}});}
}

4.string文件:

<resources><string name="app_name">Tudu</string><string name="tab1">tab1</string><string name="tab2">tab2</string><string name="tab3">tab3</string><string name="tab4">tab4</string><string name="tab5">tab5</string>
</resources>

以上就是对BottomBar基本使用的一些总结。通过上面的简单使用,我们就能实现很漂亮的底部菜单控件。注:图片资源直接使用的Github项目里的图片。

这篇关于Android最火的框架系列(二)BottomBar的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

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

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

MyBatis框架实现一个简单的数据查询操作

《MyBatis框架实现一个简单的数据查询操作》本文介绍了MyBatis框架下进行数据查询操作的详细步骤,括创建实体类、编写SQL标签、配置Mapper、开启驼峰命名映射以及执行SQL语句等,感兴趣的... 基于在前面几章我们已经学习了对MyBATis进行环境配置,并利用SqlSessionFactory核

Android WebView的加载超时处理方案

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

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

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

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

Android平台播放RTSP流的几种方案探究(VLC VS ExoPlayer VS SmartPlayer)

技术背景 好多开发者需要遴选Android平台RTSP直播播放器的时候,不知道如何选的好,本文针对常用的方案,做个大概的说明: 1. 使用VLC for Android VLC Media Player(VLC多媒体播放器),最初命名为VideoLAN客户端,是VideoLAN品牌产品,是VideoLAN计划的多媒体播放器。它支持众多音频与视频解码器及文件格式,并支持DVD影音光盘,VCD影

科研绘图系列:R语言扩展物种堆积图(Extended Stacked Barplot)

介绍 R语言的扩展物种堆积图是一种数据可视化工具,它不仅展示了物种的堆积结果,还整合了不同样本分组之间的差异性分析结果。这种图形表示方法能够直观地比较不同物种在各个分组中的显著性差异,为研究者提供了一种有效的数据解读方式。 加载R包 knitr::opts_chunk$set(warning = F, message = F)library(tidyverse)library(phyl

【生成模型系列(初级)】嵌入(Embedding)方程——自然语言处理的数学灵魂【通俗理解】

【通俗理解】嵌入(Embedding)方程——自然语言处理的数学灵魂 关键词提炼 #嵌入方程 #自然语言处理 #词向量 #机器学习 #神经网络 #向量空间模型 #Siri #Google翻译 #AlexNet 第一节:嵌入方程的类比与核心概念【尽可能通俗】 嵌入方程可以被看作是自然语言处理中的“翻译机”,它将文本中的单词或短语转换成计算机能够理解的数学形式,即向量。 正如翻译机将一种语言

cross-plateform 跨平台应用程序-03-如果只选择一个框架,应该选择哪一个?

跨平台系列 cross-plateform 跨平台应用程序-01-概览 cross-plateform 跨平台应用程序-02-有哪些主流技术栈? cross-plateform 跨平台应用程序-03-如果只选择一个框架,应该选择哪一个? cross-plateform 跨平台应用程序-04-React Native 介绍 cross-plateform 跨平台应用程序-05-Flutte

Spring框架5 - 容器的扩展功能 (ApplicationContext)

private static ApplicationContext applicationContext;static {applicationContext = new ClassPathXmlApplicationContext("bean.xml");} BeanFactory的功能扩展类ApplicationContext进行深度的分析。ApplicationConext与 BeanF