2017-05-06 4 views
-1

私はTabLayoutアクティビティを持っています。タブの1つ(ケース3)に対して、設定ページにPreferenceFragmentを使いたいと思います。下のケース3では、フラグメントを宣言しましたが、どのように開始しますか?XMLリソースからフラグメントを始める方法

public static class SettingsFragment extends PreferenceFragment { 
    @Override 
    public void onCreate(Bundle savedInstanceState) { 
     super.onCreate(savedInstanceState); 

     // Load the preferences from an XML resource 
     addPreferencesFromResource(R.xml.preferences); 
    } 

} 

@Override 
public View onCreateView(LayoutInflater inflater, ViewGroup container, 
         Bundle savedInstanceState) { 
    View rootView = null; 
    switch (getArguments().getInt(ARG_SECTION_NUMBER)) { 
     case 1: { 
      rootView = inflater.inflate(R.layout.fragment_profile, container, false); 
      break; 
     } 
     case 2: { 
      rootView = inflater.inflate(R.layout.fragment_find, container, false); 
      break; 
     } 
     case 3: { 
      SettingsFragment fragment = new SettingsFragment(); 
      // what goes here? 
      break; 
     } 
    } 

    return rootView; 
} 

フルコード:

public class Find extends AppCompatActivity { 

    private SectionsPagerAdapter mSectionsPagerAdapter; 

    private ViewPager mViewPager; 

    @Override 
    protected void onCreate(Bundle savedInstanceState) { 
     super.onCreate(savedInstanceState); 
     setContentView(R.layout.activity_find); 


     // Create the adapter that will return a fragment for each of the three 
     // primary sections of the activity. 
     mSectionsPagerAdapter = new SectionsPagerAdapter(getSupportFragmentManager()); 

     // Set up the ViewPager with the sections adapter. 
     mViewPager = (ViewPager) findViewById(R.id.container); 
     mViewPager.setAdapter(mSectionsPagerAdapter); 

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

     TabLayout.Tab tab1 = tabLayout.getTabAt(0); 
     tab1.setCustomView(R.layout.icon_view); 
     tab1.setIcon(R.drawable.profile); 

     TabLayout.Tab tab2 = tabLayout.getTabAt(1); 
     tab2.setCustomView(R.layout.icon_view); 
     tab2.setIcon(R.drawable.logo_a); 

     TabLayout.Tab tab3 = tabLayout.getTabAt(2); 
     tab3.setCustomView(R.layout.icon_view); 
     tab3.setIcon(R.drawable.settings); 

    } 

    public static class PlaceholderFragment extends Fragment { 

     private static final String ARG_SECTION_NUMBER = "section_number"; 

     public PlaceholderFragment() { 
     } 

     /** 
     * Returns a new instance of this fragment for the given section 
     * number. 
     */ 
     public static PlaceholderFragment newInstance(int sectionNumber) { 
      PlaceholderFragment fragment = new PlaceholderFragment(); 
      Bundle args = new Bundle(); 
      args.putInt(ARG_SECTION_NUMBER, sectionNumber); 
      fragment.setArguments(args); 
      return fragment; 
     } 

     public static class SettingsFragment extends PreferenceFragment { 
      @Override 
      public void onCreate(Bundle savedInstanceState) { 
       super.onCreate(savedInstanceState); 

       // Load the preferences from an XML resource 
       addPreferencesFromResource(R.xml.preferences); 
      } 

     } 

     @Override 
     public View onCreateView(LayoutInflater inflater, ViewGroup container, 
           Bundle savedInstanceState) { 
      View rootView = null; 
      switch (getArguments().getInt(ARG_SECTION_NUMBER)) { 
       case 1: { 
        rootView = inflater.inflate(R.layout.fragment_profile, container, false); 
        break; 
       } 
       case 2: { 
        rootView = inflater.inflate(R.layout.fragment_find, container, false); 
        break; 
       } 
       case 3: { 
        SettingsFragment fragment = new SettingsFragment(); 
        // what goes here? 
        break; 
       } 
      } 

      return rootView; 
     } 
    } 

    /** 
    * A {@link FragmentPagerAdapter} that returns a fragment corresponding to 
    * one of the sections/tabs/pages. 
    */ 
    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). 
      return PlaceholderFragment.newInstance(position + 1); 
     } 

     @Override 
     public int getCount() { 
      // Show 3 total pages. 
      return 3; 
     } 
+0

アダプターを使いましたか?もしそうなら、あなたのアダプタークラスを投稿してください – FAT

+0

編集でフルコードを追加しました。 – Zorgan

+0

私の答えを見てください。これがあなたの問題を解決することを願っています – FAT

答えて

1
  1. セパレートSettingsFragment3rd TAB用SettingsFragmentを表示する更新SectionsPagerAdapterのgetItem()方法
  2. PlaceholderFragmentから。
  3. case 3onCreateView()から削除します。

