Android项目ViewPager+Fragment的基本使用
来源:互联网 发布:mac系统怎么登陆steam 编辑:程序博客网 时间:2024/06/06 04:18
利用ViewPager+Fragment简单实现页面的切换
项目的大概组成:
以下是代码的实现,首先在activity_main.xml新建菜单栏和ViewPager控件:
<LinearLayout 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" android:orientation="vertical" tools:context="com.itman.viewpagerdemo.MainActivity" > <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="horizontal" > <TextView android:id="@+id/tv_item_one" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_weight="1" android:gravity="center_horizontal" android:text="菜单一" /> <TextView android:id="@+id/tv_item_two" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_weight="1" android:gravity="center_horizontal" android:text="菜单二" /> <TextView android:id="@+id/tv_item_three" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_weight="1" android:gravity="center_horizontal" android:text="菜单三" /> </LinearLayout> <android.support.v4.view.ViewPager android:id="@+id/myViewPager" android:layout_width="match_parent" android:layout_height="match_parent" android:layout_weight="1" /></LinearLayout>
接下来就新建三个Fragment页面做好准备,Fragment的布局文件:
<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" > <TextView android:layout_width="match_parent" android:layout_height="match_parent" android:gravity="center" android:text="我是菜单一" android:textSize="30sp" /></RelativeLayout>
Fragment的Java文件:
package com.itman.viewpagerdemo;import android.os.Bundle;import android.support.annotation.Nullable;import android.support.v4.app.Fragment;import android.view.LayoutInflater;import android.view.View;import android.view.ViewGroup;public class OneFragment extends Fragment{@Overridepublic View onCreateView(LayoutInflater inflater,ViewGroup container, Bundle savedInstanceState) {View view = inflater.inflate(R.layout.fragment_one, null);return view;}}
三个fragment页面都一样的,就不全部贴出来了,接下来就准备添加Fragment的适配器TabFragmentPagerAdapter:
package com.itman.viewpagerdemo;import java.util.List;import android.support.v4.app.Fragment;import android.support.v4.app.FragmentManager;import android.support.v4.app.FragmentPagerAdapter;public class TabFragmentPagerAdapter extends FragmentPagerAdapter {private FragmentManager mfragmentManager;private List<Fragment> mlist;public TabFragmentPagerAdapter(FragmentManager fm, List<Fragment> list) {super(fm); this.mlist = list;}@Overridepublic Fragment getItem(int arg0) {return mlist.get(arg0);//显示第几个页面}@Overridepublic int getCount() {return mlist.size();//有几个页面}}
准备工作完成,接下来是MainActivit.Java的代码实现:
package com.itman.viewpagerdemo;import java.util.ArrayList;import java.util.List;import android.graphics.Color;import android.os.Bundle;import android.support.v4.app.Fragment;import android.support.v4.view.ViewPager;import android.support.v4.view.ViewPager.OnPageChangeListener;import android.support.v7.app.ActionBarActivity;import android.view.View;import android.view.View.OnClickListener;import android.widget.TextView;public class MainActivity extends ActionBarActivity implements OnClickListener {private TextView tv_item_one;private TextView tv_item_two;private TextView tv_item_three;private ViewPager myViewPager;private List<Fragment> list;private TabFragmentPagerAdapter adapter;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);InitView();// 设置菜单栏的点击事件tv_item_one.setOnClickListener(this);tv_item_two.setOnClickListener(this);tv_item_three.setOnClickListener(this);myViewPager.setOnPageChangeListener(new MyPagerChangeListener());//把Fragment添加到List集合里面list = new ArrayList<>();list.add(new OneFragment());list.add(new TwoFragment());list.add(new ThreeFragment());adapter = new TabFragmentPagerAdapter(getSupportFragmentManager(), list);myViewPager.setAdapter(adapter);myViewPager.setCurrentItem(0); //初始化显示第一个页面tv_item_one.setBackgroundColor(Color.RED);//被选中就为红色}/*** 初始化控件*/private void InitView() {tv_item_one = (TextView) findViewById(R.id.tv_item_one);tv_item_two = (TextView) findViewById(R.id.tv_item_two);tv_item_three = (TextView) findViewById(R.id.tv_item_three);myViewPager = (ViewPager) findViewById(R.id.myViewPager);}/*** 点击事件*/@Overridepublic void onClick(View v) {switch (v.getId()) {case R.id.tv_item_one:myViewPager.setCurrentItem(0);tv_item_one.setBackgroundColor(Color.RED);tv_item_two.setBackgroundColor(Color.WHITE);tv_item_three.setBackgroundColor(Color.WHITE);break;case R.id.tv_item_two:myViewPager.setCurrentItem(1);tv_item_one.setBackgroundColor(Color.WHITE);tv_item_two.setBackgroundColor(Color.RED);tv_item_three.setBackgroundColor(Color.WHITE);break;case R.id.tv_item_three:myViewPager.setCurrentItem(2);tv_item_one.setBackgroundColor(Color.WHITE);tv_item_two.setBackgroundColor(Color.WHITE);tv_item_three.setBackgroundColor(Color.RED);break;}}/*** 设置一个ViewPager的侦听事件,当左右滑动ViewPager时菜单栏被选中状态跟着改变**/public class MyPagerChangeListener implements OnPageChangeListener {@Overridepublic void onPageScrollStateChanged(int arg0) {}@Overridepublic void onPageScrolled(int arg0, float arg1, int arg2) {}@Overridepublic void onPageSelected(int arg0) {switch (arg0) {case 0:tv_item_one.setBackgroundColor(Color.RED);tv_item_two.setBackgroundColor(Color.WHITE);tv_item_three.setBackgroundColor(Color.WHITE);break;case 1:tv_item_one.setBackgroundColor(Color.WHITE);tv_item_two.setBackgroundColor(Color.RED);tv_item_three.setBackgroundColor(Color.WHITE);break;case 2:tv_item_one.setBackgroundColor(Color.WHITE);tv_item_two.setBackgroundColor(Color.WHITE);tv_item_three.setBackgroundColor(Color.RED);break;}}}}
代码的注释很详细,也不是什么很难实现功能,有了基本实现的样例,大家就可以随意改动,变成自己喜欢的样式了。
1 0
- Android项目ViewPager+Fragment的基本使用
- Android中ViewPager+Fragment的基本使用
- Android中ViewPager+Fragment的基本使用
- 【Android】ViewPager+Fragment的基本使用
- Android ViewPager + Fragment的使用
- Android ViewPager+Fragment的使用
- ViewPager、ViewPager和Fragment组合使用的基本用法
- Android中Fragment+ViewPager的配合使用
- Android:Fragment 与 ViewPager的配合使用
- Fragment+ViewPager的简单使用 Android
- Android中Fragment+ViewPager的配合使用
- ViewPager+Fragment的使用
- ViewPager+Fragment的使用
- ViewPager+Fragment的使用
- Android - Fragment+ViewPager结合使用
- Android使用ViewPager+Fragment的使用(一)
- Android--ViewPager的使用(未使用fragment)
- 【Android】Android中fragment的基本使用
- RapidMiner 数据读写
- VIM快捷(三):删除
- leetcode RomanToInt
- MYSQL explain详解
- Ubuntu 下同局域网主机访问Tomcat 服务器
- Android项目ViewPager+Fragment的基本使用
- SQLite数据库——案例:商品展示
- 剑指offer 对称的二叉树
- android TextView超链接设置颜色
- Session猜数字游戏
- Elasticsearch的介绍和安装
- C++中虚函数、纯虚函数、抽象类、重载、覆盖、隐藏的区别与联系
- 自己实现的一个smallstring
- linux下同时启动多个tomcat