Intenção da câmera Android

Respostas:

178
private static final int TAKE_PICTURE = 1;    
private Uri imageUri;

public void takePhoto(View view) {
    Intent intent = new Intent(MediaStore.ACTION_IMAGE_CAPTURE);
    File photo = new File(Environment.getExternalStorageDirectory(),  "Pic.jpg");
    intent.putExtra(MediaStore.EXTRA_OUTPUT,
            Uri.fromFile(photo));
    imageUri = Uri.fromFile(photo);
    startActivityForResult(intent, TAKE_PICTURE);
}

@Override
public void onActivityResult(int requestCode, int resultCode, Intent data) {
    super.onActivityResult(requestCode, resultCode, data);
    switch (requestCode) {
    case TAKE_PICTURE:
        if (resultCode == Activity.RESULT_OK) {
            Uri selectedImage = imageUri;
            getContentResolver().notifyChange(selectedImage, null);
            ImageView imageView = (ImageView) findViewById(R.id.ImageView);
            ContentResolver cr = getContentResolver();
            Bitmap bitmap;
            try {
                 bitmap = android.provider.MediaStore.Images.Media
                 .getBitmap(cr, selectedImage);

                imageView.setImageBitmap(bitmap);
                Toast.makeText(this, selectedImage.toString(),
                        Toast.LENGTH_LONG).show();
            } catch (Exception e) {
                Toast.makeText(this, "Failed to load", Toast.LENGTH_SHORT)
                        .show();
                Log.e("Camera", e.toString());
            }
        }
    }
}
Alexander Oleynikov
fonte
5
Isso funciona muito bem, embora você possa precisar de: private static int TAKE_PICTURE = 1;
Chris Rae
11
NÃO FUNCIONA NOS TELEFONES GALAXY S :(
UMAR-MOBITSOLUTIONS
1
Por que o 'android.media.action.IMAGE_CAPTURE' codificado. Pode não funcionar em alguns telefones. Existe um padrão para isso? Talvez algo em torno de Intent.ACTION_GET_CONTENT?
AlikElzin-kilaka de
7
@kilaka, MediaStore.ACTION_IMAGE_CAPTURE
Rob
2
Talvez você precise usar FileProviderno Android> M. Veja aqui
Nicolai Weitkemper
22

Tente o seguinte que encontrei aqui

Intent intent = new Intent("android.media.action.IMAGE_CAPTURE");
startActivityForResult(intent, 0);

@Override
public void onActivityResult(int requestCode, int resultCode, Intent data) {
  if (resultCode == Activity.RESULT_OK && requestCode == 0) {
    String result = data.toURI();
    // ...
  }
}
Ryan
fonte
2
Obrigado, mas a foto tirada não está sendo salva em um dispositivo, então estou obtendo FileNotFoundException em Uri uri = Uri.parse (data.toURI ()); bitmap = android.provider.MediaStore.Images.Media .getBitmap (contentResolver, uri);
Alexander Oleynikov
Você está dizendo que a foto que você tira não está sendo armazenada no telefone / dispositivo por sua escolha ou algo está acontecendo e mesmo que você diga para armazenar a imagem no seu telefone / dispositivo, ela age como se não estivesse salvando?
Ryan
Estou dizendo que a imagem não está sendo armazenada no dispositivo automaticamente, mas retorna como um bitmap em onActivityResult (). No entanto, encontrei uma solução que mencionarei em uma resposta.
Alexander Oleynikov
Esta é a melhor resposta. A primeira resposta salva uma duplicata desnecessária da imagem. Isso aparece no aplicativo de galeria do usuário como duas imagens em vez de uma, o que a maioria das pessoas considera um bug.
Thomas Dignan
7

Levei algumas horas para fazer isso funcionar. O código é quase um copiar e colar de developer.android.com , com uma pequena diferença.

Solicite esta permissão no AndroidManifest.xml:

<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />

Em seu Activity, comece definindo isto:

static final int REQUEST_IMAGE_CAPTURE = 1;
private Bitmap mImageBitmap;
private String mCurrentPhotoPath;
private ImageView mImageView;

Em seguida, dispare isso Intentem um onClick:

Intent cameraIntent = new Intent(MediaStore.ACTION_IMAGE_CAPTURE);
if (cameraIntent.resolveActivity(getPackageManager()) != null) {
    // Create the File where the photo should go
    File photoFile = null;
    try {
        photoFile = createImageFile();
    } catch (IOException ex) {
        // Error occurred while creating the File
        Log.i(TAG, "IOException");
    }
    // Continue only if the File was successfully created
    if (photoFile != null) {
        cameraIntent.putExtra(MediaStore.EXTRA_OUTPUT, Uri.fromFile(photoFile));
        startActivityForResult(cameraIntent, REQUEST_IMAGE_CAPTURE);
    }
}

Adicione o seguinte método de suporte:

private File createImageFile() throws IOException {
    // Create an image file name
    String timeStamp = new SimpleDateFormat("yyyyMMdd_HHmmss").format(new Date());
    String imageFileName = "JPEG_" + timeStamp + "_";
    File storageDir = Environment.getExternalStoragePublicDirectory(
            Environment.DIRECTORY_PICTURES);
    File image = File.createTempFile(
            imageFileName,  // prefix
            ".jpg",         // suffix
            storageDir      // directory
    );

    // Save a file: path for use with ACTION_VIEW intents
    mCurrentPhotoPath = "file:" + image.getAbsolutePath();
    return image;
}

Então receba o resultado:

@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
    if (requestCode == REQUEST_IMAGE_CAPTURE && resultCode == RESULT_OK) {
        try {
            mImageBitmap = MediaStore.Images.Media.getBitmap(this.getContentResolver(), Uri.parse(mCurrentPhotoPath));
            mImageView.setImageBitmap(mImageBitmap);
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}

O que o fez funcionar é o MediaStore.Images.Media.getBitmap(this.getContentResolver(), Uri.parse(mCurrentPhotoPath)), que é diferente do código de developer.android.com . O código original me deu um FileNotFoundException.

Albert Vila Calvo
fonte
O mesmo para mim. Você me salvou algumas horas, suponho. Alguma ideia de por que o código Android Dev está dando uma exceção de IO?
Coo de
0

Tente o seguinte que encontrei Aqui está um link

Se seu aplicativo for direcionado a M e superior e declarar que usa a permissão CAMERA que não é concedida, a tentativa de usar esta ação resultará em uma SecurityException.

EasyImage.openCamera(Activity activity, int type);

@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
    super.onActivityResult(requestCode, resultCode, data);

    EasyImage.handleActivityResult(requestCode, resultCode, data, this, new DefaultCallback() {
        @Override
        public void onImagePickerError(Exception e, EasyImage.ImageSource source, int type) {
            //Some error handling
        }

        @Override
        public void onImagesPicked(List<File> imagesFiles, EasyImage.ImageSource source, int type) {
            //Handle the images
            onPhotosReturned(imagesFiles);
        }
    });
}
Mohit Rathore
fonte
Nesta biblioteca não há como definir o caminho de saída para a foto e também existem alguns bugs, como me pareceu
Vlad
0

Eu encontrei uma maneira bem simples de fazer isso. Use um botão para abri-lo usando um on clicklistener para iniciar a função openc(), como este:

String fileloc;
private void openc()
{
    Intent takePictureIntent = new Intent(MediaStore.ACTION_IMAGE_CAPTURE);
    File f = null;
    try 
    {
        f = File.createTempFile("temppic",".jpg",getApplicationContext().getCacheDir());
        if (takePictureIntent.resolveActivity(getPackageManager()) != null)
        {               
            takePictureIntent.putExtra(MediaStore.EXTRA_OUTPUT,FileProvider.getUriForFile(profile.this, BuildConfig.APPLICATION_ID+".provider",f));
            fileloc = Uri.fromFile(f)+"";
            Log.d("texts", "openc: "+fileloc);
            startActivityForResult(takePictureIntent, 3);
        }
    } 
    catch (IOException e) 
    {
        e.printStackTrace();
    }
}

@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) 
{
    super.onActivityResult(requestCode, resultCode, data);
    if(requestCode == 3 && resultCode == RESULT_OK) {
        Log.d("texts", "onActivityResult: "+fileloc);
        // fileloc is the uri of the file so do whatever with it
    }
}

Você pode fazer o que quiser com a uristring de localização. Por exemplo, eu o envio para um cortador de imagem para cortar a imagem.

Aishik Kirtaniya
fonte
-3

tente este código

Intent photo= new Intent("android.media.action.IMAGE_CAPTURE");
                    startActivityForResult(photo, CAMERA_PIC_REQUEST);
anupam sharma
fonte
6
Esta postagem está sendo sinalizada automaticamente como de baixa qualidade porque é apenas um código. Você se importaria de expandi-lo adicionando algum texto para explicar como ele resolve o problema?
gung - Reintegração de Monica em