页面滑动1:例题(ViewPagerDemo1)

①添加三个page页面

②主页面布局代码
<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="horizontal" >
    < android.support.v4.view.ViewPager        显示页面滑动效果
        android:id="@+id/viewpager"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" >

        < android.support.v4.view.PagerTitleStrip      显示页面标题
            android:layout_gravity="top"
            android:id="@+id/pagertitle"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content" >
        </android.support.v4.view.PagerTitleStrip>
    </android.support.v4.view.ViewPager>
</LinearLayout>
③类代码
package com.example.viewpagerdemo1;
import java.util.ArrayList;
import java.util.List;
import android.app.Activity;
import android.os.Bundle;
import android.support.v4.view.PagerAdapter;
import android.support.v4.view.ViewPager;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
public class ViewPager1Activity extends Activity {
 private ViewPager pager;
 private LayoutInflater inflater = null;
 private List<View> pages = null;
 private List<String> title = null;

 @Override
 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_view_pager1);
  pager = (ViewPager) findViewById(R.id.viewpager);
  inflater = LayoutInflater.from(this);
  View view1 = inflater.inflate(R.layout.page1, null, false);
  View view2 = inflater.inflate(R.layout.page2, null, false);
  View view3 = inflater.inflate(R.layout.page3, null, false);
  pages = new ArrayList<View>();
  pages.add(view1);
  pages.add(view2);
  pages.add(view3);
  MyPagerAdapter adapter = new MyPagerAdapter();
  pager.setAdapter(adapter);
  title = new ArrayList<String>();
  title.add("第一页");
  title.add("第二页");
  title.add("第三页");
 }

 class MyPagerAdapter extends PagerAdapter {
  @Override
  // container为ViewPager
  public void destroyItem(ViewGroup container, int position, Object object) {
   // 这句话必须注释掉,否则滑到最后一页会报错
   // super.destroyItem(container, position, object);
   // 移出view进行销毁
   container.removeView(pages.get(position));
  }

  @Override
  // 实例化ViewPager中的Item
  public Object instantiateItem(ViewGroup container, int position) {
   // container:三个view添加到这里就可以显示
   container.addView(pages.get(position));
   return pages.get(position);
  }

  @Override
  // 获得要显示的页数
  public int getCount() {
   return pages.size();
  }

  @Override
  // 判断key对象是否与View对象关联
  public boolean isViewFromObject(View view, Object object) {
   return view == object;
  }

  @Override
  // 添加标题
  public CharSequence getPageTitle(int position) {
   return title.get(position);
  }
 }
}


效果:
第一页:

第二页:

第三页:


注意:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值