Android开发之利用ViewPager实现在Activity或Fragment中引入别的布局文件实现滑动并进行页面跳转

时间:2023-03-08 23:01:45
Android开发之利用ViewPager实现在Activity或Fragment中引入别的布局文件实现滑动并进行页面跳转

有些时候经常可以看到其他APP中有一排的图标,可以在一个界面中滑来滑去,并且图标可以进行点击事件进行页面的跳转。这里对这种方法的实现做出总结。

首先看一下图片:

下面这两种图片是在一个Fragment中进行滑动的两个不同的界面。下面来说一下具体实现,请看下面代码:

图一(下)

Android开发之利用ViewPager实现在Activity或Fragment中引入别的布局文件实现滑动并进行页面跳转

图二(下)

Android开发之利用ViewPager实现在Activity或Fragment中引入别的布局文件实现滑动并进行页面跳转

上面两张图片是两个不同的xml来实现,图一对应slide1.xml,图二对应slide2.xml:

slide1.xml

 <?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="horizontal" > <LinearLayout
android:id="@+id/dept_list"
android:layout_width="0dp"
android:layout_height="match_parent"
android:layout_weight="1"
android:gravity="center"
android:orientation="vertical" > <ImageView
android:layout_width="63dp"
android:layout_height="54dp"
android:layout_gravity="center"
android:paddingTop="10dp"
android:src="@drawable/image_group" /> <TextView
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:gravity="center"
android:paddingTop="10dp"
android:text="@string/dept_list"
android:textColor="#000000"
android:textSize="20px" /> </LinearLayout> <LinearLayout
android:id="@+id/slideclassalbum"
android:layout_width="0dp"
android:layout_height="match_parent"
android:layout_weight="1"
android:gravity="center"
android:orientation="vertical" >
<ImageView
android:id="@+id/zhuxue"
android:layout_width="63dp"
android:layout_height="54dp"
android:layout_gravity="center"
android:paddingTop="10dp"
android:src="@drawable/testmemberimg6" /> <TextView
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:gravity="center"
android:paddingTop="10dp"
android:text="@string/dept_list"
android:textColor="#000000"
android:textSize="20px" />
</LinearLayout>
<LinearLayout
android:id="@+id/slidegrade"
android:layout_width="0dp"
android:layout_height="match_parent"
android:layout_weight="1"
android:gravity="center"
android:orientation="vertical" >
<ImageView
android:id="@+id/zhuxue"
android:layout_width="63dp"
android:layout_height="54dp"
android:layout_gravity="center"
android:paddingTop="10dp"
android:src="@drawable/testmemberimg3" /> <TextView
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:gravity="center"
android:paddingTop="10dp"
android:text="@string/dept_list"
android:textColor="#000000"
android:textSize="20px" />
</LinearLayout>
<LinearLayout
android:id="@+id/slideloving"
android:layout_width="0dp"
android:layout_height="match_parent"
android:layout_weight="1"
android:gravity="center"
android:orientation="vertical" >
<ImageView
android:id="@+id/zhuxue"
android:layout_width="63dp"
android:layout_height="54dp"
android:layout_gravity="center"
android:paddingTop="10dp"
android:src="@drawable/testmemberimg2" /> <TextView
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:gravity="center"
android:paddingTop="10dp"
android:text="@string/dept_list"
android:textColor="#000000"
android:textSize="20px" />
</LinearLayout>
<LinearLayout
android:id="@+id/slideabroad"
android:layout_width="0dp"
android:layout_height="match_parent"
android:layout_weight="1"
android:gravity="center"
android:orientation="vertical" >
<ImageView
android:id="@+id/zhuxue"
android:layout_width="63dp"
android:layout_height="54dp"
android:layout_gravity="center"
android:paddingTop="10dp"
android:src="@drawable/testmemberimg1" /> <TextView
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:gravity="center"
android:paddingTop="10dp"
android:text="@string/dept_list"
android:textColor="#000000"
android:textSize="20px" />
</LinearLayout>
</LinearLayout>

slide2.xml

 <?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="horizontal" > <LinearLayout
