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

相关文章

Spring框架中@Lazy延迟加载原理和使用详解

《Spring框架中@Lazy延迟加载原理和使用详解》:本文主要介绍Spring框架中@Lazy延迟加载原理和使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、@Lazy延迟加载原理1.延迟加载原理1.1 @Lazy三种配置方法1.2 @Component

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

Android开发环境配置避坑指南

《Android开发环境配置避坑指南》本文主要介绍了Android开发环境配置过程中遇到的问题及解决方案,包括VPN注意事项、工具版本统一、Gerrit邮箱配置、Git拉取和提交代码、MergevsR... 目录网络环境:VPN 注意事项工具版本统一:android Studio & JDKGerrit的邮

Android实现定时任务的几种方式汇总(附源码)

《Android实现定时任务的几种方式汇总(附源码)》在Android应用中,定时任务(ScheduledTask)的需求几乎无处不在:从定时刷新数据、定时备份、定时推送通知,到夜间静默下载、循环执行... 目录一、项目介绍1. 背景与意义二、相关基础知识与系统约束三、方案一:Handler.postDel

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

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

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