我们在一个apk中第一次開始的时候,会有一个guide界面。一般使用ViewPager来完毕。

布局文件例如以下:

<?

xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent" > <android.support.v4.view.ViewPager
android:id="@+id/guide_viewpager"
android:layout_width="match_parent"
android:layout_height="match_parent" >
</android.support.v4.view.ViewPager> <Button
android:id="@+id/guide_button"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentBottom="true"
android:layout_centerHorizontal="true"
android:layout_marginBottom="20dp"
android:paddingLeft="30dp"
android:paddingRight="30dp"
android:text="開始体验"
android:textSize="20sp"
android:visibility="gone" /> </RelativeLayout>

这就是一个想到Activity GuideActivity.java

package com.xlg.news;

import java.util.ArrayList;
import java.util.List; import com.xlg.news.adapters.WelcomeViewPagerAdapter;
import com.xuliugen.newsclient.R; import android.app.Activity;
import android.content.Intent;
import android.opengl.Visibility;
import android.os.Bundle;
import android.support.v4.view.ViewPager;
import android.support.v4.view.ViewPager.OnPageChangeListener;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.ImageView; public class GuideActivity extends Activity { private ViewPager guideViewPager;
private Button guideButton; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.guide_activity);
guideViewPager = (ViewPager) this.findViewById(R.id.guide_viewpager);
guideButton = (Button) this.findViewById(R.id.guide_button); //获取图片ImageView资源
final List<ImageView> imageViewsList = initData(); WelcomeViewPagerAdapter viewPagerAdapter = new WelcomeViewPagerAdapter(GuideActivity.this,imageViewsList);
guideViewPager.setAdapter(viewPagerAdapter); /**
* 设置guide ViewPager滑动的时候的监听事件
*/
guideViewPager.setOnPageChangeListener(new OnPageChangeListener() { /**
* 已经选中某一页的时候
*/
@Override
public void onPageSelected(int position) {
//已经到了最后一页
if(position == imageViewsList.size()-1){
guideButton.setVisibility(View.VISIBLE);
guideButton.setOnClickListener(new OnClickListener() { @Override
public void onClick(View v) {
//进入最后一页设置向导页,点击按钮完毕功能
}
});
}else{
guideButton.setVisibility(View.GONE);
}
} /**
*
* 在页面的滑动过程中
*/
@Override
public void onPageScrolled(int position, float arg1, int arg2) { } /**
*
* 滑动状态发生改变的状态
*/
@Override
public void onPageScrollStateChanged(int position) { }
});
} private List<ImageView> initData() {
List<ImageView> imageViewsList = new ArrayList<ImageView>();
// 加入图片控件
ImageView imageView1 = new ImageView(getApplicationContext());
imageView1.setBackgroundResource(R.drawable.guide_image1);
ImageView imageView2 = new ImageView(getApplicationContext());
imageView2.setBackgroundResource(R.drawable.guide_image2);
ImageView imageView3 = new ImageView(getApplicationContext());
imageView3.setBackgroundResource(R.drawable.guide_image3);
imageViewsList.add(imageView1);
imageViewsList.add(imageView2);
imageViewsList.add(imageView3);
return imageViewsList;
} }

当中的适配器例如以下:

package com.xlg.news.adapters;

import java.util.List;

import android.content.Context;
import android.support.v4.view.PagerAdapter;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ImageView; /**
* 第一次启动页面的ViewPager适配器
* @author xuliugen
*/
public class WelcomeViewPagerAdapter extends PagerAdapter { private Context mContext;
private List<ImageView> mImageViewsList; public WelcomeViewPagerAdapter(Context context,
List<ImageView> imageViewsList) {
mContext = context;
mImageViewsList = imageViewsList;
} @Override
public int getCount() {
return mImageViewsList.size();
} @Override
public boolean isViewFromObject(View view, Object object) {
return view == object;
} /**
* 给制定的viewpager加入一个view的方法
*/
@Override
public Object instantiateItem(ViewGroup container, int position) {
//加入一个imageView
container.addView(mImageViewsList.get(position));
return mImageViewsList.get(position);
} /**
* 给制定的viewpager移除一个view的方法
*/
@Override
public void destroyItem(ViewGroup container, int position, Object object) {
container.removeView((View)object);
}
}

