ML Kit 通过图片识别文字

一、添加依赖 

        不同的语言选择不同的依赖(这里以中文为例)

       implementation 'com.google.mlkit:text-recognition-chinese:16.0.0-beta6'

 二、创建 TextRecognizer 实例

      recognizer = TextRecognition.getClient(new ChineseTextRecognizerOptions.Builder().build());

三、选择图片(动态申请下权限)

        //打开相册选择

        public void openPhoto(View view) {
            if (Build.VERSION.SDK_INT < Build.VERSION_CODES.KITKAT) {
                startActivityForResult(new                 Intent(Intent.ACTION_GET_CONTENT).setType("image/*"),
                111);
            } else {
                Intent intent = new Intent(Intent.ACTION_OPEN_DOCUMENT);
                intent.addCategory(Intent.CATEGORY_OPENABLE);
                intent.setType("image/*");
                startActivityForResult(intent, 111);
            }
        }

        public void openCamera(View view) {
            Intent intent = new Intent();
            intent.setAction(MediaStore.ACTION_IMAGE_CAPTURE);// 照相机拍照
            // 需要说明一下,以下操作使用照相机拍照,
            // 拍照后的图片会存放在相册中的,这里使用的这种方式有一个好处就是获取的图片是拍照
            //后的原图,
            // 如果不实用ContentValues存放照片路径的话,拍照后获取的图片为缩略图不清晰
            ContentValues values = new ContentValues();
            photoUri =         getContentResolver().insert(MediaStore.Images.Media.EXTERNAL_CONTENT_URI,         values);
            intent.putExtra(MediaStore.EXTRA_OUTPUT, photoUri);
            startActivityForResult(intent, 112);

        }

四、处理选择后的结果 

        if (requestCode == 111 && resultCode == RESULT_OK) {
            Uri uri = intent.getData();
            InputImage image;
            try {
                image = InputImage.fromFilePath(mContext, uri);
                activityResult(image);
            } catch (IOException e) {
                e.printStackTrace();
            }
        } else if (requestCode == 112 && resultCode == RESULT_OK) {
            if (photoUri != null) {
                InputImage image;
                try {
                    image = InputImage.fromFilePath(mContext, photoUri);
                    activityResult(image);
                } catch (IOException e) {
                    e.printStackTrace();
                }
            }

        }

             //

        private void resultHandle(Text result) {
            String resultText = result.getText();
            tvResult.setText(resultText);
            for (Text.TextBlock block : result.getTextBlocks()) {
                String blockText = block.getText();
                Point[] blockCornerPoints = block.getCornerPoints();
                Rect blockFrame = block.getBoundingBox();
                for (Text.Line line : block.getLines()) {
                    String lineText = line.getText();
                    Point[] lineCornerPoints = line.getCornerPoints();
                    Rect lineFrame = line.getBoundingBox();
                    for (Text.Element element : line.getElements()) {
                        String elementText = element.getText();
                        Point[] elementCornerPoints = element.getCornerPoints();
                        Rect elementFrame = element.getBoundingBox();
                        for (Text.Symbol symbol : element.getSymbols()) {
                            String symbolText = symbol.getText();
                            Point[] symbolCornerPoints = symbol.getCornerPoints();
                            Rect symbolFrame = symbol.getBoundingBox();
                        }
                    }
                }
            }
        }

参考文献:

https://developers.google.com/ml-kit/vision/text-recognition/v2/android
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
ML Kit是Google推出的一个移动端机器学习框架,可以方便地实现人脸识别和姿势检测。下面是实现人脸识别和姿势检测的详细步骤: 1. 在Android Studio中创建一个新的项目,将minSdkVersion设置为21或更高版本。 2. 在项目的build.gradle文件中添加以下依赖项: ``` dependencies { implementation 'com.google.firebase:firebase-ml-vision:24.0.3' } ``` 3. 配置Firebase ML Kit。在Firebase控制台中创建一个新的项目,并启用ML Kit API。然后将google-services.json文件下载到您的项目中。 4. 为了实现人脸识别,您需要在布局文件中添加一个SurfaceView用于显示照相机预览,并在Activity中实现相机预览和人脸检测。以下是一个简单的示例: ``` public class MainActivity extends AppCompatActivity { private CameraSource cameraSource; private CameraSourcePreview preview; private GraphicOverlay graphicOverlay; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); preview = findViewById(R.id.camera_preview); graphicOverlay = findViewById(R.id.face_overlay); // 创建一个人脸检测器 FaceDetector faceDetector = new FaceDetector.Builder(this) .setTrackingEnabled(false) .build(); // 创建一个相机源 cameraSource = new CameraSource.Builder(this, faceDetector) .setRequestedPreviewSize(640, 480) .setFacing(CameraSource.CAMERA_FACING_FRONT) .setAutoFocusEnabled(true) .setRequestedFps(30.0f) .build(); // 启动相机预览 preview.start(cameraSource); // 添加一个人脸检测器工具 FaceGraphic faceGraphic = new FaceGraphic(graphicOverlay); graphicOverlay.add(faceGraphic); // 设置人脸检测回调 faceDetector.setProcessor(new Detector.Processor<Face>() { @Override public void release() { graphicOverlay.clear(); } @Override public void receiveDetections(Detector.Detections<Face> detections) { // 获取人脸检测结果 SparseArray<Face> faces = detections.getDetectedItems(); if (faces.size() > 0) { Face face = faces.valueAt(0); // 更新人脸检测器工具 faceGraphic.update(face); } else { faceGraphic.setFace(null); } } }); } } ``` 5. 为了实现姿势检测,您需要在布局文件中添加一个ImageView用于显示姿势检测结果,并在Activity中实现姿势检测。以下是一个简单的示例: ``` public class MainActivity extends AppCompatActivity { private FirebaseVisionPoseDetector poseDetector; private ImageView poseImageView; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); poseImageView = findViewById(R.id.pose_image); // 创建一个姿势检测器 poseDetector = FirebaseVision.getInstance().getPoseDetector(); // 加载要检测的图像 Bitmap bitmap = BitmapFactory.decodeResource(getResources(), R.drawable.pose_image); // 创建一个FirebaseVisionImage对象 FirebaseVisionImage image = FirebaseVisionImage.fromBitmap(bitmap); // 进行姿势检测 poseDetector.detectInImage(image) .addOnSuccessListener(new OnSuccessListener<List<FirebaseVisionPose>>() { @Override public void onSuccess(List<FirebaseVisionPose> poses) { // 获取第一个姿势检测结果 FirebaseVisionPose pose = poses.get(0); // 获取姿势检测结果的角度 float leftShoulderAngle = pose.getPoseLandmark(FirebaseVisionPoseLandmark.LEFT_SHOULDER).getInFrameLikelihood(); float rightShoulderAngle = pose.getPoseLandmark(FirebaseVisionPoseLandmark.RIGHT_SHOULDER).getInFrameLikelihood(); // 根据角度更新姿势检测结果 if (leftShoulderAngle > 0.5 && rightShoulderAngle > 0.5) { poseImageView.setImageResource(R.drawable.correct_pose_image); } else { poseImageView.setImageResource(R.drawable.incorrect_pose_image); } } }) .addOnFailureListener(new OnFailureListener() { @Override public void onFailure(@NonNull Exception e) { // 处理姿势检测失败的情况 } }); } } ``` 这些是实现人脸识别和姿势检测的基本步骤。您可以根据您的需求进行更改和扩展。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Android-Developer

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值