Jen*_*jdn 5 android image-processing android-imageview android-camerax google-mlkit
我有一个简单的布局:
<RelativeLayout
android:id="@+id/myP"
android:layout_width="match_parent"
android:layout_height="match_parent"
>
<androidx.camera.view.PreviewView
android:id="@+id/mPreviewView"
android:layout_width="match_parent"
android:layout_height="match_parent"/>
<com.example.dochjavatestimplementation.pkgActivity.ExtendedImageView
android:id="@+id/imageViewOmgShowIt"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:visibility="visible" />
</RelativeLayout>
Run Code Online (Sandbox Code Playgroud)
previewView 用于显示相机,ExtendedImageView 用于显示显示找到的对象 rect。
我的图像分析器:
imageAnalysis = new ImageAnalysis.Builder()
.setTargetResolution(new Size(mPreviewView.getWidth(),mPreviewView.getHeight()))
.build();
imageAnalysis.setAnalyzer(executor, new PaperImageAnalyser());
Run Code Online (Sandbox Code Playgroud)
纸图像分析器:
public class PaperImageAnalyser implements ImageAnalysis.Analyzer {
ObjectDetectorOptions options = new ObjectDetectorOptions.Builder()
.setDetectorMode(ObjectDetectorOptions.STREAM_MODE)
.enableClassification() // Optional
.build();
ObjectDetector objectDetector = ObjectDetection.getClient(options);
@Override
public void analyze(@NonNull ImageProxy imageProxy) {
@SuppressLint("UnsafeExperimentalUsageError") Image mediaImage = imageProxy.getImage();
if (mediaImage != null) {
InputImage image =InputImage.fromMediaImage(mediaImage, imageProxy.getImageInfo().getRotationDegrees());
objectDetector.process(image)
.addOnSuccessListener(
new OnSuccessListener<List<DetectedObject>>() {
@Override
public void onSuccess(List<DetectedObject> detectedObjects) {
for (DetectedObject detectedObject : detectedObjects) {
Rect boundingBox = detectedObject.getBoundingBox();
CameraImp.imageViewOmgShowIt.drawFoundObj(boundingBox);
}
}
})
.addOnFailureListener(
new OnFailureListener() {
@Override
public void onFailure(@NonNull Exception e) {
Log.e("error",""+e.getMessage());
}
})
.addOnCompleteListener(new OnCompleteListener<List<DetectedObject>>() {
@SuppressLint("UnsafeExperimentalUsageError")
@Override
public void onComplete(@NonNull Task<List<DetectedObject>> task) {
imageProxy.getImage().close();
imageProxy.close();
}
});
}
}
}
Run Code Online (Sandbox Code Playgroud)
绘制矩形:
public void drawFoundObj(Rect boundingBox) {
foundYo = boundingBox;
invalidate(); //call draw
}
Run Code Online (Sandbox Code Playgroud)
和
Paint mPaint = new Paint();
Canvas mCanvas = new Canvas();
@Override
protected void onDraw(Canvas canvas) {
//clear exsisting rects
Xfermode x = mPaint.getXfermode();
mPaint.setXfermode(new PorterDuffXfermode(PorterDuff.Mode.CLEAR));
mPaint.setXfermode(x);
mCanvas.drawPaint(mPaint);
//set current rect
Paint paint = new Paint();
paint.setColor(Color.YELLOW);
paint.setStrokeWidth(3);
paint.setAlpha(40);
canvas.drawRect(foundYo,paint);
}
Run Code Online (Sandbox Code Playgroud)
结果如下所示:
正如您所看到的,问题是尽管物体以某种方式被识别,但与物体的位置相比,坐标是错误的。
原因可能是什么?
我从 imageanalyzer 接收到的图像分辨率是否更小,从而导致坐标更小从而更错误?
还是我画错了?
小智 1
您将需要获取分析图像的宽度和高度,并将边界框转换为正确的尺寸以供显示。请参考 mlkit Vision_quickstart 中的示例作为参考。https://github.com/googlesamples/mlkit/blob/74d5edb101d1e2fb8bd404c41a684b71a06d507a/android/vision-quickstart/app/src/main/java/com/google/mlkit/vision/demo/java/CameraXLivePreviewActivity.java#L421
| 归档时间: |
|
| 查看次数: |
74 次 |
| 最近记录: |