Android中ViewPager+Fragment的基本使用

这几天学习了一下ViewPager+Fragement的基本使用方法并写了个Demo。现将代码和效果图放上。

  1. 首先是布局文件

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
  <RelativeLayout xmlns:android= "http://schemas.android.com/apk/res/android"
     xmlns:tools= "http://schemas.android.com/tools"
     android:layout_width= "match_parent"
     android:layout_height= "match_parent"
     tools:context= ".MainActivity"  >
     
     <!-- ViewPager组件 -->
     <android.support.v4.view.ViewPager
         android:id= "@+id/viewpager"
         android:layout_width= "match_parent"
         android:layout_height= "match_parent" >
               
         <!-- PagerTabStrip是标签页的切换效果 -->
         <android.support.v4.view.PagerTabStrip
             android:id= "@+id/pagertab"  
             android:layout_width= "wrap_content"  
             android:layout_height= "wrap_content"  
             />  
          
     </android.support.v4.view.ViewPager>
     
</RelativeLayout>
<!--注意事项:     
     1 .这里ViewPager和 PagerTabStrip都要把包名写全了,不然会ClassNotFount    
     2 .API中说:在布局xml把PagerTabStrip当做ViewPager的一个子标签来用,不能拿出来,不然还是会报错    
-->

 

 2.MainActivity.java

    MainActivity主要就做了一些加载控件和实例化Fragment的事情,重点要注意的是MyViewPagerAdapter这个适配器的内部类。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
package  com.xlp.myviewpagerfragment;
import  java.util.ArrayList;
import  android.os.Bundle;
import  android.support.v4.app.Fragment;
import  android.support.v4.app.FragmentActivity;
import  android.support.v4.app.FragmentManager;
import  android.support.v4.app.FragmentPagerAdapter;
import  android.support.v4.view.PagerTabStrip;
import  android.support.v4.view.ViewPager;
import  android.view.Menu;
import  android.view.MenuItem;
 
public  class  MainActivity  extends  FragmentActivity {
      private  ViewPager m_vp;
      // 通过pagerTabStrip可以设置标题的属性
      private  PagerTabStrip pagerTabStrip;
      private  Fragment1 mfragment1;
      private  Fragment2 mfragment2;
      private  Fragment3 mfragment3;
      // 页面列表
      private  ArrayList<Fragment> fragmentList;
      // 标题列表
      private  ArrayList<String> titleList =  new  ArrayList<String>();
  @Override
  protected  void  onCreate(Bundle savedInstanceState) {
   super .onCreate(savedInstanceState);
   setContentView(R.layout.activity_main);
   initView();
  }
  public  void  initView() {
       m_vp = (ViewPager) findViewById(R.id.viewpager);
       pagerTabStrip = (PagerTabStrip) findViewById(R.id.pagertab);
       // 设置下划线颜色
       pagerTabStrip.setTabIndicatorColor(getResources().getColor(
         android.R.color.holo_green_dark));
       pagerTabStrip.setBackgroundColor(getResources().getColor(
         android.R.color.holo_red_dark));
       mfragment1 =  new  Fragment1();
       mfragment2 =  new  Fragment2();
       mfragment3 =  new  Fragment3();
       fragmentList =  new  ArrayList<Fragment>();
       fragmentList.add(mfragment1);
       fragmentList.add(mfragment2);
       fragmentList.add(mfragment3);
       titleList.add( "第一页" );
       titleList.add( "第二页" );
       titleList.add( "第三页" );
       m_vp.setAdapter( new  MyViewPagerAdapter(getSupportFragmentManager()));
  }
      public  class  MyViewPagerAdapter  extends  FragmentPagerAdapter {
           public  MyViewPagerAdapter(FragmentManager fm) {
            super (fm);
       }
       @Override
       public  Fragment getItem( int  arg0) {
            return  fragmentList.get(arg0);
       }
       @Override
       public  int  getCount() {
            return  fragmentList.size();
       }
       @Override
       public  CharSequence getPageTitle( int  position) {
            // TODO Auto-generated method stub
            return  titleList.get(position);
       }
  }
      @Override
      public  boolean  onCreateOptionsMenu(Menu menu) {
       // Inflate the menu; this adds items to the action bar if it is present.
       getMenuInflater().inflate(R.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();
       if  (id == R.id.action_settings) {
        return  true ;
       }
       return  super .onOptionsItemSelected(item);
      }
}

 

3.Fragment1.java

