您的位置:首页 > 其它

Adnroid 使用安卓自带的人脸识别API

2016-11-17 01:24 513 查看
缺点是精度不高,识别信息很少,只有眼睛的识别

MainActivity.java

import android.app.Activity;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.graphics.PointF;
import android.media.FaceDetector;
import android.os.Bundle;
import android.util.Log;
import android.view.ViewGroup;
import android.widget.ImageView;

public class MainActivity extends Activity {

private final int MAX_FACES = 5;    //最大可识别的人脸数

private ImageView mIv;
private Bitmap mFaceBitmap;

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);

//创建一个ImageView,加载到Activity视图上
mIv = new ImageView(this);
setContentView(mIv, new ViewGroup.LayoutParams(ViewGroup.LayoutParams.WRAP_CONTENT, ViewGroup.LayoutParams.WRAP_CONTENT));
//要进行人脸识别的图片
mFaceBitmap = BitmapFactory.decodeResource(getResources(), R.mipmap.face);

mIv.setImageBitmap(mFaceBitmap);

//因为这是一个耗时的操作,所以放到另一个线程中运行
new Thread(new Runnable() {
@Override
public void run() {
FaceDetector.Face[] faces = new FaceDetector.Face[MAX_FACES];
//格式必须为RGB_565才可以识别
Bitmap bmp = mFaceBitmap.copy(Bitmap.Config.RGB_565, true);
//返回识别的人脸数
int faceCount = new FaceDetector(bmp.getWidth(), bmp.getHeight(), MAX_FACES).findFaces(bmp, faces);
bmp.recycle();
bmp = null;
Log.e("tag", "识别的人脸数:" + faceCount);

if (faceCount > 0) {
final Bitmap bitmap = parseBitmap(faces, faceCount);
//显示处理后的图片
mIv.post(new Runnable() {
@Override
public void run() {
mIv.setImageBitmap(bitmap);
}
});
}
}
}).start();
}

/**
* 在人脸上画矩形
*/
private Bitmap parseBitmap(FaceDetector.Face[] faces, int faceCount){
Bitmap bitmap = Bitmap.createBitmap(mFaceBitmap.getWidth(), mFaceBitmap.getHeight(), Bitmap.Config.ARGB_8888);
Canvas canvas = new Canvas(bitmap);
Paint mPaint = new Paint(Paint.ANTI_ALIAS_FLAG);
mPaint.setColor(Color.YELLOW);
mPaint.setStrokeWidth(10);
mPaint.setStyle(Paint.Style.STROKE);

canvas.drawBitmap(mFaceBitmap, 0, 0, mPaint);
for (int i = 0; i < faceCount; i++){
//双眼的中心点
PointF midPoint = new PointF();
faces[i].getMidPoint(midPoint);
//双眼的距离
float eyeDistance = faces[i].eyesDistance();
//画矩形
canvas.drawRect(midPoint.x - eyeDistance, midPoint.y - eyeDistance, midPoint.x + eyeDistance, midPoint.y + eyeDistance, mPaint);
}

return bitmap;
}
}


测试图片face.jpg



运行结果

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  人脸识别