Adroid學習之 從源碼角度分析-禁止使用回退按鈕方案

有時候,不能讓用戶進行回退操作,如何處理?

查看返回鍵觸發了哪些方法。在打開程序后把這個方法禁止了。
問題:程序在后臺駐留,這樣就會出現,其他時候也不能使用回退按鈕。如何處理,在onpase()時方法失效。
方案一:
1 //重載onBackPressed
2 @Override
3 public void onBackPressed() {
4         // TODO Auto-generated method stub
5         //super.onBackPressed();
6 }

查看Adroid源碼 onBackPressed?()源碼:

1     public void onBackPressed() {
2         finish();
3     }

重寫這個方法會不會有什么問題呢?他執行一個finish();方法對其本身應該沒什么問題,那么調用出呢?

下面是Activity中調用的兩處:
Adroid源碼調用1:
 1     public boolean onKeyDown(int keyCode, KeyEvent event) {
 2     //當按鈕等于KEYCODE_BACK時執行下面方法,KEYCODE_BACK這個就是返回鍵
 3         if (keyCode == KeyEvent.KEYCODE_BACK) {
 4            //檢測版本號   ECLAIR 值為:public static final int ECLAIR = 5;
 5             if (getApplicationInfo().targetSdkVersion
 6                     >= Build.VERSION_CODES.ECLAIR) {
 7             //當大于5是執行
 8             /**startTracking()解釋:調用onKeyUp()方法。
 9             Call this during Callback.onKeyDown to have the system track the key through its final up (possibly including a long press). Note that only one key can be tracked at a time -- if another key down event is received while a previous one is being tracked, tracking is stopped on the previous event.
10             */
11                 event.startTracking();
12             } else {
13                 onBackPressed();
14             }
15             return true;
16         }
17 }

Adroid源碼調用2:

 1     public boolean onKeyUp(int keyCode, KeyEvent event) {
 2         if (getApplicationInfo().targetSdkVersion
 3                 >= Build.VERSION_CODES.ECLAIR) {
 4             if (keyCode == KeyEvent.KEYCODE_BACK && event.isTracking()
 5                     && !event.isCanceled()) {
 6                 onBackPressed();
 7                 return true;
 8             }
 9         }
10         return false;
11     }

  到這里可以看出我們在onBackPressed()被調用處,都是在按下返回鍵的情況下,所以可以沖寫onBackPressed方法,因為是被調用的,雖然不會出錯,但是效率應該不高。

