① 如何使用Back鍵關閉android AIR應用程序
如果使用Flex開發基於AIR的Android應用,有一個問題不得不考慮,用戶使用Back按鍵或Home按鍵退出當前視圖(View)使應用程序在後台運行時,應用程序有兩條路可選:一是自動退出;二是遵從Android系統內存和進程管理規則,在內存和CPU資源緊張的情況下,被系統回收掉。對於這兩種方式,用戶以及開發者都有不同的感受和理解。有人認為應用如果退出,就應該完全釋放資源為後來者騰地方,而不是退居後台;有人認為頻繁的釋放和分配資源會加重IO和CPU運算負擔,所以應該先在後台呆著,需要時可以盡快上場轉入前台。這里暫不討論分析這兩種方式的長短,而是介紹一種針對基於AIR的Android應用的
Back按鍵處理方式。
② android 怎麼調用鍵盤的back鍵
android 監聽鍵盤的back鍵的話,activity裡面提供了方法,onbackpress這樣類似的方法,復寫就可以了。
③ unity3d程序android下響應back按鍵
如果你的activity啟動模式方面是默認的話,新的activity調用finish方法之後,應該會自動回到上一個activity的啊.
④ android back的事件怎麼從下往上傳遞的
Override
public boolean dispatchTouchEvent(MotionEvent ev)
{
//該Callback就是該DecorView附屬的Activity,可以看我的另外一篇文章《Android中窗口的創建過程》
final Callback cb = getCallback();
//如果cb!=null && mFeatureId<0 就執行Activity中的dispatchTouchEvent方法,對於應用程序窗口 <span > </span> //這兩個條件一般是滿足的
return cb != null && mFeatureId < 0 ? cb.dispatchTouchEvent(ev) : super
.dispatchTouchEvent(ev);
}
⑤ android開發中,怎麼讓activity在按back鍵不推出。
重寫返回按鍵事件public void onBackPressed()此方法當返回按鍵事件出發時,系統會默認調用finish(),你直接return別讓系統調用就行,back鍵後台參考源碼home的事件並重寫
⑥ Android監聽Home鍵和Back鍵的區別介紹
一:Android 中Home鍵監聽和Back鍵監聽的區別:
(1).在Android中,當按下Home鍵的時候,默認情況下Stop前台的Activity,即Activity設置成停止狀態【onStop()】,而不是銷毀狀態【onDestory()】。如果再次啟動該Activity,不是調用onCreate()方法,而是調用onSavedInstanceState方法。則是從onRestart()開始-onStart()-onResume()。
(2).當按下back鍵則不同,back鍵默認finish前台的activity,即activity的狀態為onDestory為止,再次啟動該activity則從onCreate開始,不會調用onSavedInstanceState方法。
總而言之:按下Home鍵會返回桌面,而back則會返回前一個activity。
在這里Back鍵的實現方法就不贅述了,主要講解一下Home鍵的實現方式吧。以下是我找的參考資料自己思考的。請大家給出建議。
Home鍵監聽的實現方法:
(1).在onResum裡面注冊廣播,OnPause裡面注銷廣播。
(2).在廣播中攔截Intent.ACTION_CLOSE_SYSTEM_DIALOGS 這個Action ,通過獲取Reason欄位 來判斷長按 還是單擊Home鍵。
代碼如下:
(1).Home鍵監聽封裝類:
package com.scd.homewatcher.util;
import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.content.IntentFilter;
import android.util.Log;
/**
* Home鍵監聽封裝
*
* @author way
*
*/
public class HomeWatcher {
// 回調介面
public interface OnHomePressedListener {
public void onHomePressed();
public void onHomeLongPressed();
}
private static final String TAG = "HomeWatcher";
/** 上下文 */
private Context mContext;
/** 過濾器 */
private IntentFilter mFilter;
/** 介面 */
private OnHomePressedListener mListener;
/** 廣播接收者 */
private InnerRecevier mRecevier;
public HomeWatcher(Context context) {
mContext = context;
mRecevier = new InnerRecevier();
mFilter = new IntentFilter(Intent.ACTION_CLOSE_SYSTEM_DIALOGS);
}
/**
* 設置監聽
*
* @param listener
*/
public void setOnHomePressedListener(OnHomePressedListener listener) {
mListener = listener;
}
/**
* 開始監聽,注冊廣播
*/
public void startWatch() {
if (mRecevier != null) {
mContext.registerReceiver(mRecevier, mFilter);
}
}
/**
* 停止監聽,注銷廣播
*/
public void stopWatch() {
if (mRecevier != null) {
mContext.unregisterReceiver(mRecevier);
}
}
/**
* 廣播接收者
*/
private class InnerRecevier extends BroadcastReceiver {
final String SYSTEM_DIALOG_REASON_KEY = "reason";
final String SYSTEM_DIALOG_REASON_GLOBAL_ACTIONS = "globalactions";
final String SYSTEM_DIALOG_REASON_RECENT_APPS = "recentapps";
final String SYSTEM_DIALOG_REASON_HOME_KEY = "homekey";
@Override
public void onReceive(Context context, Intent intent) {
String action = intent.getAction();
if (action.equals(Intent.ACTION_CLOSE_SYSTEM_DIALOGS)) {
String reason = intent.getStringExtra(SYSTEM_DIALOG_REASON_KEY);
if (reason != null) {
Log.i(TAG, "action:" + action + ",reason:" + reason);
if (mListener != null) {
if (reason.equals(SYSTEM_DIALOG_REASON_HOME_KEY)) {
// 短按home鍵
mListener.onHomePressed();
} else if (reason
.equals(SYSTEM_DIALOG_REASON_RECENT_APPS)) {
// 長按home鍵
mListener.onHomeLongPressed();
}
}
}
}
}
}
}
(2).MainActivity類:
package com.scd.homewatcher;
import android.app.Activity;
import android.os.Bundle;
import android.view.KeyEvent;
import android.widget.Toast;
import com.scd.homewatcher.util.HomeWatcher;
import com.scd.homewatcher.util.HomeWatcher.OnHomePressedListener;
public class MainActivity extends Activity implements OnHomePressedListener {
private HomeWatcher mHomeWatcher;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
}
@Override
protected void onResume() {
mHomeWatcher = new HomeWatcher(this);
mHomeWatcher.setOnHomePressedListener(this);
// 注冊廣播
mHomeWatcher.startWatch();
super.onResume();
}
@Override
protected void onPause() {
mHomeWatcher.setOnHomePressedListener(null);
// 注銷廣播
mHomeWatcher.stopWatch();
super.onPause();
}
@Override
public void onHomePressed() {
// TODO
Toast.makeText(this, "短按Home鍵,實現自己的邏輯", Toast.LENGTH_SHORT).show();
}
@Override
public void onHomeLongPressed() {
// TODO
Toast.makeText(this, "長按Home鍵,實現自己的邏輯", Toast.LENGTH_SHORT).show();
}
@Override
public boolean onKeyDown(int keyCode, KeyEvent event) {
if ((keyCode == KeyEvent.KEYCODE_BACK)) {
System.out.println("按下了back鍵 onKeyDown()");
return false;
} else {
return super.onKeyDown(keyCode, event);
}
}
@Override
public void onBackPressed() {
// super.onBackPressed()會自動調用finish()方法,關閉
super.onBackPressed();
}
}
⑦ android 中如何用back鍵,控制View的切換
@Override
public void onBackPressed() {
if (mView2.getVisibility() == View.VISIBLE) {//如果現在是顯示的view2布局
//顯示view1布局,隱藏view2布局
mView1.setVisibility(View.VISIBLE);
mView2.setVisibility(View.GONE);
} else if (mView3.getVisibility() == View.VISIBLE) {//如果現在是顯示的view3布局
//顯示view2布局,隱藏view3布局
mView2.setVisibility(View.VISIBLE);
mView3.setVisibility(View.GONE);
} else { //否則使用默認的返回鍵按下處理邏輯
super.onBackPressed();
}
}
⑧ android activity 按back鍵 執行什麼過程
進程只是APP的一個容器而已,這個容器空了不代表這個容器沒了,但是你把容器銷毀了,容器里的東西一樣會被銷毀,按back鍵就是後退棧做pop操作的過程(回調onbackpressed,默認實現是調用finish(),finish()方法又會去調用OnDestroy),棧頂Activity就被銷毀,所以會回調Activity的OnDestroy方法;而按home鍵是把整個任務棧掛起到後台,回到啟動器首頁,Activity並沒有銷毀。所以不會回調Activity的OnDestroy。
至於長按home鍵啟動任務管理器結束應用,進程還是存在,這個因手機而異。有些手機是銷毀這個應用(Application類的實例),進程這個容器還在,只是空了(空進程),發現進程不見了多數是因為系統回收空進程;有些手機是直接結束進程。
⑨ Android 中如何監聽到Back鍵和Home鍵
繼承Activity
重寫OnKeyDown()
在裡面列印下鍵 值。
似乎在不同手機上。它對應的鍵值是不相同的。
得到Back和Home的鍵值
然後再匹配鍵值。寫自己要做的事就可以了
Back的可以這樣寫:
public boolean onKeyDown(int keyCode, KeyEvent event) {
// TODO Auto-generated method stub
if (keyCode == KeyEvent.KEYCODE_BACK) {
}
return super.onKeyDown(keyCode, event);
}
⑩ android中back鍵怎麼重寫並調用
@Override
public boolean onKeyDown(int keyCode, KeyEvent event) {
// TODO Auto-generated method stub
if(keyCode==KeyEvent.KEYCODE_BACK){
//彈出確定退出對話框
new AlertDialog.Builder(this)
.setTitle("退出")
.setMessage("確定退出嗎?")
.setPositiveButton("確定", new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
System.exit(0);
}
})
.setNegativeButton("取消", new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
// TODO Auto-generated method stub
dialog.cancel();
}
})
.show();
//這里不需要執行父類的點擊事件,所以直接return
return true;
}
//繼續執行父類的其他點擊事件
return super.onKeyDown(keyCode, event);
}