ошибка во время выполнения, но пошаговая отладка работает нормально - PullRequest
0 голосов
/ 30 августа 2011

Я написал программу для Android, чтобы сделать снимок без предварительного просмотра. Мои программы работают нормально, когда я отлаживаю его шаг за шагом. Однако, когда я запускаю его в режиме выполнения, программа не работает должным образом. Изображение не сохраняется, и программа не может закончить. Кроме того, я не могу использовать свою камеру в других приложениях для Android (например, Камера, Видеокамера), пока я не перезагружу свой телефон. У кого-нибудь есть идеи по этой проблеме? Код для фотографирования и регистрации ошибок следующий:

Код для фотографирования:

    SurfaceView view = new SurfaceView(this);
    mCamera = Camera.open();
    Camera.Parameters p = mCamera.getParameters();
    p.setPictureFormat(PixelFormat.JPEG);
    mCamera.setParameters(p);

    try {
        mCamera.setPreviewDisplay(view.getHolder());
        mCamera.startPreview();
        mCamera.takePicture(null, null, mPictureCallback);
        mCamera.stopPreview();
        mCamera.unlock();
        mCamera.release();
    } catch (Exception e) {
        mCamera.stopPreview();
        mCamera.release();
        e.printStackTrace();            
    }

Функция обратного вызова

Camera.PictureCallback mPictureCallback = new Camera.PictureCallback() {
          public void onPictureTaken(byte[] imageData, Camera c) {
               if (imageData != null) {
            StoreByteImage(mContext, imageData, 50,
                    "ImageName");
            finish();
        }
    }
};
}

Сообщенные ошибки по logcat:

ERROR/Adreno200-ES20(130): rb verson is SBA #24
ERROR/mm-camera(130): prepare snapshot: Aec not settle
ERROR/CameraService(130): mHardware->setOverlay() failed with status -2147483648
ERROR/mm-camera(130): camera_issue_command: get_picture error (Connection timed out): length 36, status 0 FD: 20 1
ERROR/QualcommCameraHardware3D(130): getPicture: CAMERA_OPS_GET_PICTURE ioctl failed!
ERROR/NotificationService(292): adbEnabled = false
ERROR/NotificationService(292): adbEnabled = true

Кто-нибудь может дать какое-нибудь предложение? Заранее спасибо

1 Ответ

0 голосов
/ 30 августа 2011

это у вас работает?

Intent intent = new Intent(MediaStore.ACTION_IMAGE_CAPTURE);
            File file = new File(Environment.getExternalStorageDirectory(),
                    currentTimeString + ".jpg");
            outputFileUri = Uri.fromFile(file);
            intent.putExtra(MediaStore.EXTRA_OUTPUT, outputFileUri);
            startActivityForResult(intent, TAKE_PICTURE);
...