在指纹识别功能的实践中,我将其做成了开源库发布在了 Github 上,可通过 gradle 进行依赖,使用方法比较简单,两三行代码,再传入一个验证结果监听即可。
下面对部分实现过程做一下介绍,详细的 Api 及源码请移步 Github。
示例
Android 6.0 指纹识别框,开发者自定义:
Android 9.0 指纹识别框,系统提供:
其中指纹 icon 和取消按钮的文字颜色,由属性 colorPrimary 的颜色值决定。
指纹识别管理类
FingerprintVerifyManager
是指纹识别库的入口,对指纹识别进行管理,通过 FingerprintVerifyManager.Builder
对指纹识别进行初始化。
在这个类中,有根据手机系统版本调用不同的指纹识别 Api(FingerprintManagerCompat
或者 BiometricPrompt
),其中 BiometricPrompt
支持开启或者关闭,默认关闭。
public FingerprintVerifyManager(Builder builder) {
IFingerprint fingerprint;
// >= Android P
if (AndrVersionUtil.isAboveAndrP()) {
//在 Android P 上是否展示系统提供的识别框
if (builder.enableAndroidP)
fingerprint = FingerprintAndrP.newInstance();
else
fingerprint = FingerprintAndrM.newInstance();
} else if (AndrVersionUtil.isAboveAndrM()) {// Android 6.0 =< Version
fingerprint = FingerprintAndrM.newInstance();
} else {// < Android 6.0 ,官方未开放指纹识别,某些机型自行支持的情况暂不做处理
builder.callback.onError(builder.context.getString(R.string.biometricprompt_verify_error_below_m));
return;
}
……
fingerprint.authenticate(builder.context, bean, builder.callback);
}
其中 IFingerprint
是指纹识别的接口,兼容 Android 6.0 的 FingerprintAndrM
和兼容 Android 9.0 的 FingerprintAndrP
都实现了此接口。
public interface IFingerprint {
/**
- 初始化并调起指纹识别
- @param context
- @param verificationDialogStyleBean 指纹识别框样式
- @param callback 通知开发者指纹识别结果
*/
void authenticate(Activity context, VerificationDialogStyleBean verificationDialogStyleBean, FingerprintCallback callback);
}
基于Android 6.0 实现指纹识别
上文有提及,FingerprintAndrM
是基于 Android 6.0 的具体的指纹识别实现类:
@RequiresApi(api = Build.VERSION_CODES.M)
public class FingerprintAndrM implements IFingerprint {
private final String TAG = FingerprintAndrM.class.getName();
private Activity context;
private static FingerprintAndrM fingerprintAndrM;
//指纹验证框
private static FingerprintDialog fi