• <small id='EyDwR'></small><noframes id='EyDwR'>

  • <tfoot id='EyDwR'></tfoot>
      <bdo id='EyDwR'></bdo><ul id='EyDwR'></ul>

      <i id='EyDwR'><tr id='EyDwR'><dt id='EyDwR'><q id='EyDwR'><span id='EyDwR'><b id='EyDwR'><form id='EyDwR'><ins id='EyDwR'></ins><ul id='EyDwR'></ul><sub id='EyDwR'></sub></form><legend id='EyDwR'></legend><bdo id='EyDwR'><pre id='EyDwR'><center id='EyDwR'></center></pre></bdo></b><th id='EyDwR'></th></span></q></dt></tr></i><div id='EyDwR'><tfoot id='EyDwR'></tfoot><dl id='EyDwR'><fieldset id='EyDwR'></fieldset></dl></div>
      1. <legend id='EyDwR'><style id='EyDwR'><dir id='EyDwR'><q id='EyDwR'></q></dir></style></legend>

        Android基于API的Tabs3实现仿优酷tabhost效果实例

        下面我将详细介绍“Android基于API的Tabs3实现仿优酷tabhost效果实例”的完整攻略,包括具体的实现过程和两个示例说明。
      2. <tfoot id='aYZiW'></tfoot>
          <bdo id='aYZiW'></bdo><ul id='aYZiW'></ul>

          <small id='aYZiW'></small><noframes id='aYZiW'>

              <tbody id='aYZiW'></tbody>

            <legend id='aYZiW'><style id='aYZiW'><dir id='aYZiW'><q id='aYZiW'></q></dir></style></legend>
              • <i id='aYZiW'><tr id='aYZiW'><dt id='aYZiW'><q id='aYZiW'><span id='aYZiW'><b id='aYZiW'><form id='aYZiW'><ins id='aYZiW'></ins><ul id='aYZiW'></ul><sub id='aYZiW'></sub></form><legend id='aYZiW'></legend><bdo id='aYZiW'><pre id='aYZiW'><center id='aYZiW'></center></pre></bdo></b><th id='aYZiW'></th></span></q></dt></tr></i><div id='aYZiW'><tfoot id='aYZiW'></tfoot><dl id='aYZiW'><fieldset id='aYZiW'></fieldset></dl></div>

                  下面我将详细介绍“Android基于API的Tabs3实现仿优酷tabhost效果实例”的完整攻略,包括具体的实现过程和两个示例说明。

                  1. 实现基本思路

                  实现仿优酷tabhost效果的方案主要涉及两个部分:一是使用API实现Tabs3页面,二是为每个页面添加Fragment布局。

                  具体步骤:

                  • 在布局中添加ViewPager和TabLayout控件
                  • 创建Fragment
                  • 创建FragmentAdapter并为其添加Fragment
                  • 在TabLayout中设置TabItem
                  • 绑定ViewPager与TabLayout

                  2. 代码实现示例

                  下面我将给出两个示例,一个是实现简单的Tab页面,一个是带有动态切换内容的Tab页面。

                  示例1. 实现简单的Tab页面

                  在布局文件中添加ViewPager和TabLayout控件,为Fragment添加对应的布局文件。

                  布局文件:

                  <android.support.design.widget.TabLayout
                      android:id="@+id/tabs"
                      android:layout_width="match_parent"
                      android:layout_height="wrap_content"
                      android:background="@color/colorPrimary"
                      app:tabIndicatorColor="@color/colorAccent"
                      app:tabSelectedTextColor="@color/colorAccent"
                      app:tabTextColor="@color/white" />
                  
                  <android.support.v4.view.ViewPager
                      android:id="@+id/viewPager"
                      android:layout_width="match_parent"
                      android:layout_height="match_parent" />
                  

                  创建Fragment:

                  public class HomeFragment extends Fragment {
                      @Nullable
                      @Override
                      public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
                          View view = inflater.inflate(R.layout.fragment_home, container, false);
                          return view;
                      }
                  }
                  

                  创建FragmentAdapter并为其添加Fragment:

                  public class FragmentAdapter extends FragmentPagerAdapter {
                      private final List<Fragment> mFragments = new ArrayList<>();
                      private final List<String> mFragmentTitles = new ArrayList<>();
                  
                      public FragmentAdapter(FragmentManager fm) {
                          super(fm);
                      }
                  
                      @Override
                      public Fragment getItem(int position) {
                          return mFragments.get(position);
                      }
                  
                      @Override
                      public int getCount() {
                          return mFragments.size();
                      }
                  
                      public void addFragment(Fragment fragment, String title) {
                          mFragments.add(fragment);
                          mFragmentTitles.add(title);
                      }
                  
                      @Override
                      public CharSequence getPageTitle(int position) {
                          return mFragmentTitles.get(position);
                      }
                  }
                  

                  在TabLayout中设置TabItem:

                  TabLayout tabLayout = findViewById(R.id.tabs);
                  tabLayout.addTab(tabLayout.newTab().setText("Home"));
                  tabLayout.addTab(tabLayout.newTab().setText("Settings"));
                  

                  绑定ViewPager与TabLayout:

                  ViewPager viewPager = findViewById(R.id.viewPager);
                  FragmentAdapter adapter = new FragmentAdapter(getSupportFragmentManager());
                  adapter.addFragment(new HomeFragment(), "Home");
                  adapter.addFragment(new SettingsFragment(), "Settings");
                  viewPager.setAdapter(adapter);
                  tabLayout.setupWithViewPager(viewPager);
                  

                  示例2. 带有动态切换内容的Tab页面

                  通过点击TabLayout内的Item,显示对应的Fragment页面。

                  实现步骤:

                  • 设置TabItem的点击监听事件
                  • 获得当前选中的TabItem
                  • 根据选中的TabItem,显示对应的Fragment

                  代码实现:

                  tabLayout.addOnTabSelectedListener(new TabLayout.OnTabSelectedListener() {
                  
                      @Override
                      public void onTabSelected(TabLayout.Tab tab) {
                          int position = tab.getPosition();
                          switch (position) {
                              case 0:
                                  getSupportFragmentManager().beginTransaction().replace(R.id.fragment_container, new HomeFragment()).commit();
                                  break;
                              case 1:
                                  getSupportFragmentManager().beginTransaction().replace(R.id.fragment_container, new AboutFragment()).commit();
                                  break;
                          }
                      }
                  
                      @Override
                      public void onTabUnselected(TabLayout.Tab tab) {
                  
                      }
                  
                      @Override
                      public void onTabReselected(TabLayout.Tab tab) {
                  
                      }
                  });
                  

                  以上就是Android基于API的Tabs3实现仿优酷tabhost效果实例的完整攻略和两个示例说明。

                  本站部分内容来源互联网,如果有图片或者内容侵犯了您的权益,请联系我们,我们会在确认后第一时间进行删除!

                  相关文档推荐

                  Lambda表达式是Java 8中引入的新特性之一,它是一个匿名函数,可以捕获参数并表现为一个代码块,而不像方法一样需要一个固定的名称。它主要用于传递行为或代码块以及事件处理等操作。
                  下面为您详细讲解基于Java的回调函数。
                  在Java中,equals()是用来比较两个对象是否相等的函数。equals()方法是Object类中的方法,因此所有Java类都包含equals()方法。在默认情况下,equals()方法比较对象的引用地址是否相同,即两个对象是否是同一个实例。但是,我们可以覆盖equals()方法,来定义自
                  JavaWeb是Java在Web领域的应用,是目前非常热门的技术之一。但是JavaWeb涉及到的技术非常广泛,初学者很容易迷失方向。本文总结了JavaWeb的基础知识,为初学者提供了一份学习笔记分享,希望能够帮助大家快速入门。
                  在Java编程中,字符串操作是很常见的,而替换字符串是其中常用的操作之一。Java提供了三种函数用于替换字符串:replace、replaceAll和replaceFirst。这篇文章将为您详细介绍它们的用法。
                  进制是数学中一种表示数值大小的方法,常见的进制有10进制、2进制、16进制等。
                    <bdo id='C8FsZ'></bdo><ul id='C8FsZ'></ul>

                          <tfoot id='C8FsZ'></tfoot>
                            <tbody id='C8FsZ'></tbody>

                        • <i id='C8FsZ'><tr id='C8FsZ'><dt id='C8FsZ'><q id='C8FsZ'><span id='C8FsZ'><b id='C8FsZ'><form id='C8FsZ'><ins id='C8FsZ'></ins><ul id='C8FsZ'></ul><sub id='C8FsZ'></sub></form><legend id='C8FsZ'></legend><bdo id='C8FsZ'><pre id='C8FsZ'><center id='C8FsZ'></center></pre></bdo></b><th id='C8FsZ'></th></span></q></dt></tr></i><div id='C8FsZ'><tfoot id='C8FsZ'></tfoot><dl id='C8FsZ'><fieldset id='C8FsZ'></fieldset></dl></div>

                            <legend id='C8FsZ'><style id='C8FsZ'><dir id='C8FsZ'><q id='C8FsZ'></q></dir></style></legend>
                          1. <small id='C8FsZ'></small><noframes id='C8FsZ'>