編輯:關於Android編程
設置 android:noHistory=true後,該Activity在statck中不留歷史痕跡。默認的值是false。
舉例說明,假設有三個Activity分別是:A,B,C。這三個Activity可以依次順序啟動下一個Activity,比如,在A中做一個Button,用戶點擊後跳轉到B ; 同樣,在B中也做一個Button,點擊跳轉到C。C不再做Button,只是一個用以演示的空殼Activity。
在AndroidManifest.xml中配置B的屬性為:android:noHistory=true
其他兩個不做特別設置,僅僅作為一般的Activity處理。
可以觀察到,A啟動後,從A跳轉到B,再從B跳轉到C,進入C後,此時如果按返回鍵,將直接進入A,而不是B。簡單的跳轉邏輯路線:
A –> B –> C –> 按返回鍵 –> A
綜上,可以這麼理解android:noHistory=true對Activity行為的影響:當該Activity屏幕不可見時,相當於Android系統調用Activity的finish()方法結束了該Activity。
實驗代碼:
A.java
package zhangphil.test; import android.support.v7.app.ActionBarActivity; import android.view.View; import android.widget.Button; import android.content.Context; import android.content.Intent; import android.os.Bundle; public class A extends ActionBarActivity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); Button button = new Button(this); button.setText(點擊跳轉到B); final Context context = this; button.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { Intent intent = new Intent(context, B.class); startActivity(intent); } }); setContentView(button); } }
B.java
package zhangphil.test; import android.support.v7.app.ActionBarActivity; import android.view.View; import android.widget.Button; import android.content.Context; import android.content.Intent; import android.os.Bundle; /** * android:noHistory=true * * */ public class B extends ActionBarActivity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); Button button = new Button(this); button.setText(點擊跳轉到C); final Context context = this; button.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { Intent intent = new Intent(context, C.class); startActivity(intent); } }); setContentView(button); } }
C.java
package zhangphil.test; import android.support.v7.app.ActionBarActivity; import android.os.Bundle; public class C extends ActionBarActivity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); } }
DrawerLayout組件同樣是V4包中的組件,也是直接繼承於ViewGroup類,所以這個類也是一個容器類。抽屜菜單的擺放和布局通過android:layout_gr
本文主要講解MVP開發模式以及具體實例。一、簡介MVP(Model View Presenter)模式是著名的MVC(Model View Controller)模式的一
Fragment相當於一個小型activity,因為Fragment可以實現activity中所有的功能,不同的是Fragment可以嵌入activity,一個activ
如今微信的熱度已經遠超微博,無論是Android還是WindowsPhone系統,微信永遠是使用頻率最高的APP。下面,我們就來解決困擾上述兩種系統微信玩家