これを試してみてください:

public class Find extends AppCompatActivity { 

    private SectionsPagerAdapter mSectionsPagerAdapter; 

    private ViewPager mViewPager; 

    @Override 
    protected void onCreate(Bundle savedInstanceState) { 
     super.onCreate(savedInstanceState); 
     setContentView(R.layout.activity_find); 


     // Create the adapter that will return a fragment for each of the three 
     // primary sections of the activity. 
     mSectionsPagerAdapter = new SectionsPagerAdapter(getSupportFragmentManager()); 

     // Set up the ViewPager with the sections adapter. 
     mViewPager = (ViewPager) findViewById(R.id.container); 
     mViewPager.setAdapter(mSectionsPagerAdapter); 

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

     TabLayout.Tab tab1 = tabLayout.getTabAt(0); 
     tab1.setCustomView(R.layout.icon_view); 
     tab1.setIcon(R.drawable.profile); 

     TabLayout.Tab tab2 = tabLayout.getTabAt(1); 
     tab2.setCustomView(R.layout.icon_view); 
     tab2.setIcon(R.drawable.logo_a); 

     TabLayout.Tab tab3 = tabLayout.getTabAt(2); 
     tab3.setCustomView(R.layout.icon_view); 
     tab3.setIcon(R.drawable.settings); 

    } 

    public static class SettingsFragment extends PreferenceFragment { 
     @Override 
     public void onCreate(Bundle savedInstanceState) { 
      super.onCreate(savedInstanceState); 

      // Load the preferences from an XML resource 
      addPreferencesFromResource(R.xml.preferences); 
     } 
    } 

    public static class PlaceholderFragment extends Fragment { 

     private static final String ARG_SECTION_NUMBER = "section_number"; 

     public PlaceholderFragment() { 
     } 

     /** 
     * Returns a new instance of this fragment for the given section 
     * number. 
     */ 
     public static PlaceholderFragment newInstance(int sectionNumber) { 
      PlaceholderFragment fragment = new PlaceholderFragment(); 
      Bundle args = new Bundle(); 
      args.putInt(ARG_SECTION_NUMBER, sectionNumber); 
      fragment.setArguments(args); 
      return fragment; 
     } 

     @Override 
     public View onCreateView(LayoutInflater inflater, ViewGroup container, 
           Bundle savedInstanceState) { 
      View rootView = null; 
      switch (getArguments().getInt(ARG_SECTION_NUMBER)) { 
       case 1: { 
        rootView = inflater.inflate(R.layout.fragment_profile, container, false); 
        break; 
       } 
       case 2: { 
        rootView = inflater.inflate(R.layout.fragment_find, container, false); 
        break; 
       } 

      } 

      return rootView; 
     } 
    } 

    /** 
    * A {@link FragmentPagerAdapter} that returns a fragment corresponding to 
    * one of the sections/tabs/pages. 
    */ 
    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 PlaceholderFragment.newInstance(1); 
       } 
       case 1: { 
        return PlaceholderFragment.newInstance(2); 
       } 
       case 2: { 
        SettingsFragment fragment = new SettingsFragment(); 
        return fragment; 
       } 
      } 

      return PlaceholderFragment.newInstance(1); 
     } 

     @Override 
     public int getCount() { 
      // Show 3 total pages. 
      return 3; 
     } 
    } 
} 

UPDATE:

enter image description here

は、あなたがPreferenceFragmentCompatを使用する必要があり、このエラーを解決するには0

1.PreferenceFragmentCompatを使用するには、あなたのbuild.gradleファイルにdependencies下の行の下に追加します。PreferenceFragmentCompat代わりのPreferenceFragmentからあなたSettingsFragmentを拡張

dependencies { 
    ......... 
    ............... 
    compile 'com.android.support:preference-v7:25.1.0' 
} 

2.

import android.support.v7.preference.PreferenceFragmentCompat; 

    ......... 
    ................. 

    public static class SettingsFragment extends PreferenceFragmentCompat { 

     @Override 
     public void onCreatePreferences(Bundle savedInstanceState, String rootKey) { 

      // Load the preferences from an XML resource 
      addPreferencesFromResource(R.xml.preferences); 
     } 
    } 

    ......... 
    ................. 

3.あなたthemepreferenceThemeを指定する必要があります。

のstyles.xml:

<style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar"> 
    ....... 
    ........... 
    <item name="preferenceTheme">@style/PreferenceThemeOverlay</item> 
</style> 

をまたPreferenceFragmentCompatについての詳細を学ぶためにtutorialを確認することができます。

希望すると、これは役に立ちます〜

+0

あなたのコードでこのエラーが発生する:i.imgur.com/H7zPpHt.pngそれを修正する方法はありますか? – Zorgan

+0

"import android.support.v4.app.Fragment;"を追加する必要があります。あなたの活動の中で – FAT

+0

すでに手に入りました。 – Zorgan

関連する問題