Получить элемент полностью видимым или нет в адаптере Recyclerview - PullRequest
0 голосов
/ 25 апреля 2018

Я делаю приложение для Android, в котором RecyclerView состоит из списка GIF-файлов. Теперь я хочу разработать такую ​​функциональность, например, когда элемент GIF полностью становится видимым для пользователя, а затем начинает загружаться, как только он слегка теряет фокусПользователь должен прекратить загрузку.

Я отобразил GIF в окне реселлера, теперь осталась только одна часть - как получить, чтобы такой GIF был полностью видимым или терял фокус.Мне нужен такой код внутри адаптера, который указывает, что этот элемент полностью виден, и этот элемент теряет фокус.

МОЙ класс адаптера

public class FeedAdapter extends RecyclerView.Adapter<FeedAdapter.MyViewHolder> {


private List<FeedModel> feedList;
Context context;

@Override
public MyViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
    View itemView = LayoutInflater.from(parent.getContext())
            .inflate(R.layout.single_item, parent, false);

    return new MyViewHolder(itemView);
}

@Override
public void onBindViewHolder(final MyViewHolder holder, int position) {
    holder.setData(feedList.get(position));

    new GifDataDownloader() {
        @Override
        protected void onPostExecute(final byte[] bytes) {
            holder.gifImageView.setBytes(bytes);
            holder.gifImageView.startAnimation();
        }
    }.execute(feedList.get(position).getUrl());


}

public FeedAdapter(Context context, List<FeedModel> feedList) {
    this.feedList = feedList;
    this.context = context;
}

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

public void setGridData(ArrayList<FeedModel> feedList) {
    this.feedList = feedList;
    notifyDataSetChanged();
}

public class MyViewHolder extends RecyclerView.ViewHolder  {

    FeedModel item;
    GifImageView gifImageView;
    public MyViewHolder(View itemView) {
        super(itemView);
        gifImageView = itemView.findViewById(R.id.gifImageView);
    }

    public void setData(FeedModel item) {
        this.item = item;
    }
}

Моя активность

public class MainActivity extends AppCompatActivity {
ImageView imageView;
ImageView imageView1;
private PendingIntent pendingIntent;
RecyclerView recyclerView;
FeedAdapter mAdapter;
ProgressBar progressBar;
GridLayoutManager manager;
Spinner countrySpinner;
ArrayList<FeedModel> feedList;

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

    feedList = new ArrayList<>(10);
    for (int i = 0; i < 10; i++) {
        FeedModel feedModel = new FeedModel();
        feedModel.setUrl("https://media.tenor.com/images/925bfbaad2f947987bcf18b9167b3326/tenor.gif");
        feedList.add(feedModel);
    }


    recyclerView = (RecyclerView) findViewById(R.id.recycler_view);
    mAdapter = new FeedAdapter(getApplicationContext(), feedList);
    manager = new GridLayoutManager(getApplicationContext(), 1, GridLayoutManager.VERTICAL, false);
    recyclerView.setLayoutManager(manager);
    recyclerView.setItemAnimator(new DefaultItemAnimator());
    recyclerView.setVisibility(View.VISIBLE);
    recyclerView.setAdapter(mAdapter);

}

Ответы [ 2 ]

0 голосов
/ 25 апреля 2018

Лучший способ использовать глиссаду, чтобы показать изображение, gif и т. Д. Это все старшее, что вы определяете.

Добавить указанную ниже зависимость в файл gradle уровня приложения

    implementation 'com.github.bumptech.glide:glide:4.7.1'

затем после использования в адаптере следующим образом.

private Context context;
  // define context into constructor 
  public RecyclerviewAdapter(List<StepsItem> stepsItems, Context context) {
    this.stepsItems = stepsItems;
    this.context = context;
}

 Glide.with(context).load(yoururl).into(holder.mIvIcon);
0 голосов
/ 25 апреля 2018

Запустите gif после того, как ваше представление создано, как в методе onstart() И если вы хотите остановить gif, когда пользователь больше не взаимодействует с приложением, остановите gif в методе onpause().

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...