要不我們重寫onKeyDown方法這樣可行,直接攔截。
1  @Override 
2     public boolean onKeyDown(int keyCode, KeyEvent event) { 
3         if(keyCode==KeyEvent.KEYCODE_BACK) {
4             Toast.makeText(getApplicationContext(), "back press", Toast.LENGTH_LONG).show();
5              return false; // Disable back button.............. 
6 }

但是會如果在按鈕處直接攔截,效果應該會高一些,這樣就不會觸發上面這兩個方法了。

于是乎我們繼續向上尋找。
細心的朋友可能發現onBackPressed()調用了finish()方法,所以干脆我們重寫它吧。
方案二:重載finish函數:
查看Android的 finish()源碼:
 1 public void finish() {
 2         if (mParent == null) {
 3             int resultCode;
 4             Intent resultData;
 5             synchronized (this) {
 6                 resultCode = mResultCode;
 7                 resultData = mResultData;
 8             }
 9             if (Config.LOGV) Log.v(TAG, "Finishing self: token=" + mToken);
10             try {
11                 if (ActivityManagerNative.getDefault()
12                     .finishActivity(mToken, resultCode, resultData)) {
13                     mFinished = true;
14                 }
15             } catch (RemoteException e) {
16                 // Empty
17             }
18         } else {
19             mParent.finishFromChild(this);
20         }
21     }

查看Android源碼中調用它的方法:

 1     /**
 2      * This is called when a child activity of this one calls its
 3      * {@link #finish} method. The default implementation simply calls
 4      * finish() on this activity (the parent), finishing the entire group.
 5      *
 6      * @param child The activity making the call.
 7      *
 8      * @see #finish
 9      */
10     public void finishFromChild(Activity child) {
11         finish();
12     }

從說明中我們知道這個方法是在子Activity結束時調用的這個方法,所以不行,如果我們要重寫,需要進行判斷拿到的鍵值。效率不高。

繼續尋找,看看哪里執行了調用方法按鍵吧。
方案三:重寫keyevent方法 大括號里加上return true 這樣就禁用父類方法達到禁止返回鍵的目的?
Android源碼中找來找去找到了這個:
 1  /**
 2      * Called to process key events. You can override this to intercept all
 3      * key events before they are dispatched to the window. Be sure to call
 4      * this implementation for key events that should be handled normally.
 5      *
 6      * @param event The key event.
 7      *
 8      * @return boolean Return true if this event was consumed.
 9      */
10     public boolean dispatchKeyEvent(KeyEvent event) {
11         onUserInteraction();
12         Window win = getWindow();
13         if (win.superDispatchKeyEvent(event)) {
14             return true;
15         }
16         View decor = mDecor;
17         if (decor == null) decor = win.getDecorView();
18         return event.dispatch(this, decor != null
19                 ? decor.getKeyDispatcherState() : null, this);
20     }

就是在按鈕觸發的事件,當然是Activity中的。到此我們發現我們找到地方了,按鈕進入后第一個處理的地方,再次我們重寫這個方法就OK了。

 1 @Override
 2 
 3 public boolean dispatchKeyEvent(KeyEvent event) {
 4 
 5 if (event.getKeyCode() == KeyEvent.KEYCODE_BACK) 
 6         {     
 7 
 8      return true; 
 9 
10         }
11 
12 return super.dispatchKeyEvent(event);
13 
14 }

?


轉載于:https://www.cnblogs.com/dava/p/3688577.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/377106.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/377106.shtml
英文地址,請注明出處:http://en.pswp.cn/news/377106.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

騎士游歷問題問題_騎士步行問題

騎士游歷問題問題Problem Statement: 問題陳述: There is a chessboard of size NM and starting position (sx, sy) and destination position (dx,dy). You have to find out how many minimum numbers of moves a knight goes to that destination position? 有…

Android基礎之用Eclipse搭建Android開發環境和創建第一個Android項目(Windows平臺)...

一、搭建Android開發環境 準備工作:下載Eclipse、JDK、Android SDK、ADT插件 下載地址:Eclipse:http://www.eclipse.org/downloads/ JDK:http://www.oracle.com/technetwork/java/javase/downloads/jdk7u9-downloads-1859576.html Android SD…

《dp補卡——01背包問題》

目錄01背包[416. 分割等和子集](https://leetcode-cn.com/problems/partition-equal-subset-sum/)[1049. 最后一塊石頭的重量 II](https://leetcode-cn.com/problems/last-stone-weight-ii/)[494. 目標和](https://leetcode-cn.com/problems/target-sum/)01背包 1、dp數組以及…

用JavaScript往DIV動態添加內容

參考&#xff1a;http://zhidao.baidu.com/link?url6jSchyqPiEYCBoKdOmv52YHz9r7MTBms2pK1N6ptOX1kaR2eg320mlW1Sr6n36hpOeOadBxC2rWWGuhZPbms-K <div id"show"></div>要填充的數據為: 這是一個測試例子.jquery&#xff1a;$(function(){ var data …

《dp補卡——完全背包問題》

N件物品和一個最多能背重量為W的背包。第i件物品的重量為weight[i]&#xff0c;得到的價值是value[i]。每件物品都有無限個(可以放入背包多次)&#xff0c;求解將哪些物品裝入背包里物品價值總和最大。 01背包和完全背包唯一不同在于遍歷順序上。 01背包的核心代碼&#xff1a…

Java中的類型轉換

類型轉換 (Typecasting) Typecasting is a term which is introduced in all the language similar to java. Typecasting是一個用與Java類似的所有語言引入的術語。 When we assign primitive datatype to another datatype. 當我們將原始數據類型分配給另一個數據類型時。 I…

讓crash文件中的內存地址變成函數名稱,

假如程序員編譯了inhouse給測試。 如果在測試過程中出現奔潰現象&#xff0c;我想程序員一般會來看Device Log 也就是 crash文件 如果crash文件遇到如下的情況&#xff0c;在重要的地方看不到函數名稱。我想是一件很奔潰的事情。 1 Exception Type: EXC_BAD_ACCESS (SIGSEGV)2…

《dp補卡——多重背包》

多重背包簡介&#xff1a; 有N種物品和一個容量為V的背包。第i種物品最多有Mi件可用&#xff0c;每件耗費的空間為Ci&#xff0c;價值為Wi。求解將哪些物品裝入背包可使得這些物品耗費的空間總和不超過背包容量&#xff0c;且價值總和最大。 將Mi件攤開&#xff0c;就是一個01背…

kafka消息確認ack_什么是確認(ACK)? ACK代表什么?

kafka消息確認ackACK&#xff1a;致謝 (ACK: Acknowledgment) An acknowledgment (ACK) is a signal that is passed among the communicating processes, computers, or devices to indicate acknowledgment, or delivery of the message, as a component of a communications…

CocoaAsyncSocket 套接字

CocoaAsyncSocket 套接字 https://github.com/robbiehanson/CocoaAsyncSocket Asynchronous socket networking library for Mac and iOS 用于iOS以及Mac的異步套接字網絡庫。 TCP GCDAsyncSocket and AsyncSocket are TCP/IP socket networking libraries. Here are the key…

谷歌瀏覽器設置緩存方法

谷歌瀏覽器設置緩存方法&#xff1a; 1、在桌面Google Chrome快捷方式&#xff0c;目標&#xff1a;找到 C:\Users\Splendid\AppData\Local\…\Application\chrome.exe 在這后面加上-Disk-Cache-Dir”Z:\TEMP” 注意: -Disk前面有空格&#xff0c;”Z:\TEMP” 是文件存放在Z盤T…

《dp補卡——買賣股票問題》

目錄121. 買賣股票的最佳時機貪心dp思路滾動數組優化122. 買賣股票的最佳時機 II123. 買賣股票的最佳時機 III188. 買賣股票的最佳時機 IV309. 最佳買賣股票時機含冷凍期714. 買賣股票的最佳時機含手續費121. 買賣股票的最佳時機 貪心 取最左最小值&#xff0c;取最右最大值&…

oo0ooo0ooo0oo_OoO的完整形式是什么?

oo0ooo0ooo0ooOoO&#xff1a;外出 (OoO: Out of Office) OoO is an abbreviation of "Out of Office". OoO是“不在辦公室”的縮寫。 It is an expression, which is commonly used in the Gmail platform. It is written in the body or the subject of the email…

SP2010開發和VS2010專家食譜--第三章節--高級工作流(2)--為沙盒解決方案創建自定義活動...

盡管沙河解決方案功能有限&#xff0c;你仍然可以開發自定義活動&#xff0c;在SharePoint Designer中使用而不用改變web.config或添加.ACTION文件到根文件夾。 轉載于:https://www.cnblogs.com/crazygolf/p/3856795.html

sql where 1=1和 0=1 的作用

where 11; 這個條件始終為True&#xff0c;在不定數量查詢條件情況下&#xff0c;11可以很方便的規范語句。 一、不用where 11 在多條件查詢中的困擾 舉個例子&#xff0c;如果您做查詢頁面&#xff0c;并且&#xff0c;可查詢的選項有多個&#xff0c;同時&#xff0c;還讓用戶…

j@2ff4f00f_J4F的完整形式是什么?

j2ff4f00fJ4F&#xff1a;只是為了好玩 (J4F: Just For Fun) J4F is an abbreviation of "Just For Fun". J4F是“ Just For Fun”的縮寫 。 It is an expression, which is commonly used in messaging or chatting on social media networking sites like Faceboo…

《dp補卡——子序列問題》

目錄300. 最長遞增子序列674. 最長連續遞增序列718. 最長重復子數組1143. 最長公共子序列53. 最大子序和392. 判斷子序列115. 不同的子序列583. 兩個字符串的刪除操作72. 編輯距離647. 回文子串 &#xff08;與 5.最長回文子串思路差不多&#xff09;516. 最長回文子序列300. 最…

[LeetCode] Maximal Rectangle

Given a 2D binary matrix filled with 0s and 1s, find the largest rectangle containing all ones and return its area. 在做 Largest Rectangle in Histogram的時候有人說可以用在這題&#xff0c;看了一下還真是&#xff0c;以每行為x軸&#xff0c;每列往上累計的連續的…

什么是alpha測試_什么是ALPHA?

什么是alpha測試Α (ALPHA) Alpha is the first and foremost letter of the Greek alphabet. In the classification of Greek numerals or numbers, it constitutes a value of 1. Alpha是希臘字母的第一個也是最重要的字母 。 在希臘數字或希臘數字的分類中&#xff0c;它的…

《leetcode : 647. 回文子串 思考分析雙指針解法》

647. 回文子串 如何確定是回文串&#xff1a; 找中心然后往兩邊擴散&#xff0c;判斷是否對稱即可。 在遍歷中心點的時候&#xff0c;注意中心點可以是一個元素也可以是兩個元素。 class Solution { public:int cal_two_extend(const string& s,int i,int j,int n){int re…