Выполнение действия после того, как пользователь захватил изображение

Я хочу выполнить действие после того, как пользователь захватил изображение. Но я вижу, что после того, как я захватил изображение, ничего не происходит. Я использую приведенный ниже код и CWAC-Camera library. Содержимое, записанное внутри onPictureTaken, — это действие, которое я хочу выполнить после того, как пользователь захватил изображение.

public class CameraActivity extends Activity implements Camera.PictureCallback {

private final String TAG_CAMERA_FRAGMENT = "camera_fragment";
private CameraPreview mCameraPreview;
ImageView switchToVideoOpen,camera;
private Boolean isVideoOpen = false;
CircleImageView togglePlay;
RelativeLayout actioncamera;
View blackTransparent;
byte[] datacamera;
@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.fragment_camera);
    switchToVideoOpen=(ImageView)findViewById(R.id.switchToVideoOpen);
    camera=(ImageView)findViewById(R.id.camera);
    togglePlay = (CircleImageView) findViewById(R.id.togglePlay);
    actioncamera = (RelativeLayout) findViewById(R.id.audio_actions_container);
    blackTransparent = findViewById(R.id.blacktreansparent);

    CameraFragment f = new CameraFragment();
    getFragmentManager().beginTransaction()
            .add(R.id.preview_view, f, TAG_CAMERA_FRAGMENT)
            .commit();

    f.setHost(new SimpleCameraHost(this));

    camera.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View view) {
            takePicture();
        }
    });
    switchToVideoOpen.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View view) {
            if (!isVideoOpen) {

                isVideoOpen = true;
                switchToVideoOpen.setImageResource(R.drawable.video_stop);
                camera.setImageResource(R.drawable.video_icon);
                setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_LANDSCAPE);
                takeVideo();
            }
            else{
                isVideoOpen = false;
                switchToVideoOpen.setImageResource(R.drawable.video_icon);
                camera.setImageResource(R.drawable.video_stop);
                stopVideo();
            }
        }
    });
}
@Override
public void onResume() {
    super.onResume();

}

private void takePicture() {
    CameraFragment f = (CameraFragment) getFragmentManager().findFragmentByTag(TAG_CAMERA_FRAGMENT);
    if (f != null && f.isVisible()) {
        f.takePicture();
    }
}
private void takeVideo() {

    CameraFragment f = (CameraFragment) getFragmentManager().findFragmentByTag(TAG_CAMERA_FRAGMENT);
    if (f != null && f.isVisible()) {
        try {
            f.record();
        } catch (Exception e) {

        }
    }
}
private void stopVideo() {

    CameraFragment f = (CameraFragment) getFragmentManager().findFragmentByTag(TAG_CAMERA_FRAGMENT);
    if (f != null && f.isVisible()) {
        try {
            f.stopRecording();
        } catch (Exception e) {

        }
    }
}

@Override
public void onPictureTaken(byte[] bytes, Camera camera) {
    String pictureFile = GFileUtils.getGCameraDir().getAbsolutePath()+"/"+
            G.getFileNameForGMedia(G.General.MEDIA_TYPE_PHOTO);
    if (pictureFile == null) {

        return;
    }
    blackTransparent.setVisibility(View.VISIBLE);
    actioncamera.setVisibility(View.VISIBLE);
    togglePlay.setVisibility(View.VISIBLE);
    datacamera=bytes;
}

}

person Community    schedule 03.06.2015    source источник


Ответы (1)


onPictureTaken() вызываться не будет, потому что библиотека так не работает.

В документации описано, как вы можете отменить сохранение фотографий и получить byte[] от камеру для того, чтобы делать то, что вы планируете делать. Это включает в себя создание собственного CameraHost (будь то с нуля или путем создания подкласса SimpleCameraHost) и переопределение saveImage(PictureTransaction, byte[]).

person CommonsWare    schedule 03.06.2015