android.content.Context.getPackageName () 'для пустой ссылки на объект при попытке доступа к методу в действии через класс Java - PullRequest
0 голосов
/ 16 апреля 2019

Я запускаю базовое приложение распознавания лиц в режиме реального времени, и я рассчитываю, сколько раз оно обнаруживает лицо в классе 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, ......)

Что очень огорчает ситуацию, так это то, что та же логика работала с тем же кодом, на моем ноутбуке друзей, где я изначально тестировал логику.

1 Ответ

0 голосов
/ 16 апреля 2019

В FaceDetectActivity я отправил Intent и контекст в FaceDetectionProcessor.java:

case FACE_DETECTION:
                    Log.i(TAG, "Using Face Detector Processor");
                    Intent i=new Intent( this,SelectingParty.class);
                    cameraSource.setMachineLearningFrameProcessor(new FaceDetectionProcessor(this,i));
                    break;

А в конструкторе FaceDetectionProcessor.java я инициализировал экземпляр Context obj и намерение Intent следующим образом:

public FaceDetectionProcessor(Context obj, Intent intent) {
        this.obj=obj;
        this.intent=intent;
.
.
.

Наконец, в методе onSuccess в FaceDetectionProcessor.java я сделал:

if(count>=15){
                obj.startActivity(intent);
            }

Вот и все!Однако я все еще не могу закрыть предыдущие действия, любые комментарии, предлагающие, как я мог бы достичь, очень помогли бы!PS Я пробовал CLEAR_TASK, CLEAR_TOP, NEW_TASK, не работал, но я мог что-то упустить.

...