фрагмент данных загружается каждый раз, когда вызывается фрагмент - PullRequest
0 голосов
/ 07 мая 2018

Я создаю приложение с нижней навигацией и извлекаю данные с помощью API. Я вызываю API и присваиваю значения методу listview in fragment in oncreateview. Но проблема в том, что этот метод выполняется каждый раз, и API получает данные каждый раз, когда вызывается фрагмент. Я хочу, чтобы данные загружались только один раз, когда фрагмент вызывается в первый раз, а в любое другое время просмотр списка должен просто отображать ранее загруженные данные, я не знаю, как это сделать, пожалуйста, помогите, если вы знаете какой-то другой способ сделать это.

вот как я называю фрагменты

    private BottomNavigationView.OnNavigationItemSelectedListener mOnNavigationItemSelectedListener
        = new BottomNavigationView.OnNavigationItemSelectedListener() {

    @Override
    public boolean onNavigationItemSelected(@NonNull MenuItem item) {
        android.app.FragmentManager manager = getFragmentManager();
        switch (item.getItemId()) {
            case R.id.navigation_schedule:
                Fragment scheduleFragment = new ScheduleFragment();
                    manager.beginTransaction().replace(R.id.main, scheduleFragment).commit();
                return true;
            case R.id.navigation_teams:
                Fragment teamFragment = new TeamFragment();
                manager.beginTransaction().replace(R.id.main, teamFragment).commit();
                return true;
            case R.id.navigation_champions:
                Fragment championsFragment = new ChampionsFragment();
                manager.beginTransaction().replace(R.id.main, championsFragment).commit();
                return true;
            case R.id.navigation_live:
                Fragment liveFragment = new LiveFragment();
                manager.beginTransaction().replace(R.id.main, liveFragment).commit();
                return true;
            case R.id.navigation_records:
                Fragment recordsFragment = new RecordsFragment();
                manager.beginTransaction().replace(R.id.main, recordsFragment).commit();
                return true;
        }
        return false;
    }
};

и вот как данные загружаются во фрагмент

public class ScheduleFragment extends Fragment {

private ListView lvSchedule;

customAdapterSchedule adapterSchedule;
List<BeanSchedule> listSchedule = new ArrayList<>();
float x1, x2, y1, y2;

private static final String url = "https://wc19.000webhostapp.com/ad/class/api.php?method=schedule";

public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);


}

public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
    View view = inflater.inflate(R.layout.fragment_schedule, null);

    lvSchedule = (ListView)view.findViewById(R.id.lvSchedule);





        adapterSchedule = new customAdapterSchedule(this.getContext(), listSchedule);
        lvSchedule.setAdapter(adapterSchedule);
        apiCall();

    return view;
}

public void apiCall(){
    JsonArrayRequest scheduleReq = new JsonArrayRequest(url,
            new Response.Listener<JSONArray>() {
                @Override
                public void onResponse(JSONArray response) {

                    for (int i = 0; i < response.length(); i++) {
                        try {
                            JSONObject obj = response.getJSONObject(i);
                            BeanSchedule schedule = new BeanSchedule();

                           schedule.setTeam1name(obj.getString("team1name"));
                            schedule.setTeam2name(obj.getString("team2name"));
                            schedule.setTeam2img(obj.getString("team2img"));
                            schedule.setTeam1img(obj.getString("team1img"));
                            schedule.setDate(obj.getString("date"));
                            if(obj.getString("daynight").equals("0"))
                                schedule.setDaynight(" ");
                            else
                                schedule.setDaynight("Day/Night");

                            // Genre is json array


                            // adding movie to movies array
                            listSchedule.add(schedule);

                        } catch (JSONException e) {
                            e.printStackTrace();
                          //  Toast.makeText(getActivity(),"inside catch",Toast.LENGTH_LONG);

                        }


                    }

                    // notifying list adapter about data changes
                    // so that it renders the list view with updated data
                    adapterSchedule.notifyDataSetChanged();
                }
            }, new Response.ErrorListener() {
        @Override
        public void onErrorResponse(VolleyError error) {


        }
    });

    AppController.getInstance().addToRequestQueue(scheduleReq);

}

}

1 Ответ

0 голосов
/ 07 мая 2018

Что мешает вам установить флаг после первоначального получения данных? Я не знаю, как выглядит ваш код, и ваш вопрос тоже не очень сложный, но что-то вроде этого должно работать:

boolean data_loaded_once = false;

и в функции обратного вызова API:

if(!data_loaded_once){
    data_loaded_once = true;
    // load data here
}

Как говорится, у вас, вероятно, вообще не должно быть этой проблемы.

РЕДАКТИРОВАТЬ: сохранить данные в другом месте: ListView адаптер (временный) или SQLite.

...