2017-04-14 92 views
0

我有一個tabpayout與viewpager與5片段,我不知道爲什麼,但在第五個片段時,當我使用getActivity(),即使在onActivityCreated後它返回null,當在其他片段我在onCreateView中使用它,它工作正常。片段getActivity爲空onActivityCreated with viewPager

我的第五片段:

public class SettingsFragment extends Fragment { 

private static final String ARG_SECTION_NUMBER = "section_number"; 
private TextView name,losed_bg,winned_bg,played_bg; 
private DatabaseReference mdatabase; 
private FirebaseAuth mAuth; 
private CircleImageView userpic; 
private static final int CAMERA=0,GALLERY=1; 
private Typeface font; 
private Button logout; 
private ProgressBar loading; 
private ImageView edit_image; 
private EditText edit_text; 
private AlertDialog.Builder getImageFrom; 

public SettingsFragment() { 
} 

public static SettingsFragment newInstance(int sectionNumber) { 
    SettingsFragment fragment = new SettingsFragment(); 
    Bundle args = new Bundle(); 
    args.putInt(ARG_SECTION_NUMBER, sectionNumber); 
    fragment.setArguments(args); 
    return fragment; 
} 

@Override 
public void onActivityCreated(@Nullable Bundle savedInstanceState) { 
    super.onActivityCreated(savedInstanceState); 

    mdatabase= FirebaseDatabase.getInstance().getReference().child("USERS").child(mAuth.getCurrentUser().getUid()); 

    mdatabase.addValueEventListener(new ValueEventListener() { 
     @Override 
     public void onDataChange(DataSnapshot dataSnapshot) { 
      name.setText(dataSnapshot.child("name").getValue(String.class)); 

      if(dataSnapshot.hasChild("losed")){ 

        //CRASH String spannable = getActivity().getString(R.string.settings_losed)+" "+String.valueOf(dataSnapshot.child("losed").getValue(Integer.class)); 
        losed_bg.setText(spannable); 
      } 
      else{ 

        String spannable =getActivity().getString(R.string.settings_losed)+" "+String.valueOf(0); 
        losed_bg.setText(spannable); 

      } 

      if(dataSnapshot.hasChild("winned")){ 
        String spannable = getActivity().getString(R.string.settings_winned)+" "+String.valueOf(dataSnapshot.child("winned").getValue(Integer.class)); 
        winned_bg.setText(spannable); 

      } 
      else{ 
        String spannable = getActivity().getString(R.string.settings_winned) + " " + String.valueOf(0); 
        winned_bg.setText(spannable); 

      } 

      if(dataSnapshot.hasChild("played")){ 
        String spannable = getActivity().getString(R.string.settings_played) + " " + String.valueOf(dataSnapshot.child("played").getValue(Integer.class)); 
        played_bg.setText(spannable); 

      } 
      else{ 
        String spannable = getActivity().getString(R.string.settings_played) + " " + String.valueOf(0); 
        played_bg.setText(spannable); 

      } 
      if(dataSnapshot.child("profile_pic").getValue(String.class)!=null) { 

       getImage(); 
      } 
      else{ 
       loading.setVisibility(View.INVISIBLE); 
       userpic.setVisibility(View.VISIBLE); 
       userpic.setOnClickListener(new View.OnClickListener() { 
        @Override 
        public void onClick(View view) { 
         getImageFrom.show(); 

        } 
       }); 
      } 
     } 

     @Override 
     public void onCancelled(DatabaseError databaseError) { 

     } 
    }); 

} 

}

我越來越

java.lang.IllegalStateException: Fragment SettingsFragment{3ee8ade} not attached to Activity 

而且在那裏我建立了tabLayout

public class SectionsPagerAdapter extends FragmentPagerAdapter { 

    public SectionsPagerAdapter(FragmentManager fm) { 
     super(fm); 
    } 

    @Override 
    public Fragment getItem(int position) { 

     // getItem is called to instantiate the fragment for the given page. 
     // Return a PlaceholderFragment (defined as a static inner class below). 
     switch (position){ 
      case 0: 
       return MainFragment.newInstance(0); 
      case 1: 
       return GamesFragment.newInstance(0); 
      case 2: 
       return OfflineFragment.newInstance(0); 
      case 3: 
       return FactoryFragment.newInstance(0); 
      case 4: 
       return SettingsFragment.newInstance(0); 
     } 

     return MainFragment.newInstance(position + 1); 
    } 

    @Override 
    public int getCount() { 

     return 5; 
    } 

    @Override 
    public CharSequence getPageTitle(int position) { 

     return null; 
    } 
} 

mSectionsPagerAdapter = new SectionsPagerAdapter(getSupportFragmentManager()); 
       // Set up the ViewPager with the sections adapter. 
       mViewPager = (ViewPager) findViewById(R.id.container); 
       mViewPager.setAdapter(mSectionsPagerAdapter); 
       tabLayout = (TabLayout) findViewById(R.id.tabs); 
       tabLayout.setupWithViewPager(mViewPager); 

       for (int i = 0; i < tabLayout.getTabCount(); i++) { 
        switch (i){ 
         case 0: 
          View view1 = getLayoutInflater().inflate(R.layout.tab_icon_view, null); 
          view1.findViewById(R.id.icon).setBackgroundResource(R.drawable.ic_home_white_48dp); 
          tabLayout.getTabAt(i).setCustomView(view1); 
          break; 
         case 3: 
          View view2 = getLayoutInflater().inflate(R.layout.tab_icon_view, null); 
          view2.findViewById(R.id.icon).setBackgroundResource(R.drawable.factory); 
          tabLayout.getTabAt(i).setCustomView(view2); 
          break; 
         case 1: 
          View view3 = getLayoutInflater().inflate(R.layout.tab_icon_view, null); 
          view3.findViewById(R.id.icon).setBackgroundResource(R.drawable.games_icon); 
          tabLayout.getTabAt(i).setCustomView(view3); 
          break; 
         case 2: 
          View view5 = getLayoutInflater().inflate(R.layout.tab_icon_view, null); 
          view5.findViewById(R.id.icon).setBackgroundResource(R.drawable.nointernet); 
          tabLayout.getTabAt(i).setCustomView(view5); 
          break; 
         case 4: 
          View view4 = getLayoutInflater().inflate(R.layout.tab_icon_view, null); 
          view4.findViewById(R.id.icon).setBackgroundResource(R.drawable.ic_account_circle_white_48dp); 
          tabLayout.getTabAt(i).setCustomView(view4); 
          break; 

        } 

       } 
+0

哪條線導致NPE? –

+0

第一個通過getActivity獲取字符串 –

+0

更改this-返回MainFragment.newInstance(position + 1); to this- return MainFragment.newInstance(position); –

回答

0

移動代碼中的活動,添加聆聽從數據庫(addValueEventListener)到片段的OnAttach方法。根據您使用ViewPager的方式,FragmentPagerAdapter可能會決定「回收」您的碎片。因此,在從活動中分離片段時(OnDetach),刪除數據庫偵聽器很重要。

看起來像數據庫是一個單身人士,所以聽衆可能會超出你的片段甚至活動。可能導致一些內存泄漏。所以記得要確定地移除聽衆。

+0

謝謝,問題是ValueEventListener,我已經嘗試覆蓋onAttach之前,但它沒有工作,因爲我沒有使用addListenerForSingleValueEvent。 –