Обновление только текущего фрагмента окна просмотра - PullRequest
1 голос
/ 27 апреля 2020

У меня есть ViewPager с 200+ вкладками. Каждая вкладка включает просмотр повторного загрузчика с динамической загрузкой данных через модификацию2. Данные загружаются после каждого onTabSelected() действия.

Но из-за загрузки видового пейджера position-1 (if any), position, position+1 (if any) Я получаю 2-3 вкладки с одинаковыми данными.

Вопрос - как можно Я загружаю только один фрагмент, который в настоящий момент выбран без соседних позиций?

Я думал, что BEHAVIOR_RESUME_ONLY_CURRENT_FRAGMENT в моем FragmentPagerAdapter решит мою проблему, просто передав его конструктору:

public Adapter_programmes(FragmentManager fm, Context context) {
    super(fm, BEHAVIOR_RESUME_ONLY_CURRENT_FRAGMENT);
    mContext = context;
    fragment_some = new Fragment_Some();
}

но ничего не изменилось.

UPD: Мне кажется, я нашел решение здесь: Ограничение количества страниц в ViewPager

Но я не могу этого понять: загрузите вашу сетку с изображениями-заполнителями и не загружайте реальные изображения, пока страница не будет изменена.

** UPD2: ** setOffscreenPageLimit (1) сделал не решаю мою проблему.

Мой код:

Фрагмент:

public static Fragment_some newInstance(int page) {
    Bundle args = new Bundle();
    args.putInt(ARG_PAGE, page);
    Fragment_some fragment = new Fragment_some();
    fragment.setArguments(args);
    return fragment;
}

@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    if (getArguments() != null) {
        mPage = getArguments().getInt(ARG_PAGE);
    }
    arrayNames.clear();
    arrayTimes.clear();
}

@Override
public void onAttach(@NonNull Context context) {
    super.onAttach(context);
    mContext=context;
}

@Nullable
@Override
public View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
    Log.d(TAG, "");
    //creating fragment
    rootView = inflater.inflate(R.layout.content_list, container, false);

    loadProgrammes(CID); //doing retrofit query for data, using argument which I've got from onTabSelected by SharedPreferences
    //data loaded succecfully
    Handler handler = new Handler();
    handler.postDelayed(() -> {
    adapterItem = new Adapter_programme_item(mContext, arrayTimes, arrayNames);
    RecyclerView RV = rootView.findViewById(R.id.recycler_view);
    LinearLayoutManager layoutManager = new LinearLayoutManager(mContext);
    RV.setLayoutManager(layoutManager);
    RV.setAdapter(adapterItem);
            }, 3000);   //3 seconds waiting

    return rootView;
}

FragmentPagerAdapter:

    public Adapter_programmes(FragmentManager fm, Context context) {
    super(fm, BEHAVIOR_RESUME_ONLY_CURRENT_FRAGMENT);
    mContext = context;
    fragment_some = new Fragment_some();
}

@Override public int getCount() {
    return PAGE_COUNT;

}

@Override public Fragment getItem(int position) {


    return fragment_some.newInstance(position + 1);
}

@Override public CharSequence getPageTitle(int position) {
    return tabTitles[position];
}

public void updateTitleData(String[] titles) {
    ...
    notifyDataSetChanged();
}

MainActivity:

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    adapter = new Adapter_programmes(getSupportFragmentManager(), MainActivity.this);

    ViewPager viewPager = findViewById(R.id.viewpager);
    viewPager.setAdapter(adapter);

    TabLayout tabLayout = findViewById(R.id.tabs);
    tabLayout.setupWithViewPager(viewPager);

    loaderFromURL(); //getting tab titles via retrofit

    tabLayout.addOnTabSelectedListener(new TabLayout.OnTabSelectedListener() {
        @Override
        public void onTabUnselected(TabLayout.Tab tab) {

        }

        @Override
        public void onTabReselected(TabLayout.Tab tab) {

        }

        @Override
        public void onTabSelected(TabLayout.Tab tab) {
            Log.d(TAG, "onTabSelected");

            String mCID = listm3u.get(tab.getPosition()).getItemCID();
            AppPreferences.setCurrentCID(MainActivity.this, mCID);

            String iconURL = listm3u.get(tab.getPosition()).getItemIcon();
            ImageView IVChanelLogo = findViewById(R.id.IVChanelLogo);
            Picasso.with(MainActivity.this).load(iconURL).into(IVChanelLogo);

        }
    });
}

