android使用opencv實現指紋驗證效果

touchZW

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

相關文章
相關標籤/搜索