Toolbar的使用
来源:互联网 发布:企业网络信息安全培训 编辑:程序博客网 时间:2024/05/21 10:03
一. 概述
从2013年开始谷歌倡导所谓的Android Style,由此出现了Android 3.0 以后的新控件ActionBar.
但是ActionBar在使用时有一堆问题,文字不能定制,位置不能改变,图标距离无法控制,暴露出了ActionBar设计的不灵活,无法满足开发者的需要.
于是推出了ActionBar升级版:Toolbar,以便满足开发者个性化定制状态的需求,并且提供了support library 向下兼容包
特点:Toolbar之所以使用灵活,是因为它其实就是一个ViewGroup,可以往里面放控件,
使用Toolbar:和使用普通的组件一样,在布局文件中声明即可。
- 设置导航栏图标;
- 设置App的logo;
- 支持设置标题和子标题;
- 支持添加一个或多个的自定义控件;
- 支持Action Menu;
这里选用第二种方法
清单文件代码如下
<?xml version="1.0"encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.dubuwucool.eventbusdemo">
<application
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:supportsRtl="true"
android:theme="@style/AppTheme">
<activity android:name=".activity.MainActivity">
<intent-filter>
<action android:name="android.intent.action.MAIN"/>
<category android:name="android.intent.category.LAUNCHER"/>
</intent-filter>
</activity>
<activity android:name=".activity.EventBusSendActivity">
</activity>
</application>
</manifest>
res/values/style.xml文件代码如下
<resources>
<!-- Base application theme. -->
<stylename="AppTheme"parent="Theme.AppCompat.NoActionBar">
<!-- Customize your theme here. -->
<itemname="colorPrimary">@color/colorPrimary</item>
<item name="colorPrimaryDark">@color/colorPrimaryDark</item>
<item name="colorAccent">@color/colorAccent</item>
</style>
</resources>
<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="com.zhiyuan3g.toolsbardemo.MainActivity">
<!--
Toolbar 是在 Android 5.0 才开始加上的,Google为了向下兼容,推出了兼容版包。为此,我们需要在工程中引入 appcompat-v7 的兼容包,使用android.support.v7.widget.Toolbar 进行开发。
这里设置Toolbar的背景颜色,Toolbar可以当容器来使用-->
<android.support.v7.widget.Toolbar android:id="@+id/toolsBar" android:layout_width="match_parent" android:layout_height="wrap_content" android:background="#ff0202"> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="666" android:textSize="15sp"/> </android.support.v7.widget.Toolbar></RelativeLayout>
toolbar.setTitle("666");//设置主标题(注意使用他,要放在setSupportActionBar方法前)
toolbar.setSubtitle("999");//设置子标题,子标题会出现在主标题正下方
创建完成后如图所示:
<?xml version="1.0"encoding="utf-8"?>
<menuxmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res - auto"> <!--该行必须加-->
<item
android:id="@+id/action_search"
android:icon="@mipmap/ic_launcher"
android:title="item0"
app:showAsAction="always"
></item>
<item
android:id="@+id/action_search1"
android:icon="@mipmap/ic_launcher"
android:title="item1"
app:showAsAction="always"
></item>
<item
android:id="@+id/action_search2"
android:icon="@mipmap/ic_launcher"
android:title="item2"
app:showAsAction="always"
></item>
</menu>
//toolbar点击事件
toolsBar.setOnMenuItemClickListener(new Toolbar.OnMenuItemClickListener() {
@Override
public boolean onMenuItemClick(MenuItem item) {
Toast.makeText(MainActivity.this,"您也点击了菜单", Toast.LENGTH_SHORT).show();
return true;}
});
}
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.toolbar_menu,menu);
return true;
}
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.support.v7.widget.Toolbar;
import android.view.Menu;
import android.view.MenuItem;
public class MainActivity extends AppCompatActivity {
private Toolbar toolsBar;
/**
* 使用ToolsBar基本步骤
* 1.隐藏原本的ActionBar,可以通过清单文件修改我们的基础主题
* 可以改变某个activity的主题 android:theme="@style/Theme.AppCompat.NoActionBar"
* 也可以改变某个应用主题
* 2.在布局中声明Toolbar
* 3.代码中初始化Toolbar
* 4.对Toolbar做个性化设置
* 5.设置Toolbar的菜单点击事件,在Res文件下创建Menu文件
* 6.重写onCreateOptionsMenu方法
*
* @param savedInstanceState
*/
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
//初始化控件
initView();
//设置主标题,必须要在 setSupportActionBa代码执行循序的前面
toolsBar.setTitle("主标题");
//必须有的一步操作,参数为Toolbar对象
setSupportActionBar(toolsBar);
//设置导航栏图标
toolsBar.setNavigationIcon(R.mipmap.ic_launcher);
//设置app的logo
toolsBar.setLogo(R.mipmap.ic_launcher);
//设置子标题
toolsBar.setSubtitle("子标题");
//往Toolbar填充菜单布局
toolsBar.inflateMenu(R.menu.toolbar_menu);
//toolbar点击事件
toolsBar.setOnMenuItemClickListener(new Toolbar.OnMenuItemClickListener() {
@Override
public boolean onMenuItemClick(MenuItem item) {
Toast.makeText(MainActivity.this,"您也点击了菜单", Toast.LENGTH_SHORT).show();
return true;}
});
}
//使用getMenuinflater()填充menu布局,第二个参数固定式menu,返回值为true才有效果
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.toolbar_menu,menu);
return true;
}
private void initView() {
toolsBar = (Toolbar) findViewById(R.id.toolsBar);
}
- ToolBar控件的使用
- Toolbar的高级使用
- Android --Toolbar的使用
- ToolBar的使用
- android toolbar的使用
- ToolBar的使用
- toolbar的使用
- ToolBar的基本使用
- ToolBar的使用
- toolbar的使用
- ToolBar的简单使用
- ToolBar的使用
- Toolbar的使用.md
- ToolBar的使用
- Toolbar的使用总结
- ToolBar的基本使用
- Toolbar的使用详解
- ToolBar的使用
- 学习maven的博客
- C语言——字符串翻转
- 快逸报表为报表添加无数据的日期(二)
- Swift3.0 Date日期的使用
- 局域网媒体共享、点播工具
- Toolbar的使用
- SpringMVC注解开发基础2---传参
- 将DataTable一行放入另一个DataTable中
- ubuntu 中怎么截图
- iOS 解决.a 静态库冲突问题
- 03课后5
- 002.hello world
- log4j2使用及配置讲解
- Linux 文件编码大挪移