安卓:ViewPager,添加图片方式2及标题版,自动轮播版(第一种)

第二种方式添加图片:


1.创建3个带有ImageView的布局

2.主布局里放ViewPager控件

3逻辑代码里将布局加载到ViewPager中


逻辑代码文件:

<span style="font-size:18px;">package com.example.day20_viewpage_title;

import java.util.ArrayList;
import java.util.List;

import android.app.Activity;
import android.os.Bundle;
import android.os.Handler;
import android.support.v4.view.PagerAdapter;
import android.support.v4.view.PagerTitleStrip;
import android.support.v4.view.ViewPager;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;

public class MainActivity2 extends Activity {

	ViewPager vp;
	List<View> list;//图片的集合
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        vp=(ViewPager) findViewById(R.id.vp);
        pt=(PagerTitleStrip) findViewById(R.id.pt);
        list=new ArrayList<View>();
        list.add(LayoutInflater.from(this).inflate(R.layout.layout1,null));
        list.add(LayoutInflater.from(this).inflate(R.layout.layout2,null));
        list.add(LayoutInflater.from(this).inflate(R.layout.layout3,null));        
        MyAdapter adapter=new MyAdapter();
        vp.setAdapter(adapter);    
    }
    class MyAdapter extends PagerAdapter
    {

		@Override
		public int getCount() {

			return list.size();
		}
		@Override
		public Object instantiateItem(ViewGroup container, int position) {
			container.addView(list.get(position));
			return list.get(position);
		}
		@Override
		public void destroyItem(ViewGroup container, int position, Object object) {
		container.removeView(list.get(position));	
		}
		
		@Override
		public boolean isViewFromObject(View arg0, Object arg1) {
			return arg0==arg1;
		}
    }
}
</span>


主布局文件:

<span style="font-size:18px;"><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"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    tools:context=".MainActivity" >

    <android.support.v4.view.ViewPager
        android:id="@+id/vp"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        >
     </android.support.v4.view.ViewPager>
</RelativeLayout>
</span>


3个放图片的布局文件:

<span style="font-size:18px;"><?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="vertical" >
    <ImageView 
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:src="@drawable/slide2"/>

</LinearLayout>
</span>



标题版:



1.在布局文件ViewPager标签内加PagerTitleStrip

2.逻辑代码文件中创建一个List存放标题的集合

3.PagerAdapter适配器类中重写名为getPageTitle的方法


逻辑代码文件:

<span style="font-size:18px;">package com.example.day20_viewpage_title;

import java.util.ArrayList;
import java.util.List;

import android.app.Activity;
import android.os.Bundle;
import android.os.Handler;
import android.support.v4.view.PagerAdapter;
import android.support.v4.view.PagerTitleStrip;
import android.support.v4.view.ViewPager;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;

public class MainActivity2 extends Activity {

	ViewPager vp;
	PagerTitleStrip pt;
	List<View> list;//图片的集合
	List<String> tList;//标题的集合
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        vp=(ViewPager) findViewById(R.id.vp);
        pt=(PagerTitleStrip) findViewById(R.id.pt);
        list=new ArrayList<View>();
        list.add(LayoutInflater.from(this).inflate(R.layout.layout1,null));
        list.add(LayoutInflater.from(this).inflate(R.layout.layout2,null));
        list.add(LayoutInflater.from(this).inflate(R.layout.layout3,null));

        tList=new ArrayList<String>();
        tList.add("娱乐");
        tList.add("茶文化");
        tList.add("新闻头条");       
        
        MyAdapter adapter=new MyAdapter();
        vp.setAdapter(adapter);
   }   
    class MyAdapter extends PagerAdapter
    {

		@Override
		public int getCount() {

			return list.size();
		}
		@Override
		public Object instantiateItem(ViewGroup container, int position) {
			container.addView(list.get(position));
			return list.get(position);
		}
		@Override
		public void destroyItem(ViewGroup container, int position, Object object) {
		container.removeView(list.get(position));	
		}
		
		@Override
		public boolean isViewFromObject(View arg0, Object arg1) {
			return arg0==arg1;
		}
		
		//android.support.v4.view.PagerTitleStrip 给pager界面加标题
		@Override
		public CharSequence getPageTitle(int position) {
			return tList.get(position);
		}
    }
}
</span>

布局文件:

