android的一個指紋驗證效果java
接觸opencv有一段時間了,恰好公司最近有個指紋相關的功能,其中有個指紋特效晚上現成沒有很好定製型因此就用opencv試着寫了一個效果。android
https://github.com/woshiliyihang/touchZWgit
效果不是很是好可是修改定製簡單,所須要準備的有兩張圖片:
前景圖:
背景圖:
github
一個是紅色前景,一個黑色背景,兩張圖片尺寸同樣大。app
package com.jasonliyihang.zwdome; import androidx.appcompat.app.AppCompatActivity; import android.os.Bundle; import android.os.Handler; import android.widget.ImageView; import org.opencv.jason.DrawZW; public class MainActivity extends AppCompatActivity { private DrawZW drawZW; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); } @Override protected void onResume() { super.onResume(); // 初始化opencv工具類 DrawZW.onResume(this, new Runnable() { @Override public void run() { startAnim(); } }); } private void startAnim() { //R.mipmap.zhiwen 前景圖 R.mipmap.zhiwen_gr 背景圖 drawZW = new DrawZW((ImageView) findViewById(R.id.img), R.mipmap.zhiwen, R.mipmap.zhiwen_gr); new Handler().postDelayed(new Runnable() { @Override public void run() { // x y r 分別表明這個 圓心 xy 點 和 半徑 r drawZW.logic(drawZW.getRgb().cols()/2,drawZW.getRgb().rows()/2, (int) (drawZW.getRgb().cols()*0.4f), 700); } }, 2001); new Handler().postDelayed(new Runnable() { @Override public void run() { drawZW.logic(drawZW.getRgb().cols()/3,drawZW.getRgb().rows()/3,drawZW.getRgb().cols()/3, 700); } }, 4001); new Handler().postDelayed(new Runnable() { @Override public void run() { drawZW.logic(drawZW.getRgb().cols()/2,drawZW.getRgb().rows()/4*3, (int) (drawZW.getRgb().cols()*0.7f), 700); } }, 6001); new Handler().postDelayed(new Runnable() { @Override public void run() { drawZW.logic(drawZW.getRgb().cols()/2,drawZW.getRgb().rows()/4,drawZW.getRgb().cols()*2, 700); } }, 8000); new Handler().postDelayed(new Runnable() { @Override public void run() { drawZW.free();//記得釋放內存哦 } }, 10000); } }
主要說明註釋裏面已經寫了!
簡單介紹原理:就是經過畫圓的方式模擬點擊效果,而後使用圖形處理達到效果。
不喜勿噴,若是這個對你有幫助記得點贊哦 !!!!!!!!!!!!!!!!!!!!!!!!!dom