android:id="@+id/slidefile"
android:layout_width="0dp"
android:layout_height="match_parent"
android:layout_weight="1"
android:gravity="center"
android:orientation="vertical" > <ImageView
android:id="@+id/file"
android:layout_width="63dp"
android:layout_height="54dp"
android:layout_gravity="center"
android:paddingTop="10dp"
android:src="@drawable/image_group" /> <TextView
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:gravity="center"
android:paddingTop="10dp"
android:text="@string/dept_list"
android:textColor="#000000"
android:textSize="20px" /> </LinearLayout> <LinearLayout
android:id="@+id/slidealbum"
android:layout_width="0dp"
android:layout_height="match_parent"
android:layout_weight="1"
android:gravity="center"
android:orientation="vertical" >
<ImageView
android:id="@+id/operation"
android:layout_width="63dp"
android:layout_height="54dp"
android:layout_gravity="center"
android:paddingTop="10dp"
android:src="@drawable/testmemberimg6" /> <TextView
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:gravity="center"
android:paddingTop="10dp"
android:text="@string/dept_list"
android:textColor="#000000"
android:textSize="20px" />
</LinearLayout>
<LinearLayout
android:id="@+id/grade"
android:layout_width="0dp"
android:layout_height="match_parent"
android:layout_weight="1"
android:gravity="center"
android:orientation="vertical" > </LinearLayout>
<LinearLayout
android:id="@+id/loving"
android:layout_width="0dp"
android:layout_height="match_parent"
android:layout_weight="1"
android:gravity="center"
android:orientation="vertical" > </LinearLayout>
<LinearLayout
android:id="@+id/abroad"
android:layout_width="0dp"
android:layout_height="match_parent"
android:layout_weight="1"
android:gravity="center"
android:orientation="vertical" > </LinearLayout>
</LinearLayout>

下面是Fragment所对应的布局文件fragment_my.xml。其中红色区域为核心代码,主要是这部分实现滑动。

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@drawable/timg"
android:orientation="vertical" > <com.example.myassembly.VerticalScrollView
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:background="@drawable/timg"
android:fillViewport="true" > <LinearLayout
android:id="@+id/slide"
android:layout_width="match_parent"
android:layout_height="130dp"
android:background="@drawable/timg" > <FrameLayout
android:layout_width="fill_parent"
android:layout_height="130dp"
android:orientation="vertical" > <android.support.v4.view.ViewPager
android:id="@+id/viewPager"
android:layout_width="fill_parent"
android:layout_height="wrap_content" /> <RelativeLayout
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:orientation="vertical" > <LinearLayout
android:id="@+id/viewGroup"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:layout_alignParentBottom="true"
android:layout_marginBottom="10dp"
android:gravity="center_horizontal"
android:orientation="horizontal" >
</LinearLayout>
</RelativeLayout>
</FrameLayout>
</LinearLayout>
</com.example.myassembly.VerticalScrollView> </LinearLayout>

接下来是Fragment中的代码,关于一些具体的情况,还有使用的细节里面有着具体的代码注释。

 import java.util.ArrayList;
