Android指紋登錄工具類封裝
本文實例為大家分享了Android指紋登錄工具類的封裝代碼,供大家參考,具體內容如下
核心
Android 指紋 是在 6.0 才出來的一個重要的功能
@RequiresApi(api = Build.VERSION_CODES.M)
核心的兩個 api:
FingerprintManager
KeyguardManager
step1
判斷android 版本,如果小于 6.0 支持不了指紋
if(Build.VERSION.SDK_INT < Build.VERSION_CODES.M){ return; }
step2
判斷 手機硬件(有沒有指紋感應區(qū))就是手機是否支持傳感
@RequiresApi(api = Build.VERSION_CODES.M) public boolean isHardFinger() { if (fingerprintManager != null && fingerprintManager.isHardwareDetected()) { return true; } else { return false; } }
step3
檢查手機是否開啟鎖屏密碼(如手機未開鎖,涉及到一個優(yōu)先級問題,先解鎖 后使用)
public boolean isWindowSafe() { if (keyguardManager != null && keyguardManager.isKeyguardSecure()) { return true; } else { return false; } }
step4
檢查手機是否有錄入指紋
@RequiresApi(api = Build.VERSION_CODES.M) public boolean isHaveHandler() { if (fingerprintManager != null && fingerprintManager.hasEnrolledFingerprints()) { return true; } else { return false; } }
只有以上步驟全滿足,才能使用指紋
開啟指紋驗證
@RequiresApi(api = Build.VERSION_CODES.M) public void authenticate(FingerprintManager.CryptoObject cryptoObject, CancellationSignal cancellationSignal, int flag, FingerprintManager.AuthenticationCallback authenticationCallback, Handler handler) { if (fingerprintManager != null) { fingerprintManager.authenticate(cryptoObject, cancellationSignal, flag, authenticationCallback, handler); } }
參數(shù)中最重要的就是 cancellationSignal和 callback,其他傳null 和 0 就行,cancellationsignal 是用來取消指紋驗證的,而callback 可以回調 指紋驗證失敗次數(shù) 或者指紋驗證成功
最后附上簡單工具類
/** * 指紋識別工具類 */ public class FingerUtils { private final FingerprintManager fingerprintManager; private final KeyguardManager keyguardManager; @RequiresApi(api = Build.VERSION_CODES.M) private FingerUtils(Context context) { fingerprintManager = (FingerprintManager) context.getSystemService(Context.FINGERPRINT_SERVICE); keyguardManager = (KeyguardManager) context.getSystemService(Context.KEYGUARD_SERVICE); } private static FingerUtils singleton = null; @RequiresApi(api = Build.VERSION_CODES.M) public static FingerUtils getInstance(Context context) { if (singleton == null) { synchronized (FingerUtils.class) { if (singleton == null) { singleton = new FingerUtils(context); } } } return singleton; } /** * ②檢查手機硬件(有沒有指紋感應區(qū)) */ @RequiresApi(api = Build.VERSION_CODES.M) public boolean isHardFinger() { if (fingerprintManager != null && fingerprintManager.isHardwareDetected()) { return true; } else { return false; } } /** * ③檢查手機是否開啟鎖屏密碼 */ public boolean isWindowSafe() { if (keyguardManager != null && keyguardManager.isKeyguardSecure()) { return true; } else { return false; } } /** * ④檢查手機是否已錄入指紋 */ @RequiresApi(api = Build.VERSION_CODES.M) public boolean isHaveHandler() { if (fingerprintManager != null && fingerprintManager.hasEnrolledFingerprints()) { return true; } else { return false; } } /** * 創(chuàng)建指紋驗證 */ @RequiresApi(api = Build.VERSION_CODES.M) public void authenticate(FingerprintManager.CryptoObject cryptoObject, CancellationSignal cancellationSignal, int flag, FingerprintManager.AuthenticationCallback authenticationCallback, Handler handler) { if (fingerprintManager != null) { fingerprintManager.authenticate(cryptoObject, cancellationSignal, flag, authenticationCallback, handler); } } /** * 取消指紋驗證 . 應該不會用上 */ public void cannelFinger(CancellationSignal cancellationSignal) { cancellationSignal.cancel(); } }
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
Android開發(fā)教程之獲取系統(tǒng)輸入法高度的正確姿勢
這篇文章主要給大家介紹了關于Android開發(fā)教程之獲取系統(tǒng)輸入法高度的正確姿勢,文中通過示例代碼介紹的非常詳細,對大家學習或者使用Android具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2018-10-10RecyclerView嵌套RecyclerView滑動卡頓的解決方法
這篇文章主要為大家詳細介紹了RecyclerView嵌套RecyclerView滑動卡頓的解決方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-12-12Android TextWatcher監(jiān)控EditText中的輸入內容并限制其個數(shù)
本篇文章主要介紹了Android TextWatcher監(jiān)控EditText中的輸入內容并限制其個數(shù),我們可以通過TextWatcher去觀察輸入框中輸入的內容,有興趣的可以了解一下。2017-04-04Android實現(xiàn)獲取未接來電和未讀短信數(shù)量的方法
這篇文章主要介紹了Android實現(xiàn)獲取未接來電和未讀短信數(shù)量的方法,是Android程序開發(fā)中非常常見的重要功能,需要的朋友可以參考下2014-08-08