Сохранение пути к файлу изображения в переменной-члене? - PullRequest
0 голосов
/ 26 апреля 2020

Я пытаюсь создать простое приложение Контакт. Естественно, существует класс Contact с переменной-членом mCurrentPhotoPath. Деятельность, которая отвечает за создание контактов, имеет возможность выбрать изображение из галереи следующим образом:

  final Intent pickImage = new Intent(Intent.ACTION_GET_CONTENT);
  pickImage.setType("image/*")
  /*some code...*/
  galleryButton.setOnClickListener((View v) -> {
        startActivityForResult(pickImage, REQUEST_GALLERY_PHOTO);
    });

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

    if (requestCode == REQUEST_GALLERY_PHOTO && resultCode == RESULT_OK){
        photoTaken = true;

        Uri selectedImage = data.getData();
        Log.i("path", selectedImage.getPath()) //prints out: /document/image:292562
        mPhotoView.setImageURI(selectedImage);

Я могу отобразить выбранное изображение в ImageView (mPhotoView).

Однако, когда я пытаюсь установить Intent другим способом, я получаю полный путь, но я не могу воссоздать файл по этому пути, и я получаю FileNotFoundException.

final Intent pickImage = new Intent(Intent.ACTION_PICK,android.provider.MediaStore.Images.Media.EXTERNAL_CONTENT_URI);

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

        if (requestCode == REQUEST_GALLERY_PHOTO && resultCode == RESULT_OK){
            photoTaken = true;

             Uri selectedImage = data.getData();
             String[] filePathColumn = {MediaStore.Images.Media.DATA};

             if (selectedImage != null) {
                 Cursor cursor = getContentResolver().query(selectedImage, filePathColumn, null, null, null);
                 if (cursor != null) {
                      cursor.moveToFirst();

                      int columnIndex = cursor.getColumnIndex(filePathColumn[0]);
                      String picturePath = cursor.getString(columnIndex);
                      Log.i.("TAG", picturePath); //I get, /storage/emulated/0/Pictures/Viber/IMG-bbd54c96cc971a1700f92205937014c8-V.jpg
                      mPhotoFile = new File(picturePath);
                      cursor.close();
                      updatePhotoView(); //This method recreates image based on exact file path and witdh & height of ImageView where the picture is going to be placed;
                 }
            }

         }

Вот здесь updatePhotoView()

private void updatePhotoView(int imageWidth, int imageHeight) {
        if (mPhotoFile == null || !mPhotoFile.exists()) {
            mPhotoView.setImageDrawable(null);

        } else {
            Bitmap bitmap = PictureUtils.getScaledBitmap(mPhotoFile.getPath(),imageWidth, imageHeight); // imageWidth & imageHeight are member variables of actiivty...

            mPhotoView.setImageBitmap(bitmap);
        }
    }

Я почти уверен, что эта функция работает, потому что, когда я реализовал опцию для получения изображения с камеры (я создал файл с помощью getExternalFilesDir (), и в любой другой деятельности, когда я передал строковое значение mCurrentPhotoPath, getScaledBitmap() удалось воссоздать изображение).

Вот getScaledBitmap():

public static Bitmap getScaledBitmap(String path, int destWidth, int destHeight) {
        // Read in the dimensions of the image on disk
        BitmapFactory.Options options = new BitmapFactory.Options();
        options.inJustDecodeBounds = true;
        BitmapFactory.decodeFile(path, options);
        float srcWidth = options.outWidth;
        float srcHeight = options.outHeight;
        // Figure out how much to scale down by
        int inSampleSize = 1;
        if (srcHeight > destHeight || srcWidth > destWidth) {
            if (srcWidth > srcHeight) {
                inSampleSize = Math.round(srcHeight / destHeight);
            } else {
                inSampleSize = Math.round(srcWidth / destWidth);
            }
        }
        options = new BitmapFactory.Options();
        options.inSampleSize = inSampleSize;
        // Read in and create final bitmap
        return BitmapFactory.decodeFile(path, options);
}

1 Ответ

0 голосов
/ 27 апреля 2020

Просто если кто-нибудь наткнется на подобную проблему. Я решил проблему получения изображений с помощью библиотеки Glide. Посмотри, куча уроков. Я предполагаю, что эта load функция делает тяжелую работу в фоновом режиме. Великая вещь! Вот как выглядит код:

Glide.with(context)
                .load(imageFilePath)
                .apply(new RequestOptions().centerCrop())
                .override(imageView.getWidth(), imageView.getHeight())
                .into(imageView);
...