Android Jetpack之AppCompat(一)

今天我们来聊一聊有关AppCompat,作为Android Jetpack系列文章的开篇。说到Android Jetpack,我们先看一下这张图:

Jetpack一览


从图中我们可以看到,整个Android Jetpack分为了四大部分,而我们今天要讲述的就是Foundation中的AppCompat小节,官方将该部分翻译为“基础”。
Google官方网站:
https://developer.android.com/jetpack
按照Google官方的描述,AppCompat就是指v7 appcompat库。

“This library adds support for the Action Bar user interface design pattern. This library includes support for material design user interface implementations.”

意思是:此库添加了对操作栏用户界面设计模式的支持。这个库包括对Material Design用户界面实现的支持。也就是说,我们可以借助该库,对Material Design有更便捷和兼容性更好的实现。
进入AppCompat章节后,我们发现它又被分为了4个部分,这4个部分被称为“key class”,也就是重点类,它们分别是:

ActionBar:提供Actionbar用户界面模式的实现;

AppCompatActivity:添加可用作使用支持库操作栏实现的Activity的基类;

AppCompatDialog:添加一个可用作AppCompat主题的Dialog的基类;

ShareActionProvider:添加对可包含在ActionBar中的标准化共享操作(如电子邮件或发布到社交应用程序)的支持。

想要使用这些类,我们需要添加v7支持库。
到现在为止,支持库的最新版本是28,添加的库名称和版本如下:

com.android.support:appcompat-v7:28.0.0

今天我们就先来聊一聊ActionBar,也是这里面最为复杂的一个部分。
依稀记得,伴随着Google I/O 2014的召开,早在Android 5.0的时代,Google 官方推出了ToolBar组件,在那之后,ToolBar就登上了历史舞台,扮演着重要的角色。之前我在CSDN上面也发表过相关主题的文章,因为发布的时机刚好是ToolBar登场之际,所以获得了很多的阅读量。快5年过去了,回头再看那几篇连载,感觉文笔很是稚嫩。今天借着讲述Jetpack,再次聊聊ToolBar那些事,相信你我都会有新的收获。

首先解决疑问:

问:既然有了ActionBar,为何还要用ToolBar? 答:使用AppCompat Toolbar能兼容更广泛的设备(ActionBar要求最低Android 3.0,ToolBar要求最低Android 2.1,但只有Android 5.0及以上才能在不使用AppCompat兼容包的前提下支持Material Design),以及各式各样的自定义需求。

问:ToolBar上面都应该包含哪些内容? 答:根据Google的指导,应用栏区域应具备以下要素:1)一个专用区域,可以标识您的应用并指示用户在应用中的位置;2)以可预测的方式访问搜索等重要操作;3)支持导航和视图切换(通过标签页或下拉列表)。

一、添加ToolBar
想要添加一个ToolBar,总共3步走:
1. 更改application主题样式,操作对象:styles.xml。
对于新建的Android项目,AndroidManifest.xml中已经定义了所使用的theme,即:

android:theme="@style/AppTheme"

此时,我们修改styles.xml文件即可,将默认的继承值改掉,如下所示:

<style parent="Theme.AppCompat.Light.NoActionBar">

2. 在Activity布局中添加ToolBar,操作对象:layout布局文件

<android.support.v7.widget.Toolbar android:id="@+id/activity_main_tb" android:layout_width="match_parent" android:layout_height="?attr/actionBarSize" android:background="?attr/colorPrimary" android:elevation="4dp" android:theme="@style/ThemeOverlay.AppCompat.ActionBar" app:popupTheme="@style/ThemeOverlay.AppCompat.Light" />

对高度掌握不好火候的同学,直接如上使用ActionBar的高度就可以了。
android:evevation指“仰角”,这部分知识请参考:
https://developer.android.com/training/material/shadows-clipping
这里就不再赘述了。
如果你的项目已经迁移到Android X,你的布局文件代码片应该是:

<androidx.appcompat.widget.Toolbar android:id="@+id/activity_main_tb" android:layout_width="match_parent" android:layout_height="?attr/actionBarSize" android:background="?attr/colorPrimary" android:elevation="4dp" android:theme="@style/ThemeOverlay.AppCompat.ActionBar" app:popupTheme="@style/ThemeOverlay.AppCompat.Light" />

3. 在Activity类中找到ToolBar,并应用它,操作对象:Activity类
这一步并不复杂,参考普通的Android控件。类似地,我们通过findViewById()找到ToolBar,并做执行一些设定,即可完成该步骤,示例如下:

private Toolbar topTb; topTb = findViewById(R.id.activity_main_tb); setSupportActionBar(topTb);

一旦我们setSupportActionBar()后,日后我们就可以通过getSupportActionBar()方法来获取ToolBar实例,也可以使用兼容包提供的ActionBar的各种API方法了。
到此,我们就完成了ToolBar的添加,还算简单吧?

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/wpyyxy.html