<span style="font-size:18px;"><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"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    tools:context=".MainActivity" >

    <android.support.v4.view.ViewPager
        android:id="@+id/vp"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        >
        <android.support.v4.view.PagerTitleStrip
            android:id="@+id/pt"
            android:layout_width="wrap_content"
        	android:layout_height="wrap_content"
        />
     </android.support.v4.view.ViewPager>
</RelativeLayout>
</span>


ViewPager用的放图片的布局文件:

<span style="font-size:18px;"><?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="vertical" >
    <ImageView 
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:src="@drawable/slide1"/>

</LinearLayout>
</span>



自动轮播版方式1:

在标题的基础上加的,其他布局文件同上,逻辑代码文件如下:


逻辑代码文件:

<span style="font-size:18px;">package com.example.day20_viewpage_title;

import java.util.ArrayList;
import java.util.List;

import android.app.Activity;
import android.os.Bundle;
import android.os.Handler;
import android.support.v4.view.PagerAdapter;
import android.support.v4.view.PagerTitleStrip;
import android.support.v4.view.ViewPager;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;

public class MainActivity2 extends Activity {

	ViewPager vp;
	PagerTitleStrip pt;
	List<View> list;//图片的集合
	List<String> tList;//标题的集合
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        vp=(ViewPager) findViewById(R.id.vp);
        pt=(PagerTitleStrip) findViewById(R.id.pt);
        list=new ArrayList<View>();
        list.add(LayoutInflater.from(this).inflate(R.layout.layout1,null));
        list.add(LayoutInflater.from(this).inflate(R.layout.layout2,null));
        list.add(LayoutInflater.from(this).inflate(R.layout.layout3,null));

        tList=new ArrayList<String>();
        tList.add("娱乐");
        tList.add("茶文化");
        tList.add("新闻头条");       
        
        MyAdapter adapter=new MyAdapter();
        vp.setAdapter(adapter);
        //预加载界面
        vp.setOffscreenPageLimit(2);
        handler.sendEmptyMessageAtTime(1,2000);
        
    }
    //自动轮播,但此法有个回退,day20...2的工程里有其他方法
    Handler handler=new Handler(){
    	public void handleMessage(android.os.Message msg) {
    		int i=vp.getCurrentItem();
    		if(i==list.size()-1)
    		{
    			vp.setCurrentItem(0,true);
    		}
    		else
    		{
    			vp.setCurrentItem(i+1,true);
    		}
    		sendEmptyMessageDelayed(1, 2000);
    	};
    };
    
    class MyAdapter extends PagerAdapter
    {

		@Override
		public int getCount() {

			return list.size();
		}
		@Override
		public Object instantiateItem(ViewGroup container, int position) {
			container.addView(list.get(position));
			return list.get(position);
		}
		@Override
		public void destroyItem(ViewGroup container, int position, Object object) {
		container.removeView(list.get(position));	
		}
		
		@Override
		public boolean isViewFromObject(View arg0, Object arg1) {
			return arg0==arg1;
		}
		
		//android.support.v4.view.PagerTitleStrip 给pager界面加标题
		@Override
		public CharSequence getPageTitle(int position) {
			return tList.get(position);
		}
    }
}
</span>




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要实现ViewPager的自动轮播,你可以按照以下步骤进行操作: 1. 首先,在布局文件中添加ViewPager控件,并设置其相关属性,如布局宽高、指示器等。 2. 在代码中,创建一个Handler对象和一个Runnable对象,用于实现自动轮播的定时任务。 ```java private ViewPager viewPager; private int currentPage = 0; private Timer timer; private final long DELAY_MS = 500; // 延迟时间 private final long PERIOD_MS = 3000; // 滚动间隔时间 @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); viewPager = findViewById(R.id.viewPager); // 设置ViewPager的Adapter以及其他属性 final Handler handler = new Handler(); final Runnable runnable = new Runnable() { public void run() { if (currentPage == NUM_PAGES) { currentPage = 0; } viewPager.setCurrentItem(currentPage++, true); } }; timer = new Timer(); timer.schedule(new TimerTask() { @Override public void run() { handler.post(runnable); } }, DELAY_MS, PERIOD_MS); } ``` 3. 在Activity的`onDestroy`方法中,取消定时任务,避免内存泄漏。 ```java @Override protected void onDestroy() { super.onDestroy(); if (timer != null) { timer.cancel(); timer = null; } } ``` 这样,ViewPager就会自动进行轮播了。注意,上述代码中的`NUM_PAGES`是ViewPager中页面的数量,你需要根据实际情况进行替换。另外,你还可以根据需求添加页面切换的动画效果、手势滑动等功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值