(Android 基础知识) ActionBar顶部控件
ActionBar介绍:
ActionBar是一个显示在屏幕顶部的控件,它包括了在左边显示的应用的logo图标和右边操作菜单的可见项。我们可以选择可见的操作菜单可见项,不可见项会以下拉列表的形式呈现出来。
ActionBar基础:
在Android3.0的默认主题“holographic”中,已经创造了ActionBar,所以Android最低的版本是Android3.0。(最低开发权限要求)
<uses-sdk
android:minSdkVersion="11"
android:targetSdkVersion="11" />
Activity消除ActionBar配置
<activity
android:name="com.rf.actionbardemo.MainActivity"
android:label="@string/app_name"
android:screenOrientation="landscape"
android:theme="@android:style/Theme.Holo.NoActionBar"
>
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
添加ActionBar Item--源代码
package com.rf.actionbardemo;
import android.os.Bundle;
import android.app.ActionBar;
import android.app.Activity;
import android.view.Menu;
import android.view.MenuInflater;
import android.view.MenuItem;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.Toast;
public class MainActivity extends Activity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Button showBtn=(Button) findViewById(R.id.showBt);
//ActionBar实例化
final ActionBar actionBar = getActionBar();
showBtn.setOnClickListener(new OnClickListener(){
@Override
public void onClick(View v) {
// TODO Auto-generated method stub
//显示顶部控件(ActionBar)
actionBar.show();
}
});
Button hideBtn=(Button) findViewById(R.id.hideBt);
hideBtn.setOnClickListener(new OnClickListener(){
@Override
public void onClick(View v) {
// TODO Auto-generated method stub
//隐藏顶部控件(ActionBar)
actionBar.hide();
}
});
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
//添加活动项(Action Item)----代码添加
// 每一个操作菜单的菜单项都可以成为ActionBar中的一个Action Item
super.onCreateOptionsMenu(menu);
MenuItem add = menu.add(0, 1, 0, "保存");
MenuItem open = menu.add(0, 2, 1, "打开");
MenuItem close = menu.add(0, 3, 2, "关闭");
add.setShowAsAction(MenuItem.SHOW_AS_ACTION_IF_ROOM);
open.setShowAsAction(MenuItem.SHOW_AS_ACTION_IF_ROOM);
close.setShowAsAction(MenuItem.SHOW_AS_ACTION_IF_ROOM);
return true;
//添加活动项(Action Item)----xml文件
// 当使用xml文件创建菜单(menu)时,可以标记这些菜单项作为想要实现的Action Item
// MenuInflater inflater = getMenuInflater();
// inflater.inflate(R.menu.optionsmenu, menu);
// return true;
}
//ActionBar 点击事件
@Override
public boolean onOptionsItemSelected(MenuItem item) {
// TODO Auto-generated method stub
switch(item.getItemId()){
case R.id.item1:
Toast.makeText(MainActivity.this, "ActionBar点击事件响应", Toast.LENGTH_LONG).show();
default:
return super.onOptionsItemSelected(item);
}
}
}
Action事件
ActionBar中一个菜单项(即Action item)的触发像以前版本中的活动菜单回调方法(onOptionsItemSelected())一样。
当用户选择一个Fragment的菜单项时,首先会调用Activity的onOptionsItemSelected()方法,如果该方法返回false,则调用Fragment实现的onOptionsItemSelected()方法。
应用图标
默认情况下,应用图标在ActionBar的左侧
当用户点击应用bar的时候,系统会调用你的Activity里面的onOptionsItemSelected() 方法里面的Android.R.id.Home ID(你的主ID)里定义的事件。我们可以重写这个方法,添加一个条件执行该行为:让它跳转到这个应用的主Activity而不是返回的主屏幕。
如果选择返回应用的主activity,最好的方式是在创建的Intent中添加FLAG_ACTIVITY_CLEAR_TOP这个标签。
使用这个FLAG_ACTIVITY_CLEAR_TOP标签,如果应用的主Activity已经在activity栈中存在,所有在其上的activity都会被销毁,然后主activity会到栈顶,而不用创建主Activity的的新实例。
public boolean onOptionsItemSelected(MenuItem item)
{
switch (item.getItemId())
{
case android.R.id.home:
Intent intent = new Intent(this, MainActivity.class);
intent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
startActivity(intent);
return true;
default:
return super.onOptionsItemSelected(item);
}
}
当我们想实现用户点击ActionBar 图标后返回前一个activity,可以通过在Actionbar设置setDisplayHomeAsUpEnabled(true) 来实现。
[java]
public class HomyUpActivity extends Activity {
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
}
@Override
protected void onStart() {
super.onStart();
ActionBar actionBar = this.getActionBar();
actionBar.setDisplayHomeAsUpEnabled(true);
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
MenuInflater inflater = getMenuInflater();
inflater.inflate(R.menu.optionsmenu, menu);
return true;
}
}
1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。