0

код моего фрагмента выглядит следующим образом:я не могу сохранить экземпляр фрагмента не перезагружать после поворота экрана

public class AllIssuesFragment extends Fragment { 

@Bind(R.id.list_all_issues) ListView mListAllIssues; 
IssuesGetter ai; 
ArrayAdapter<IssuesResponse.Issue> adapter; 

@Override 
public View onCreateView(LayoutInflater inflater, ViewGroup container, 
         Bundle savedInstanceState) { 
    View view = inflater.inflate(R.layout.fragment_all_issues, container, false); 
    return view; 
} 

@Override 
public void onViewCreated(View view, @Nullable Bundle savedInstanceState) { 
    super.onViewCreated(view, savedInstanceState); 
    ButterKnife.bind(this, view); 
    setRetainInstance(true); 

    SharedPreferences user_data = this.getActivity().getSharedPreferences("user_data", Context.MODE_PRIVATE); 
    UserManager.getInstance().setUsername(user_data.getString("username", null)); 
    UserManager.getInstance().setPassword(user_data.getString("password", null)); 

    if(UserManager.getInstance().getUsername() == null || UserManager.getInstance().getPassword() == null) { 
     Intent intent = new Intent(getActivity(), ChangeUserActivity.class); 
     startActivity(intent); 
    } 
    else { 
     adapter = new ArrayAdapter<>(getActivity(), android.R.layout.simple_list_item_1); 
     if(savedInstanceState == null) { 
      getIssues(Constants.URI + Constants.ISSUES + Constants.OFFSET + 0); 
     } 
     mListAllIssues.setOnScrollListener(new AbsListView.OnScrollListener() { 
      @Override 
      public void onScrollStateChanged(AbsListView absListView, int i) { 

      } 

      @Override 
      public void onScroll(AbsListView absListView, int firstVisible, int visibleCount, int totalCount) { 
       boolean loadMore = firstVisible + visibleCount >= totalCount; 

       if (loadMore && ai.getStatus() == AsyncTask.Status.FINISHED) { 
        getIssues(Constants.URI + Constants.ISSUES + Constants.OFFSET + totalCount); 
        mListAllIssues.setSelection(totalCount); 
       } 
      } 
     }); 
    } 
} 

private void getIssues(String url) { 
    ai = new IssuesGetter(new AsyncCallback<IssuesResponse>() { 
     @Override 
     public void onSuccess(IssuesResponse response) { 
      int index = mListAllIssues.getFirstVisiblePosition(); 
      View v = mListAllIssues.getChildAt(0); 
      int top = (v == null)? 0 : v.getTop(); 

      adapter.addAll(response.getIssues()); 
      adapter.notifyDataSetChanged(); 
      mListAllIssues.setAdapter(adapter); 
      mListAllIssues.setSelectionFromTop(index, top); 
     } 

     @Override 
     public void onError() { 
      Intent intent = new Intent(getActivity(), ChangeUserActivity.class); 
      startActivity(intent); 
     } 
    }); 
    ai.execute(url); 
} 
} 

MainActivity.java:

public class MainActivity extends AppCompatActivity { 


@Bind(R.id.viewpager) ViewPager viewPager; 
@Bind(R.id.tabs) PagerSlidingTabStrip tabStrip; 

@Override 
protected void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.activity_main); 
    ButterKnife.bind(this); 
    viewPager.setAdapter(new MainActivityPagerAdapter(getSupportFragmentManager())); 
    tabStrip.setViewPager(viewPager); 
} 

@Override 
public boolean onCreateOptionsMenu(Menu menu) { 
    // Inflate the menu; this adds items to the action bar if it is present. 
    getMenuInflater().inflate(R.menu.menu_main, menu); 
    return true; 
} 

@Override 
public boolean onOptionsItemSelected(MenuItem item) { 
    // Handle action bar item clicks here. The action bar will 
    // automatically handle clicks on the Home/Up button, so long 
    // as you specify a parent activity in AndroidManifest.xml. 
    int id = item.getItemId(); 

    //noinspection SimplifiableIfStatement 
    if (id == R.id.action_change_user) { 
     Intent intent = new Intent(this, ChangeUserActivity.class); 
     this.startActivity(intent); 
     return true; 
    } 

    return super.onOptionsItemSelected(item); 
} 
} 

Я пытался использовать setRetainInstance (true) и проверьте, что savedInstanceState равно null, но это не помогло решить мою проблему Эм. Я застрял :(

Мой AsyncTask возвращает результат с помощью обратного вызова

+0

Можете ли вы показать код активности, который использует этот фрагмент? – Nolan

+0

'private ArrayList cache;' then ... in 'getIssues' ... if' cache'! = Null, тогда установите из него адаптер ... if is null execute asynctask и установите 'cache' из ответа .getIssues() и установить адаптер ... точка в том, что фрагмент не работает с компонентами пользовательского интерфейса ... ** edit ** кажется, что вы используете пейджинг ... тогда это будет не так просто ... – Selvin

+0

@ Нолан, я добавил. –

ответ

0

Я вижу проблему здесь:..

public void onCreate() { 
    //.. 
    viewPager.setAdapter(new MainActivityPagerAdapter(getSupportFragmentManager())); 
    tabStrip.setViewPager(viewPager); 
} 

Этот метод вызывается каждый раз, когда активность воссоздан И что она делает это создает новый адаптер, который создает совершенно новые фрагменты.И это проблема.Так что ваша деятельность не контролирует создание фрагментов.Это необходимо для сохранения фрагментов.

Предлагаю вам сохранить состояние фрагмента в onSaveInstanceState() обратный вызов и восстановить его в onCreateView(). Обратите внимание, что вам не нужно сохранять состояние элементов пользовательского интерфейса только переменными класса фрагмента. Элементы пользовательского интерфейса автоматически сохраняют свое состояние, если у них есть уникальный идентификатор.

EDIT:

Мое предложение:

public class AllIssuesFragment extends Fragment { 
    private List<String> issues; 
    // .. 

    @Nullable 
    @Override 
    public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { 
     // .. 
     if (null != savedInstanceState) { 
      issues = savedInstanceState.getStringArray("issues"); 
     } else { 
      issues = new List<>(); 
     } 
     adapter = new ArrayAdapter<>(getActivity(), android.R.layout.simple_list_item_1, issues); 
     // .. 
    } 

    @Override 
    public void onSaveInstanceState(Bundle outState) { 
     super.onSaveInstanceState(outState); 
     outState.putStringArray("issues", issues); 
    } 

    private void getIssues(String url) { 
     // .. 
     ai = new IssuesGetter(new AsyncCallback<IssuesResponse>() { 
      @Override 
      public void onSuccess(IssuesResponse response) { 
       // .. 
       //adapter.addAll(response.getIssues()); 
       issues.addAll(response.getIssues()); 
       adapter.notifyDataSetChanged(); 
       // .. 
      } 
     }; 
     // .. 
    } 
} 
+0

Можете ли вы рассказать мне подробно, как я могу это сделать? –

+0

@VitalyRomaniv, трудно говорить о деталях без погружения в код. – Nolan

+0

ОК. Я должен переопределить onSaveInstanceState в AllIssuesFragment? Но как я могу сохранить состояние фрагмента? –