在Android开发中,大部分应用都是以用户为第一位,用户都有自己的个人中心,用来展示自己的信息,头像无疑是展示自己最直观的方式,随着各种政策的出台,实名认证,真人头像变得尤为重要,如果要求上传真人头像,那就需要后台做校验,判断是不是真人,如果真人审核,那工作量是非人力所能为的,这时候就用到各种识别图片的算法,来做这些工作了,这里主要介绍Android里面谷歌开放的图片脸部识别的API。
上代码:
依赖:
dependencies { compile 'com.google.android.gms:play-services-vision:8.4.0' }
import com.google.android.gms.vision.Frame; import com.google.android.gms.vision.face.Face; import com.google.android.gms.vision.face.FaceDetector; private Bitmap getFaceBitmap(Bitmap bmp, Context context) { FaceDetector faceDetector = new FaceDetector.Builder(context).setTrackingEnabled(false) .build(); if (!faceDetector.isOperational()) { System.out.println("Face detector not working"); return null; } Bitmap faceBitmap = null; Frame frame = new Frame.Builder().setBitmap(bmp).build(); SparseArray<Face> faces = faceDetector.detect(frame); Log.e("RoungImage", "00100bmp.getWidth" + bmp.getWidth()); Log.e("RoungImage", "00100bmp.getHeight" + bmp.getHeight()); Log.e("RoungImage", "006faces:" + faces.size()); for (int i = 0; i < faces.size(); i++) { Face thisFace = faces.valueAt(i); int faceWidth = (int) thisFace.getWidth(); Log.e("RoungImage", "007faceWidth:" + faceWidth); int faceHeight = (int) thisFace.getHeight(); Log.e("RoungImage", "008faceHeight:" + faceHeight); int x1 = (int) thisFace.getPosition().x; Log.e("RoungImage", "009x1:" + x1); int y1 = (int) thisFace.getPosition().y; Log.e("RoungImage", "0010y1" + y1); faceBitmap = Bitmap.createBitmap(bmp, x1 > (faceWidth / 2) ? (x1 - faceWidth / 2) : 0, y1 > (faceHeight / 2) ? (y1 - faceHeight / 2) : 0, 1.5 * faceWidth < bmp.getWidth() ? (int) (1.5 * faceWidth) : bmp.getWidth(), 1.5 * faceHeight < bmp.getWidth() ? (int) (1.5 * faceHeight) : bmp.getHeight()); } if (faceBitmap != null) return faceBitmap; return bmp; }
这里测试两张图片,识别图片中的脸部信息,图片如下:
识别出各种坐标以后,大致是这样的:
精确度还是很不错的。
这里只是打印一下坐标,实际还有很多其他的API,eg:眼睛是否睁开,脸部是否微笑,微笑的概率,and so on...