Muszę przenieść intencję do domyślnej aplikacji aparatu, aby zrobić zdjęcie, zapisać je i zwrócić identyfikator URI. Czy jest na to sposób?
android
android-camera
android-camera-intent
Alexander Oleynikov
źródło
źródło
Odpowiedzi:
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()); } } } }
źródło
FileProvider
w systemie Android> M. Zobacz tutajSpró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(); // ... } }
źródło
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ą
Activity
rozpocząć od zdefiniowania tego:static final int REQUEST_IMAGE_CAPTURE = 1; private Bitmap mImageBitmap; private String mCurrentPhotoPath; private ImageView mImageView;
Następnie odpal to
Intent
wonClick
: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 plikFileNotFoundException
.źródło
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); } }); }
źródło
Znalazłem dość prosty sposób, aby to zrobić. Użyj przycisku, aby go otworzyć, używając
on click
detektora do uruchomienia funkcjiopenc()
, 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
uri
ciągiem lokalizacji. Na przykład wysyłam go do narzędzia do przycinania obrazu, aby przyciąć obraz.źródło
wypróbuj ten kod
Intent photo= new Intent("android.media.action.IMAGE_CAPTURE"); startActivityForResult(photo, CAMERA_PIC_REQUEST);
źródło