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

Основное занятие:

import android.content.Intent;
import android.os.Bundle;
import android.support.annotation.NonNull;
import android.support.design.widget.NavigationView;
import android.support.v4.view.GravityCompat;
import android.support.v4.widget.DrawerLayout;
import android.support.v7.app.ActionBarDrawerToggle;
import android.support.v7.app.AppCompatActivity;
import android.support.v7.widget.Toolbar;
import android.view.Menu;
import android.view.MenuItem;

public class MainActivity extends AppCompatActivity
    implements NavigationView.OnNavigationItemSelectedListener {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
        toolbar.setTitle(R.string.home);
        setSupportActionBar(toolbar);

        DrawerLayout drawer = (DrawerLayout) findViewById(R.id.drawer_layout);
        ActionBarDrawerToggle toggle = new ActionBarDrawerToggle(
            this, drawer, toolbar, R.string.navigation_drawer_open, R.string.navigation_drawer_close);
        drawer.addDrawerListener(toggle);
        toggle.syncState();

        NavigationView navigationView = (NavigationView) findViewById(R.id.nav_view);
        navigationView.setNavigationItemSelectedListener(this);

        getSupportFragmentManager().beginTransaction()
            .add(R.id.layout, new MainFragment())
            .commit();
   }

    @Override
    public void onBackPressed() {
        DrawerLayout drawer = (DrawerLayout) findViewById(R.id.drawer_layout);
        if (drawer.isDrawerOpen(GravityCompat.START)) {
            drawer.closeDrawer(GravityCompat.START);
        } else {
            if (getSupportFragmentManager().getBackStackEntryCount() > 0) {
                NavigationView navigationView = (NavigationView) findViewById(R.id.nav_view);
                navigationView.getMenu().findItem(R.id.nav_home).setChecked(true);
                getSupportFragmentManager().popBackStack();
            } else {
                super.onBackPressed();
            }
        }
    }

    @SuppressWarnings("StatementWithEmptyBody")
    @Override
    public boolean onNavigationItemSelected(@NonNull MenuItem item) {

        if (getSupportFragmentManager().getBackStackEntryCount() > 0) {
            getSupportFragmentManager().popBackStack();
        }

        switch (item.getItemId()) {
            case R.id.nav_history:
                getSupportFragmentManager().beginTransaction()
                    .replace(R.id.layout, new Fragment2())
                    .addToBackStack(null)
                    .commit();
                break;
            case R.id.nav_settings:
                break;
            case R.id.nav_logout:
                break;
        }

        DrawerLayout drawer = (DrawerLayout) findViewById(R.id.drawer_layout);
        drawer.closeDrawer(GravityCompat.START);
        return true;
    }
}

Основной фрагмент:

import android.os.AsyncTask;
import android.os.Bundle;
import android.support.annotation.Nullable;
import android.support.v4.app.Fragment;
import android.support.v7.widget.DividerItemDecoration;
import android.support.v7.widget.LinearLayoutManager;
import android.support.v7.widget.RecyclerView;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ProgressBar;
import android.widget.TextView;

import java.util.ArrayList;
import java.util.Date;
import java.util.List;

import br.com.example.adapters.ScheduledServicesAdapter;
import br.com.example.entities.ScheduledService;

public class MainFragment extends Fragment {


    private final class ScheduleServiceTask extends AsyncTask<Void, Void, List<ScheduledService>> {

        @Override
        protected List<ScheduledService> doInBackground(Void... params) {
            mList = new ArrayList<>();
            mList.add(new ScheduledService(new Date(), 250.50, 0));
            mList.add(new ScheduledService(new Date(), 50.75, 0));

            return mList;
        }

        @Override
        protected void onPostExecute(List<ScheduledService> scheduledServices) {
            super.onPostExecute(scheduledServices);
            setData(scheduledServices);
        }
    }

    private RecyclerView mRecyclerView;
    private ScheduledServicesAdapter mAdapter;
    private List<ScheduledService> mList;


    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup parent, Bundle savedInstanceState) {
        super.onCreateView(inflater, parent, savedInstanceState);
        return inflater.inflate(R.layout.content_main, parent, false);
    }

    @Override
    public void onViewCreated(View view, @Nullable Bundle savedInstanceState) {
        super.onViewCreated(view, savedInstanceState);


        LinearLayoutManager linearLayoutManager = new LinearLayoutManager(getActivity());
        DividerItemDecoration dividerItemDecoration = new DividerItemDecoration(getActivity(),
            linearLayoutManager.getOrientation());

        mRecyclerView = (RecyclerView) view.findViewById(R.id.recycler_view);
        mRecyclerView.setHasFixedSize(true);
        mRecyclerView.setLayoutManager(linearLayoutManager);
        mRecyclerView.addItemDecoration(dividerItemDecoration);

        new ScheduleServiceTask().execute();
    }

    private void setData(List<ScheduledService> list) {
        ProgressBar progressBar = (ProgressBar) getActivity().findViewById(R.id.progress_bar);
        progressBar.setVisibility(View.GONE);

        if (!list.isEmpty()) {
            mAdapter = new ScheduledServicesAdapter(list);
            mRecyclerView.setAdapter(mAdapter);
        } else {
            TextView emptyText = (TextView) getActivity().findViewById(R.id.empty_text);
            emptyText.setVisibility(View.VISIBLE);
        }
    }
}

Фрагмент 2 имеет вид текста приветствия в тестовом режиме.

1
Douglas Fornaro 25 Апр 2017 в 05:55

2 ответа

Лучший ответ
  1. Когда вы помещаете ваш MainFragment в BackStack (означает, что представление этого fragment не visible, потому что Fragment2 принимают экран), все виды, которые принадлежат ему, будут уничтожены.
  2. Затем, когда вы вернетесь к MainFragment из другого фрагмента, вы увидите MainFragment будет создан заново. Это означает, что onCreateView и onViewCreated будут позвонил снова.
  3. В вашем случае я предлагаю:

    • Переместить new ScheduleServiceTask().execute(); в onCreate или в другой метод (пример: requestGetData())
    • Init mAdapter и установите adapter для mRecyclerView в onViewCreated()
    • В методе setData() все, что вам нужно, это переустановить данные для mAdapter и вызвать функцию notifyDatasetChanged().
2
Phan Dinh Thai 25 Апр 2017 в 05:20

@Douglas Fomaro, лучше вы можете переместить ваши данные (mList) за пределы фрагмента. Поддержание класса DataManager, который содержит все значения данных вашего списка.

0
Magesh Pandian 25 Апр 2017 в 04:25
43600793