編輯:關於Android編程
先看圖:
[1]是ActionBar的圖標,[2]是兩個action按鈕,[3]是overflow按鈕。
介紹:
Action Bar是一種新増的導航欄功能,在Android 3.0之後加入到系統的API當中,它標識了用戶當前操作界面的位置,並提供了額外的用戶動作、界面導航等功能。使用ActionBar的好處是,它可以給提供一種全局統一的UI界面,使得用戶在使用任何一款軟件時都懂得該如何操作,並且ActionBar還可以自動適應各種不同大小的屏幕。
添加ActionBar
1、不需要導入ActionBar,因為在android3.0或者以上版本中,ActionBar已經默認的包含在Activity中
2、在Android3.0的默認主題“holographic”中,已經創造了ActionBar
3、當android:minSdkVersion 或者 android:targetSdkVersion 屬性被設置成11或者更高時,應用會被認為是Android3.0版本(默認含有ActionBar)
二、隱藏ActionBar
1、我們可以通過把主題設置為Theme.Holo.NoActionBar為一個Activity去除掉ActionBar
<activity android:theme="@android:style/Theme.Holo.NoActionBar">
2、我們也可以通過在代碼中調用show()或者hide()方法來相應的顯示或者隱藏ActionBar
3、在我們使用actionBar.hide();方法是系統默認會將ActionBar占用的空間分配給界面,此時顯示的界面將會重新繪制。
同樣調用actionBar.show();時也會重新繪制界面。如果我們一個程序需要頻繁的顯示或者隱藏ActionBar的話,這樣
就不會有良好的效果。Google提供給一個屬性可以讓ActionBar浮在界面上,當然你可以讓ActionBar的背景為透明,
這樣會有良好的體驗效果。
Demo栗子:
清單文件中設置theme
<application android:name=".view.MyApp" android:allowBackup="true" android:icon="@mipmap/ic_launcher" android:label="@string/app_name" android:supportsRtl="true" android:theme="@style/AppTheme">
style/AppTheme
<style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar"> <!-- Customize your theme here. --> <item name="colorPrimary">@color/colorPrimary</item> <item name="colorPrimaryDark">@color/colorPrimaryDark</item> <item name="colorAccent">@color/colorAccent</item> </style>
MainActivity中初始化
/** * 初始化標題 */ private void initActionbar() { ActionBar actionBar= getSupportActionBar();//獲取當前頁面的標題欄 actionBar.setTitle("Demo應用");//設置顯示標題 actionBar.setLogo(R.mipmap.ic_launcher);//設置logo標志 actionBar.setDisplayShowHomeEnabled(true);//是否顯示在主頁面上 actionBar.setDisplayUseLogoEnabled(true);//是否使用標志圖片 actionBar.setDisplayHomeAsUpEnabled(true);//返回鍵 actionBar.show();//設置後調用show顯示標題欄 }
菜單中加載布局
@Override public boolean onCreateOptionsMenu(Menu menu) { getMenuInflater().inflate(R.menu.action_bar_menu,menu); return true; }
menu.action_bar_menu
<?xml version="1.0" encoding="utf-8"?> <menu xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto"> <!--menu集合添加多個按鈕 showAsAction 顯示設置 always 爭取顯示 ifRoom根據剩余空間的大小來決定 ,大 就顯示 ,反之 不顯示 never 默認從來不顯示在集合外面 app:showAsAction="always"--> <item android:id="@+id/menu1" android:title="菜單1" android:icon="@drawable/action_download"/> <item android:id="@+id/menu2" android:title="菜單2" android:icon="@drawable/ic_feedback"/> <item android:id="@+id/menu3" android:title="菜單3" app:showAsAction="never" android:icon="@drawable/ic_exit"/> </menu>
提供處理標題元素的事件方法
/** *這是Activity提供處理標題元素的事件方法,返回true消費事件 *關鍵點:android.R.id.home 是系統分配置的返回的id */ public boolean onOptionsItemSelected(MenuItem item) { switch (item.getItemId()){ case android.R.id.home: //這個id是固定的,系統分配的 if(mDrawerLayout.isDrawerOpen(mMenuLayout)){ //如果是打開狀態,那麼點擊就關閉 mDrawerLayout.closeDrawer(mMenuLayout); }else{ //如果是關閉狀態,那麼點擊就打開 mDrawerLayout.openDrawer(mMenuLayout); } break; case R.id.menu1: Toast.makeText(this, item.getTitle(), Toast.LENGTH_SHORT).show(); break; case R.id.menu2: Toast.makeText(MyApp.getContext(), item.getTitle(), Toast.LENGTH_SHORT).show(); break; case R.id.menu3: UiUtils.showToast(item.getTitle().toString()); break; } return super.onOptionsItemSelected(item); }
/** * 設置箭頭打開動畫 */ private void initRotateArrowAnimation() { //參數1:Activity 參數2:抽屜控件 參數3,4:string ActionBarDrawerToggle toggle = new ActionBarDrawerToggle(this,mDrawerLayout,R.string.open,R.string.close); //同步狀態 作用:把返回圖標替換 2,把旋轉特效箭頭跟抽屜關聯 toggle.syncState(); //抽屜滑動的距離換成角度,使用箭頭旋轉 mDrawerLayout.addDrawerListener(toggle); }
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持本站。
我們在平時做開發的時候,免不了會用到各種各樣的對話框,相信有過其他平台開發經驗的朋友都會知道,大部分的平台都只提供了幾個最簡單的實現,如果我們想實現自己特定需求的對話框,
效果圖:以上效果類似於顯示點贊用戶的界面,我們可以通過點擊不同的昵稱進入每個人的個人主頁。 關於公共控件,請點擊文章下方的git地址。 第一步:我們為
React Native號稱能跨平台開發IOS和Android的原生應用,想來必定會成為一種趨勢。剛好計劃開發一款手機APP,又沒有相應的開發資源,決定自己摸索著試試。第
一.前言之前已經將銀聯支付功能進行了集成,暫時將退款功能擱下了,今天抽了一小段光陰把這個洞給補上了。其實有了上一次集成支付功能的經驗,對退貨退款的集成就很容易實現了。本文