关闭

如何给非AppCompatActivity添加Toolbar?

676人阅读 评论(0) 收藏 举报

Android支持包22.1引进了AppCompatDelegate

最新22.1版本的支持包引入了大量酷炫的新特性,这些特性将允许我们轻易地将材料设计/API 21+的特性应用到之前的那些老的,不兼容的Activity上面。

我们知道,继承AppCompatActivity是最容易实现的方式,但是有时候我们还是需要使用老办法,对吗?

你可以使用支持包提供了新的AppCompatDelegate构件,很容易地将Toolbar添加到Activity上。

 

1,将Toolbar控件添加到布局文件上面

 

ActionBar现在已经被不再被告维护了,它应该被Toolbar取代,因为后者允许了更多的UI灵活性,并且允许Activity更容易地兼容于材料设计的UI模式。

因为我们要在这使用支持包,那么我们将使用Toolbar的支持版本,不然的话,将只能在API  21+上可用。

xml中添加如下内容:

1 <android.support.v7.widget.Toolbar
2     android:id="@+id/my_awesome_toolbar"
3     android:layout_height="@dimen/abc_action_bar_
4 default_height_material"
5     android:layout_width="match_parent"
6     android:minHeight="@dimen/abc_action_bar_
7 default_height_material"
8     android:background="?attr/colorPrimary"
9     />
View Code

 

2,修改主题:

 

因为我们要将Toolbar嵌入到布局文件中,所以我们需要不支持ActionBar的主题。

所以,在确定在styles.xml文件中使用主题Theme.AppCompat.NoActionBar

特别推荐,要在你的主题上添加如下所示的材料设计色彩项,这将很容易地实现对Toolbar和状态栏的着色(只有API 21+的设备上才会对状态栏进行着色):

 1 <!-- Base application theme. -->
 2 <style name="AppTheme" parent="Theme.AppCompat.NoActionBar">
 3     <!-- colorPrimary is used for coloring the Toolbar -->
 4     <item name="colorPrimary">#3F51B5</item>
 5     <!-- colorPrimaryDark is used for coloring the status bar -->
 6     <item name="colorPrimaryDark">#303F9F</item>
 7     <!-- colorAccent is used as the default value for colorControlActivated
 8          which is used to tint widgets -->
 9     <item name="colorAccent">#FFAB40</item>
10 </style>
View Code

 

3,将AppCompatDelegate添加到Activity里面

 

AppCompatDelegate是一个委托代表,它将AppCompatActivity的特性提供给Activity,而且只能通过create()方法创建,此时它需要两个参数,ActivityAppCompatCallback

所以,首先,我们将Activity实现AppCompatCallback接口,在本例中,可以不必具体实现要覆盖的方法。

 1 public class MainActivity extends Activity implements AppCompatCallback {
 2     @Override
 3     public void onSupportActionModeStarted(ActionMode mode) {
 4       //let's leave this empty, for now
 5     }
 6     @Override
 7     public void onSupportActionModeFinished(ActionMode mode) {   
 8       // let's leave this empty, for now
 9     }
10 }
View Code

然后,在ActivityonCreate()方法中,

  1. 通过AppCompatDelegate.create()方法创建AppCompatDelegate
  2. 调用AppCompatDelegate.create();(有些Activity的生命周期方法应用由该AppCompatDelegate代理)
  3. 通过AppCompatDelegate.setContentView()方法填充布局文件;
  4. 通过AppCompatDelegate.setSupportActionbar()Toolbar添加给AppCompatDelegate
 1 private AppCompatDelegate delegate;
 2 @Override
 3 protected void onCreate(Bundle savedInstanceState) {
 4     super.onCreate(savedInstanceState);
 5     //let's create the delegate, passing the activity at both arguments (Activity, AppCompatCallback)
 6     delegate = AppCompatDelegate.create(this, this);
 7     //we need to call the onCreate() of the AppCompatDelegate
 8     delegate.onCreate(savedInstanceState);
 9     //we use the delegate to inflate the layout
10     delegate.setContentView(R.layout.activity_main);
11     //Finally, let's add the Toolbar
12     Toolbar toolbar= (Toolbar) findViewById(R.id.my_awesome_toolbar);
13     delegate.setSupportActionBar(toolbar);
14 }
View Code

 

