Zamiar aparatu w systemie Android

Odpowiedzi:

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
źródło
5
Działa to świetnie, chociaż możesz potrzebować: private static int TAKE_PICTURE = 1;
Chris Rae,
11
NIE
DZIAŁA NA TELEFONACH
1
Dlaczego na stałe zakodowany „android.media.action.IMAGE_CAPTURE”. Może nie działać na niektórych telefonach. Czy jest na to norma? Może coś wokół Intent.ACTION_GET_CONTENT?
AlikElzin-kilaka
7
@kilaka, MediaStore.ACTION_IMAGE_CAPTURE
Rob
2
Może być konieczne użycie FileProviderw systemie Android> M. Zobacz tutaj
Nicolai Weitkemper,
22

Spróbuj tego, co znalazłem tutaj

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
źródło
2
Dzięki, ale zrobione zdjęcie nie jest zapisywane na urządzeniu, więc otrzymuję wyjątek FileNotFoundException w Uri uri = Uri.parse (data.toURI ()); bitmap = android.provider.MediaStore.Images.Media .getBitmap (contentResolver, uri);
Alexander Oleynikov
Czy mówisz, że zdjęcie, które robisz, nie jest przechowywane w telefonie / urządzeniu według Twojego wyboru lub coś się dzieje i nawet jeśli każesz mu przechowywać obraz na telefonie / urządzeniu, zachowuje się tak, jakby nie zapisywał?
Ryan
Mówię, że obraz nie jest automatycznie zapisywany na urządzeniu, ale wraca jako bitmapa w onActivityResult (). Jednak znalazłem rozwiązanie, o którym wspomnę w odpowiedzi.
Alexander Oleynikov
To jest lepsza odpowiedź. Najlepsza odpowiedź zapisuje niepotrzebną kopię obrazu. Pojawia się w aplikacji galerii użytkownika jako dwa obrazy zamiast jednego, co większość ludzi uważa za błąd.
Thomas Dignan
7

Zajęło mi to kilka godzin, zanim to zadziałało. Kod to prawie skopiuj i wklej z developer.android.com , z niewielką różnicą.

Poproś o to pozwolenie na AndroidManifest.xml:

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

Na własną Activityrozpocząć od zdefiniowania tego:

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

Następnie odpal to Intentw 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);
    }
}

Dodaj następującą metodę wsparcia:

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;
}

Następnie otrzymaj wynik:

@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();
        }
    }
}

To, co sprawiło, że zadziałało, to MediaStore.Images.Media.getBitmap(this.getContentResolver(), Uri.parse(mCurrentPhotoPath)), co różni się od kodu z developer.android.com . Oryginalny kod dał mi plik FileNotFoundException.

Albert Vila Calvo
źródło
Dla mnie to samo. Pewnie zaoszczędziłeś mi kilka godzin. Masz jakiś pomysł, dlaczego kod Android Dev zawiera wyjątek we / wy?
Coo
0

Spróbuj tego, co znalazłem Oto link

Jeśli Twoja aplikacja jest przeznaczona dla M i nowszych i deklaruje, że używa uprawnienia CAMERA, które nie zostało przyznane, próba użycia tej akcji spowoduje wystąpienie 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
źródło
W tej bibliotece nie ma sposobu, aby ustawić ścieżkę wyjściową dla zdjęcia i są też pewne błędy, jak mi się wydawało
Vlad,
0

Znalazłem dość prosty sposób, aby to zrobić. Użyj przycisku, aby go otworzyć, używając on clickdetektora do uruchomienia funkcji openc(), na przykład:

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
    }
}

Możesz zrobić, co chcesz, z uriciągiem lokalizacji. Na przykład wysyłam go do narzędzia do przycinania obrazu, aby przyciąć obraz.

Aishik kirtaniya
źródło
-3

wypróbuj ten kod

Intent photo= new Intent("android.media.action.IMAGE_CAPTURE");
                    startActivityForResult(photo, CAMERA_PIC_REQUEST);
anupam sharma
źródło
6
Ten post jest automatycznie oznaczany jako niskiej jakości, ponieważ zawiera tylko kod. Czy możesz go rozszerzyć, dodając trochę tekstu wyjaśniającego, jak rozwiązuje problem?
gung - Przywróć Monikę