import com.example.activity.DeptActivity;
import com.example.myproject.R;
import android.content.Intent;
import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.support.v4.view.PagerAdapter;
import android.support.v4.view.ViewPager;
import android.support.v4.view.ViewPager.OnPageChangeListener;
import android.view.LayoutInflater;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.ViewGroup;
import android.widget.ImageView;
import android.widget.LinearLayout;
/**
* 我的Fragment
* @author admin
*
*/
public class MyFragment extends Fragment implements OnPageChangeListener {
private View rootView;
/****************************************** 滑动界面代码 声明下 *********************************************/
// 用于存放滑动viewpager底部导航栏(点点)
private ImageView[] tips;
private ViewPager viewPager;// 声明viewPager
// 装View数组
private ArrayList<View> viewContainter = new ArrayList<View>();
// 资源id
private int[] imgIdArray;
// 声明ViewPager变量
private View slide1;
private View slide2;
// 声明slide1中的变量
private LinearLayout dept_list; /****************************************** 滑动界面代码声明 上 *********************************************/
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
//Fragment中引入fragment的布局文件
if (null == rootView) {
rootView = inflater.inflate(R.layout.fragment_my, container, false);
initView(rootView);
}
return rootView;
} @Override
public void onStart() {
// 无论是activity中还是在Fragment中,对于另外一个布局文件中的子控件进行操作不能在onceate中进行操作。
InitSetPage();
// super.onStart();不能去掉,否则会出现错误
super.onStart();
} /**
* 获取子view中的控件,并绑定对应操作监听器
*/
private void InitSetPage() {
// 获取slide1中的子控件
dept_list = (LinearLayout) slide1.findViewById(R.id.dept_list);
// 对slide1中的子控件slidezhuxue绑定监听器
dept_list.setOnClickListener(new OnClickListener() { @Override
public void onClick(View v) {
// TODO Auto-generated method stub
Intent intent = new Intent(getActivity(), DeptActivity.class);
startActivity(intent);
}
});
} private void initView(View rootView) {
// 布局文件中的group用来放置viewPager的底部导航栏。
ViewGroup group = (ViewGroup) rootView.findViewById(R.id.viewGroup);
viewPager = (ViewPager) rootView.findViewById(R.id.viewPager);
// 载入资源
imgIdArray = new int[] { R.layout.slide1, R.layout.slide2 };
// 创建底部指示导航栏
tips = new ImageView[imgIdArray.length];
for (int i = 0; i < tips.length; i++) {
ImageView imageView = new ImageView(getActivity()
.getApplicationContext());
LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(
10, 10);
params.setMargins(5, 0, 5, 0);
imageView.setLayoutParams(params);
if (i == 0) {
imageView.setBackgroundResource(R.drawable.dot);
} else {
imageView.setBackgroundResource(R.drawable.dot_focus);
}
tips[i] = imageView;
group.addView(imageView);
}
// 获取要引入的布局文件。在Fragment用getActivity().getApplicationContext()来代替Activity中的this或getApplication。
slide1 = LayoutInflater.from(getActivity().getApplicationContext())
.inflate(R.layout.slide1, null);
slide2 = LayoutInflater.from(getActivity().getApplicationContext())
.inflate(R.layout.slide2, null);
// 将布局文件装载到集合中
viewContainter.add(slide1);
viewContainter.add(slide2);
// 设置adapter
viewPager.setAdapter(new MyAdapter());
// 为viewPager设置监听
viewPager.setOnPageChangeListener(this);
// 设置viewpager显示的默认图片,进去之后直接是第一张图片
viewPager.setCurrentItem(0);
} /*
* 滑动界面PagerView的适配器
*/
public class MyAdapter extends PagerAdapter { @Override
public int getCount() {
// TODO Auto-generated method stub
return viewContainter.size();
} @Override
public boolean isViewFromObject(View arg0, Object arg1) {
// TODO Auto-generated method stub
return arg0 == arg1;
} @Override
public int getItemPosition(Object object) {
// TODO Auto-generated method stub
return super.getItemPosition(object);
} @Override
public void destroyItem(ViewGroup container, int position, Object object) {
((ViewPager) container).removeView(viewContainter.get(position));
} /**
* 载入图片进去,用当前的position 除以 图片数组长度取余数是关键
*/
@Override
public Object instantiateItem(View container, int position) {
((ViewPager) container).addView(viewContainter.get(position));
return viewContainter.get(position);
} } @Override
public void onPageScrollStateChanged(int arg0) {
// TODO Auto-generated method stub } @Override
public void onPageScrolled(int arg0, float arg1, int arg2) {
// TODO Auto-generated method stub } @Override
public void onPageSelected(int arg0) {
// TODO Auto-generated method stub
setImageBackground(arg0 % viewContainter.size());
} /**
* 设置选中的tip的背景
*
* @param selectItems
*/
private void setImageBackground(int selectItems) {
for (int i = 0; i < tips.length; i++) {
if (i == selectItems) {
tips[i].setBackgroundResource(R.drawable.dot);
} else {
tips[i].setBackgroundResource(R.drawable.dot_focus);
}
}
}
}

通过上面的代码即可实现界面的滑动,有一点必须要注意:在对子菜单中的控件进行点击操作时一定要在onstart()方法中进行同时super.onStart();不可省略,否则程序将会崩溃。这一点要特别注意,关于这部分源码稍后会上传****,源码地址稍后补充,不过如果上面的代码看懂了无需源码即可实现。