Установить фон изображения с помощью пути - PullRequest
0 голосов
/ 18 июня 2020

У меня есть ReyclerView, который показывает все изображения на телефоне пользователя. Я хочу разрешить выбирать только одно изображение за раз, и когда изображение выбрано, вокруг этого изображения появляется рамка, указывающая на выбор.

Я подготовил все, включая границу, которая появится вокруг изображения, однако, похоже, я не могу найти способ применить этот фон к выбранному изображению. onPhotoClick работает, и он успешно идентифицирует выбранное изображение. Но я не уверен, где отсюда go применять фон только к одному изображению за раз. У меня есть только путь.

Вот мой код:

SelectFileActivity. java

public class SelectFileActivity extends AppCompatActivity {

  RecyclerView recyclerView;
  GalleryAdapter galleryAdapter;
  List < String > images;

  private static final int REQUEST_CODE_STORAGE_PERMISSION = 101;

  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_select_file);

    // Remove status bar
    getWindow().addFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN);

    // Initialize content
    recyclerView = findViewById(R.id.recyclerview_gallery_images);

    // Check for permission
    if (ContextCompat.checkSelfPermission(SelectFileActivity.this,
        Manifest.permission.READ_EXTERNAL_STORAGE) != PackageManager.PERMISSION_GRANTED) {

      ActivityCompat.requestPermissions(SelectFileActivity.this,
        new String[] {
          Manifest.permission.READ_EXTERNAL_STORAGE
        }, REQUEST_CODE_STORAGE_PERMISSION);
    } else {
      loadImages();
    }
  }

  @Override
  public void onBackPressed() {
    startActivity(new Intent(this, HomeActivity.class));
    finish();
  }

  private void loadImages() {

    // All images will be same size
    recyclerView.setHasFixedSize(true);

    // Set the number of pictures per a row
    recyclerView.setLayoutManager(new GridLayoutManager(this, 3));

    images = SelectImagesGallery.listOfImages(this);
    galleryAdapter = new GalleryAdapter(this, images, new GalleryAdapter.PhotoListener() {
      @Override
      public void onPhotoClick(String path) {

        // Highlight the selected photo with a border
        Drawable highlight = getResources().getDrawable(R.drawable.background_highlight_border);
        I DO NOT KNOW WHAT TO PUT HERE.setBackground(highlight);

        Toast.makeText(SelectFileActivity.this, "" + path, Toast.LENGTH_SHORT).show();

        // Do something with the selected photo
      }
    });

    recyclerView.setAdapter(galleryAdapter);
  }

  @Override
  public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
    super.onRequestPermissionsResult(requestCode, permissions, grantResults);

    if (requestCode == REQUEST_CODE_STORAGE_PERMISSION) {
      if (grantResults[0] == PackageManager.PERMISSION_GRANTED) {

        loadImages();

      } else {
        Toast.makeText(this, "Permission Denied", Toast.LENGTH_SHORT).show();
      }
    }
  }
}

GalleryAdapter. java

public class GalleryAdapter extends RecyclerView.Adapter < GalleryAdapter.ViewHolder > {

  private Context context;
  private List < String > images;
  protected PhotoListener photoListener;

  public GalleryAdapter(Context context, List < String > images, PhotoListener photoListener) {
    this.context = context;
    this.images = images;
    this.photoListener = photoListener;
  }

  @NonNull
  @Override
  public ViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
    return new ViewHolder(
      LayoutInflater.from(context).inflate(R.layout.gallery_item, parent, false)
    );
  }

  @Override
  public void onBindViewHolder(@NonNull ViewHolder holder, int position) {

    String image = images.get(position);

    // Load images to Glide
    Glide.with(context)
      .load(image)
      .transform(new CenterCrop(), new RoundedCorners(30))
      .into(holder.image);

    holder.itemView.setOnClickListener(new View.OnClickListener() {
      @Override
      public void onClick(View view) {
        photoListener.onPhotoClick(image);
      }
    });
  }

  @Override
  public int getItemCount() {
    return images.size();
  }

  public class ViewHolder extends RecyclerView.ViewHolder {

    ImageView image;

    public ViewHolder(@NonNull View itemView) {
      super(itemView);
      image = itemView.findViewById(R.id.image);
    }
  }

  public interface PhotoListener {
    void onPhotoClick(String path);
  }
}

Ответы [ 2 ]

1 голос
/ 18 июня 2020

Создайте переменную selectedPosition типа int для сохранения элемента, по которому был выполнен щелчок.

Теперь обновите свой onBindViewHolder, чтобы применить фон к выбранному изображению. Вы можете установить позицию внутри OnClickListener и вызвать notifyDataSetChanged ().

Код:

public class GalleryAdapter extends RecyclerView.Adapter < GalleryAdapter.ViewHolder > {

        //rest of the code 
        private int selectedPos = 0;
        // rest of the code

  @Override
  public void onBindViewHolder(@NonNull ViewHolder holder, int position) {

    String image = images.get(position);

    // Load images to Glide
    Glide.with(context)
      .load(image)
      .transform(new CenterCrop(), new RoundedCorners(30))
      .into(holder.image);

    if(selectedPos == position)
      holder.image.setBackgroundResource(R.drawable.background_highlight_border);

    holder.itemView.setOnClickListener(new View.OnClickListener() {
      @Override
      public void onClick(View view) {
        photoListener.onPhotoClick(image);
        selectedPos = getAdapterPosition()
        notifyDataSetChanged()
      }
    });


  }

    }
1 голос
/ 18 июня 2020

вам не нужно использовать интерфейс здесь, поскольку у вас нет ссылки для выбранного представления изображения в SelectFileActivity. Но вот так легко это сделать. Добавьте этот код в свой onClickListener

holder.itemView.setOnClickListener(new View.OnClickListener() {
  @Override
  public void onClick(View view) {
    holder.image.setBackgroundResource(R.drawable.background_highlight_border);
  }
});
...