特别推荐,一个Activity只能链接到一个AppCompatDelegate实例,因此通过create()方法返回的实例应该保存在Activity里面直到该Activity被销毁。

现在,你已经完成了,运行你的应用,然后你的Activity将会魔法一般拥有一个Toolbar,而且看起来完全你是材料设计的AppCompatActivity

非常简单?

再次声明,这只是边缘事例,在使用AppCompatDelegate之前,问题要考虑使用AppCompatActivity

同时,一定要检出AppCompatDelegate的完全引用。如果你想要AppCompatDelegate活动地完全像一个AppCompatActivity,那么在你包裹AppCompatDelegateActivity时将有大量的方法需要考虑写。

原文:http://www.w2bc.com/Article/41479

0
0
查看评论
发表评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场

AppCompatActivity与toolbar的结合,封装BaseActivity

AppCompatActivity与toolbar的结合,BaseActivity简单封装 Android 5.0的时候就用Toolbar替代了ActionBar,而ActionBarActiv...
  • wk843620202
  • wk843620202
  • 2016-07-07 15:59
  • 8697

深入剖析Android四大组件(九)——Activity之AppCompatActivity与toolbar的结合

对于技术类的博客,我们永远追寻最新API脚步,在API22之前我们使用标题栏基本都是在ActionBarActivity的Activity中处理的,而API22之后,谷歌遗弃了ActionBarAct...
  • qq_23331691
  • qq_23331691
  • 2016-04-13 10:09
  • 775

深入剖析Android四大组件(九)——Activity之AppCompatActivity与toolbar的结合

本文即介绍Activity之AppCompatActivity也介绍Toolbar。但重点讲解他们结合的效果,两者缺一,其界面的效果都会减分,唯有结合使用,才能将两者的优点放大。那么具体的细节,请查看...
  • liyuanjinglyj
  • liyuanjinglyj
  • 2015-12-25 19:42
  • 14067

AppCompatActivity与toolbar结合的详细使用

深入剖析Android四大组件(九)——Activity之AppCompatActivity与toolbar的结合 对于技术类的博客,我们永远追寻最新API脚步,在API22之前我们使用标题栏基本都...
  • quyangjus
  • quyangjus
  • 2016-10-10 09:45
  • 305

实现toolbar上的搜索栏

先看一下效果图:点击搜索图标之前和点击之后                      &#...
  • qq_21700489
  • qq_21700489
  • 2015-11-22 14:55
  • 3709

在AppCompatActivity中自定义toolbar出现的问题

使用AppCompatActivity自定义toolbar的问题,布局如下: <FrameLayout xmlns:android="http://schemas.android.co...
  • tscyds
  • tscyds
  • 2017-06-04 21:10
  • 128

android5.0之往toolbar上添加按钮

第一步: 在res目录下的menu目录下,新建自己的菜单文件,如下 <menu xmlns:android="http://schemas.android.com/apk/res/android"...
  • carlos1992
  • carlos1992
  • 2016-02-21 12:08
  • 10904

QtDesigner如何添加工具栏toolBar

QtDesigner如何添加工具栏toolBar   2014-04-05 16:59:40|  分类: Qt |  标签:qt  工具栏  qaction ...
  • u012803067
  • u012803067
  • 2017-06-04 08:31
  • 615

在Fragment中如何使用Toolbar

这个Toolbar实在折磨了我好几天。。。知道看到下面这个提醒然后出去吹了吹风,终于弄出来了....其实跟提醒无关。我卡在这句上了.... toolbar.inflateMenu(R.m...
  • tiramisu_ljh
  • tiramisu_ljh
  • 2016-01-08 15:21
  • 6138

给Toolbar的menu添加图标

废话不多说。直接进入主题。。。。。 今天要实现产品设计的新界面,要使用带Toolbar控件,于是手起刀落,麻溜的一下就写好了: <android.support.v7.widg...
  • YYXXLL2
  • YYXXLL2
  • 2017-04-18 09:57
  • 1290
    个人资料
    • 访问:267526次
    • 积分:4410
    • 等级:
    • 排名:第7919名
    • 原创:168篇
    • 转载:126篇
    • 译文:0篇
    • 评论:42条
    联系方式
    zhanglihow@gmail.com
    最新评论