Я запускаю базовое приложение распознавания лиц в режиме реального времени, и я рассчитываю, сколько раз оно обнаруживает лицо в классе FaceDetectionProcessor.java (используется как справочник -> https://github.com/firebase/quickstart-android/tree/master/mlkit/app/src/main/java/com/google/firebase/samples/apps/mlkit/java) и по определенное значение счетчика делает объект Activity с помощью объекта FaceDetectionProcessor.java для вызова метода для запуска нового действия, и там происходит сбой.
пробовал FaceDetectActivity.this, просто это, getApplicationContext (), даже глобальный объект Context, который устанавливает свое значение в "this" в onCreate () FaceDetectActivity
public class FaceDetectActivity extends AppCompatActivity implements ActivityCompat.OnRequestPermissionsResultCallback,CompoundButton.OnCheckedChangeListener{
private static final String FACE_DETECTION = "Face Detection";
private static final String TAG = "LivePreviewActivity";
private static final int PERMISSION_REQUESTS = 1;
private CameraSource cameraSource = null;
private CameraSourcePreview preview;
private GraphicOverlay graphicOverlay;
private String selectedModel = FACE_DETECTION;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
.
.
.
.
}
private void createCameraSource(String model) {
// If there's no existing cameraSource, create one.
if (cameraSource == null) {
cameraSource = new CameraSource(this, graphicOverlay);
}
try {
switch (model) {
case FACE_DETECTION:
Log.i(TAG, "Using Face Detector Processor");
cameraSource.setMachineLearningFrameProcessor(new FaceDetectionProcessor());
break;
default:
Log.e(TAG, "Unknown model: " + model);
}
} catch (Exception e) {
Log.e(TAG, "can not create camera source: " + model);
}
}
public void alertAndMove(){
Intent i=new Intent(FaceDetectActivity.this,SelectingParty.class);
startActivity(i);
}
public class FaceDetectionProcessor extends VisionProcessorBase<List<FirebaseVisionFace>> {
int count=0;
private static final String TAG = "FaceDetectionProcessor";
private final FirebaseVisionFaceDetector detector;
public FaceDetectionProcessor() {
FirebaseVisionFaceDetectorOptions options =
new FirebaseVisionFaceDetectorOptions.Builder()
.setClassificationMode(FirebaseVisionFaceDetectorOptions.ALL_CLASSIFICATIONS)
.enableTracking()
.build();
detector = FirebaseVision.getInstance().getVisionFaceDetector(options);
}
.
.
.
.
.
.
.
@Override
protected void onSuccess(
@NonNull List<FirebaseVisionFace> faces,
@NonNull FrameMetadata frameMetadata,
@NonNull GraphicOverlay graphicOverlay) {
graphicOverlay.clear();
for (int i = 0; i < faces.size(); ++i) {
FirebaseVisionFace face = faces.get(i);
FaceGraphic faceGraphic = new FaceGraphic(graphicOverlay);
graphicOverlay.add(faceGraphic);
faceGraphic.updateFace(face, frameMetadata.getCameraFacing());
Log.d(TAG, "onSuccess: Face detected and count= "+count);
count++;
if(count>=15)
new FaceDetectActivity().alertAndMove();
}
}
@Override
protected void onFailure(@NonNull Exception e) {
Log.e(TAG, "Face detection failed " + e);
}
}
при вызове нового FaceDetectActivity (). AlertAndMove () приложение вылетает в alertAndMove () в строке Intent i = новое Intent (FaceDetectActivity.this, ......)
Что очень огорчает ситуацию, так это то, что та же логика работала с тем же кодом, на моем ноутбуке друзей, где я изначально тестировал логику.