Android中ViewPager的使用的更多相关文章

  1. Android中viewPager的一两点使用

    Android中viewPager的一两点使用 viewPager是谷歌官方提供的一种方便实现页面滑动效果的控件,可以直接使用也可以和fragment联合使用.这里只简单说下直接使用. 使用viewP ...

  2. Android中ViewPager+Fragment取消(禁止)预加载延迟加载(懒加载)问题解决方案

    转载请注明出处:http://blog.csdn.net/linglongxin24/article/details/53205878本文出自[DylanAndroid的博客] Android中Vie ...

  3. Android中ViewPager实现滑动条及与Fragment结合的实例教程

    ViewPager类主要被用来实现可滑动的视图功能,这里我们就来共同学习Android中ViewPager实现滑动条及与Fragment结合的实例教程,需要的朋友可以参考下 自主实现滑动指示条先上一个 ...

  4. android中viewPager+fragment实现的屏幕左右切换(进阶篇)

    Fragment支持在不同的Activity中使用并且可以处理自己的输入事件以及生命周期方法等.可以看做是一个子Activity. 先看一下布局: 1 <LinearLayout xmlns:a ...

  5. android中viewPager实现的屏幕左右切换(入门篇)

    大多数的APP都可以实现几个屏幕来回的切换, 首先新建两个Activity,内容随意,布局随意.接下来在MainActivity.xml: <RelativeLayout xmlns:andro ...

  6. android 中 viewpager 滑动的指示器

    先看下效果图: 这个需要用到1个开源的 库,这个后面也会说下的. 工程目录: 1. MainActivity.java public class MainActivity extends Fragme ...

  7. android 中 ViewPager 的平常用法 ViewPager+ Views

    延续前面几个的经常用到的ViewPager, 直接加载各种不同的 View 工程目录: 代码: public class ViewActivity extends Activity { // 每个Vi ...

  8. Android中ViewPager如何设置不能通过屏幕左右滑动来切换页面

    //很多时候,我想禁止用户通过屏幕的左右滑动来切换界面!如何实现! //创建一个类继承viewpager,实现 onTouchEvent   和   onInterceptTouchEvent方法,都 ...

  9. Android中ViewPager动态创建的ImageView铺满屏幕

    ImageView imageView=new ImageView(context); imageView.setScaleType(ScaleType.FIT_XY);//铺满屏幕

随机推荐

  1. (三)React基础

    3-1 使用React编写TodoList功能 import { Fragment} from ‘react’ Fragment是占位符 用于替代最外层div元素, 防止生成的元素会有两层div嵌套这 ...

  2. 微信小程序优化

    setData setData 是小程序开发中使用最频繁的接口,也是最容易引发性能问题的接口.在介绍常见的错误用法前,先简单介绍一下 setData 背后的工作原理. 工作原理 小程序的视图层目前使用 ...

  3. 洛谷P4894 GodFly求解法向量

    如果没有学过向量相关知识请出门右转高中数学必修四~~~ 当然如果你和我一样也是小学生我也不反对 首先说结论:\(\vec{z}=(y1z2-y2z1,z1x2-z2x1,x1y2-x2y1)\) 其实 ...

  4. [luogu]P4316 绿豆蛙的归宿(拓扑排序,期望)

    P4316 绿豆蛙的归宿 题目背景 随着新版百度空间的上线,Blog宠物绿豆蛙完成了它的使命,去寻找它新的归宿. 题目描述 给出一个有向无环图,起点为1终点为N,每条边都有一个长度,并且从起点出发能够 ...

  5. 对于树的序列化,用了stream,很好

    https://leetcode.com/problems/serialize-and-deserialize-binary-tree/?tab=Description 下面这个解法里面的C++部分很 ...

  6. hadoop学习;datajoin;chain签名;combine()

    hadoop有种简化机制来管理job和control的非线性作业之间的依赖.job对象时mapreduce的表现形式.job对象的实例化可通过传递一个jobconf对象到作业的构造函数中来实现. x. ...

  7. 怎样創建 iOS 展開式 UITableView?

    原文:http://www.appcoda.com.tw/expandable-table-view/ 译者:kmyhy(appcoda的驻站译者) 幾乎全部的 App 都會以導航的方式向用戶展示多個 ...

  8. HTML5 canvas炫酷棱镜效果的幻灯片特效

    这是一款效果很炫酷华丽的HTML5 canvas带棱镜效果的幻灯片特效. 这个特效在每个幻灯片的前面放置一个图形.并将图形制作为三棱镜效果.它底下的幻灯片图片会被"折射"到棱镜上面 ...

  9. 与Greenplum度过的三个星期

    5月4日-5月24日.断断续续折腾了三个星期的Greenplum,总算告一段落了:扩容,发现扩不成容.仅仅好升级.升级,发现一堆错误,仅仅好暂停修复数据库:修好了,继续升级.升完级,发现错误.修啊修啊 ...

  10. mysql---左连接、右连接、内连接之间的差别与联系

    现有两张表 第一张表为男生表,记录了男生的姓名和配偶的编号 watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvbXlfbWFv/font/5a6L5L2T/fo ...