    其中的一个Fragment页面,这里只展示一个,其他写法相同

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
  package  com.xlp.myviewpagerfragment;
import  android.os.Bundle;
import  android.support.v4.app.Fragment;
import  android.util.Log;
import  android.view.LayoutInflater;
import  android.view.View;
import  android.view.ViewGroup;
 
public  class  Fragment1  extends  Fragment {
  private  View mMainView;
  @Override
  public  void  onCreate(Bundle savedInstanceState) {
   // TODO Auto-generated method stub
   super .onCreate(savedInstanceState);
   Log.i( "xlp" "fragment1-->oncreate()" );
   //动态加载布局文件
   LayoutInflater inflater = getActivity().getLayoutInflater();
   mMainView = inflater.inflate(R.layout.fragment1,
     (ViewGroup) getActivity().findViewById(R.id.viewpager),  false );
  }
  @Override
  public  View onCreateView(LayoutInflater inflater, ViewGroup container,
    Bundle savedInstanceState) {
   Log.i( "xlp" "fragment1-->onCreateView()" );
   ViewGroup viewGroup = (ViewGroup) mMainView.getParent();
   return  mMainView;
  }
  @Override
  public  void  onDestroy() {
   // TODO Auto-generated method stub
   super .onDestroy();
   Log.v( "xlp" "fragment1-->onDestroy()" );
  }
  @Override
  public  void  onPause() {
   // TODO Auto-generated method stub
   super .onPause();
   Log.v( "xlp" "fragment1-->onPause()" );
  }
  @Override
  public  void  onResume() {
   // TODO Auto-generated method stub
   super .onResume();
   Log.v( "xlp" "fragment1-->onResume()" );
  }
  @Override
  public  void  onStart() {
   // TODO Auto-generated method stub
   super .onStart();
   Log.v( "xlp" "fragment1-->onStart()" );
  }
  @Override
  public  void  onStop() {
   // TODO Auto-generated method stub
   super .onStop();
   Log.v( "xlp" "fragment1-->onStop()" );
  }
}

 

    4.最后放上效果图

    

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我会为您讲解关于AndroidViewPagerFragment使用ViewPagerFragmentAndroid非常常用的组件,他们可以一起使用来实现滑动页面效果。ViewPager是一个可以左右滑动切换页面的布局容器,而Fragment作为ViewPager的子页面,可以在ViewPager进行动态添加和移除。 下面我们将分别介绍ViewPagerFragment使用。 ## ViewPager使用 ### 1.布局文件 在布局文件,我们需要使用ViewPager作为容器,将需要滑动切换的页面放入其。如下所示: ``` <androidx.viewpager.widget.ViewPager android:id="@+id/viewPager" android:layout_width="match_parent" android:layout_height="match_parent"/> ``` ### 2.创建Adapter 我们需要创建一个Adapter继承自PagerAdapter,并重写以下方法: ``` public class MyPagerAdapter extends PagerAdapter { private List<Fragment> mFragments; public MyPagerAdapter(List<Fragment> fragments) { mFragments = fragments; } @Override public int getCount() { return mFragments.size(); } @Override public boolean isViewFromObject(@NonNull View view, @NonNull Object object) { return view == object; } @NonNull @Override public Object instantiateItem(@NonNull ViewGroup container, int position) { Fragment fragment = mFragments.get(position); container.addView(fragment.getView()); return fragment.getView(); } @Override public void destroyItem(@NonNull ViewGroup container, int position, @NonNull Object object) { container.removeView((View) object); } } ``` ### 3.设置Adapter 在Activity或Fragment,我们需要创建ViewPager的实例,并设置Adapter。如下所示: ``` ViewPager viewPager = findViewById(R.id.viewPager); List<Fragment> fragments = new ArrayList<>(); fragments.add(new Fragment1()); fragments.add(new Fragment2()); fragments.add(new Fragment3()); MyPagerAdapter adapter = new MyPagerAdapter(fragments); viewPager.setAdapter(adapter); ``` 这样,我们就完成了ViewPager使用。 ## Fragment使用 ### 1.创建Fragment 我们需要创建一个继承自Fragment的类,并重写以下方法: ``` public class Fragment1 extends Fragment { @Nullable @Override public View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) { View view = inflater.inflate(R.layout.fragment1, container, false); return view; } } ``` ### 2.布局文件 我们需要在Fragment添加布局文件,如下所示: ``` <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent"> <TextView android:text="Fragment1" android:layout_width="match_parent" android:layout_height="match_parent" /> </LinearLayout> ``` 这样,我们就完成了Fragment使用。 ## ViewPagerFragment的结合使用 通过以上介绍,我们已经知道了如何使用ViewPagerFragment了。现在我们需要将它们结合起来使用。 ### 1.创建Fragment 我们需要创建多个Fragment作为ViewPager的子页面。 ### 2.创建Adapter 我们需要创建一个PagerAdapter,将Fragment添加到ViewPager。如上所示,我们已经创建了一个MyPagerAdapter。 ### 3.设置Adapter 在Activity或Fragment,我们需要创建ViewPager的实例,并设置Adapter。如上所示,我们已经使用ViewPager的setAdapter方法设置了MyPagerAdapter。 这样,我们就完成了ViewPagerFragment的结合使用

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值