1 Ответ

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

Поскольку вы заполняете представление реселлера в onCreateView фрагмента, изменение на BEHAVIOR_RESUME_ONLY_CURRENT_FRAGMENT не окажет никакого влияния.

BEHAVIOR_RESUME_ONLY_CURRENT_FRAGMENT вместо того, чтобы привести текущий фрагмент +/- OffscreenPageLimit (по умолчанию 1) в состояние «Возобновлено», он переводит только текущий Фрагмент в состояние «Возобновление», а любой другой Фрагмент - в состояние «Запущено» в жизненном цикле фрагмента.

Поскольку «Запущено» прошло onCreateView ваши повторные просмотры заполняется слишком рано.

Решение во Фрагменте onCreateView. Создайте адаптер просмотра повторных обращений без данных в нем, найдите recyclerView, настройте его компоновщик и адаптер и т. д. c.

Затем в методе фрагмента onResume получите данные для recyclerView и обновите адаптер переработчика с этими новыми данными, затем уведомите RecyclerView об изменении данных.

Затем можно удалить материал onTabSelected

Недостаточно примера кода, чтобы привести рабочий пример, НО ниже приведен пример фрагмента, который показывает обновление textview2 с текущим временем, когда «Возобновлено» по сравнению с textview1, которое установлено, когда оно переводится в состояние «Запущено» (вы бы создали 3 копии этого фрагмента в Viewpager с установленным BEHAVIOR_RESUME_ONLY_CURRENT_FRAGMENT)

package com.test.viewpager;

import android.content.Context;
import android.os.Bundle;

import androidx.annotation.NonNull;
import androidx.annotation.Nullable;
import androidx.fragment.app.Fragment;

import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.TextView;

import java.text.DateFormat;
import java.text.SimpleDateFormat;
import java.util.Calendar;
import java.util.Locale;

public class TextFragment extends Fragment {
    // the fragment initialization parameters, e.g. ARG_ITEM_NUMBER
    private static final String ARG_PARAM1 = "param1";

    private int mParam1;
    private View view;


    public TextFragment() {
        // Required empty public constructor
    }

    public static TextFragment newInstance(int param1) {
        TextFragment fragment = new TextFragment();
        Bundle args = new Bundle();
        args.putInt(ARG_PARAM1, param1);
        fragment.setArguments(args);
        Log.d("Frag", "newInstance");
        return fragment;
    }

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        if (getArguments() != null) {
            mParam1 = getArguments().getInt(ARG_PARAM1);
        }
        Log.d("Frag", "onCreate");
    }

    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,
                             Bundle savedInstanceState) {
        // Inflate the layout for this fragment
        Log.d("Frag", "onCreateView:" + mParam1);
        view = inflater.inflate(R.layout.fragment_text, container, false);

        return view;
    }

    @Override
    public void onViewCreated(@NonNull View view, @Nullable Bundle savedInstanceState) {
        Log.d("Frag", "onViewCreated:" + mParam1);
        Bundle args = getArguments();
        TextView textView1 = view.findViewById(R.id.textview1);
        DateFormat df = new SimpleDateFormat("yyyy-MM-dd'T'HH-mm-ss.sss", Locale.US);
        String dt = df.format(Calendar.getInstance().getTime());
        textView1.setText(dt);
    }


    public void updateView(){
        Log.d("Frag", "updateView");
        TextView textView2 = view.findViewById(R.id.textview2);
        DateFormat df = new SimpleDateFormat("yyyy-MM-dd'T'HH-mm-ss.sss", Locale.US);
        String dt = df.format(Calendar.getInstance().getTime());
        textView2.setText(dt);
    }

    @Override
    public void onAttach(Context context) {
        super.onAttach(context);
        Log.d("Frag", "onAttach:" + mParam1);
    }

    @Override
    public void onDetach() {
        super.onDetach();
        Log.d("Frag", "onDetach:" + mParam1);
    }

    @Override
    public void onResume() {
        super.onResume();
        Log.d("Frag", "onResume:" + mParam1);
        updateView();
    }

    @Override
    public void onPause() {
        super.onPause();
        Log.d("Frag", "onPause:" + mParam1);
    }
}


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