一、几张图片组成欢迎界面 下方有几个点对应每个图片 当图片被选中时对应的点会变亮,当对应的点被点击时也会切换到指定画面

以下是代码

 package com.example.viewpager_1;

 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.support.v4.view.ViewPager.OnPageChangeListener;
import android.view.View;
import android.view.ViewGroup; import android.widget.ImageView;
import android.widget.ImageView.ScaleType;
import android.widget.LinearLayout;
import android.widget.LinearLayout.LayoutParams;
import android.widget.Toast; public class MainActivity extends Activity { private ViewPager vPager;
private List<ImageView> views;//ViewPager中显示的所有页面,PagerAdapter使用的数据源
private PagerAdapter adapter; private LinearLayout navLayout;//导航布局空间 private LinearLayout.LayoutParams layoutParams;//线性布局中子控件使用的布局参数,作用设置子控件大小,外边距 @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
navLayout = (LinearLayout) findViewById(R.id.navLayouttId); vPager = (ViewPager) findViewById(R.id.viewPager); inintViews();//初始化显示的页面
//设置viewpager的页面滑动事件
vPager.setOnPageChangeListener(new OnPageChangeListener() {
@Override
public void onPageSelected(int position) {
// 指定的位置的页面被选择
selectNav(position);
} private void selectNav(int position) {
// 选择指定位置的导航图片为选择图片,选择的图片要重置一下
ImageView navImg = null;
//遍历 导航布局中所有的子控件,判断子控件的位置是否为选择位置,若是,则改变图片的内容
for(int i=0;i<navLayout.getChildCount();i++){
navImg = (ImageView) navLayout.getChildAt(i );//获取布局中指定位置的子控件
if(i==position)
navImg.setImageResource(R.drawable.page_now);
else
navImg.setImageResource(R.drawable.page);
}
}
/*
* 第一个参数: 滚动页面开始的位置
* 第二个参数: 两个页面之间滚动的偏移量,范围是0-1
* 第三个参数:两个页面之间滚动的像素偏移量
*/
@Override
public void onPageScrolled(int position, float offset, int offsetPixels) {
// TODO 从当前页面位置开始滚动事件
} @Override
public void onPageScrollStateChanged(int state) {
// 页面滚动状态发生变化时事件: 开始滚动,停止滚动,正在设置页面
// ViewPager.SCROLL_STATE_DRAGGING 开始滚动
// ViewPager.SCROLL_STATE_IDLE 停止滚动
// ViewPager.SCROLL_STATE_SETTLING 正在设置页面,即将要停止,并且设置当前的页面 switch (state) {
case ViewPager.SCROLL_STATE_DRAGGING:
break;
case ViewPager.SCROLL_STATE_IDLE:
break;
case ViewPager.SCROLL_STATE_SETTLING:
break;
default:
break;
}
}
});
}
private void inintViews() {
// TODO 加载viewpager中显示的额页面
views = new ArrayList<ImageView>();
ImageView imgView = null;
ImageView navImg = null;
layoutParams = new LayoutParams(LayoutParams.WRAP_CONTENT,LayoutParams.WRAP_CONTENT);
layoutParams.leftMargin=20;
layoutParams.rightMargin=20;//px
for(int i=1;i<=3;i++){
//实例化viewpager中要显示图片的空间
imgView = new ImageView(getApplicationContext());
imgView.setScaleType(ScaleType.CENTER_CROP); //根据资源名和类型获取 这一资源的标示 -->R.drawable.slide1
int resId = getResources().getIdentifier("slide"+i, "drawable", getPackageName());
imgView.setImageResource(resId);//设置图片控件显示的图片资源
if(i==3){
imgView.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Toast.makeText(getApplicationContext(), "正在跳转。。。。", 0).show();
}
});
}
views.add(imgView);//将实例化的空间添加到数据源中。 navImg = new ImageView(getApplicationContext());
navImg.setScaleType(ScaleType.CENTER_CROP);
if(i==1)
navImg.setImageResource(R.drawable.page_now);
else
navImg.setImageResource(R.drawable.page); //设置导航图片的标签: 当前导航图片的位置
navImg.setTag(i-1);
navImg.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
// 点击导航图片的事件方法: 读取图片控件中的标签,转化为与ViewPager页面对应的位置,最后选择页面
int position = (Integer) v.getTag();
vPager.setCurrentItem(position);//切换viewpager显示的位置
}
});
navLayout.addView(navImg,layoutParams);
}
//实例化PagerAdapter适配器
adapter = new WelcomePagerAdapter();
vPager.setAdapter(adapter);
//设置移除UI的间隔大小
// vPager.setOffscreenPageLimit(3);//默认值不能小于1,建议不要 改变默认值。
}
//声明PagerAdapter的子类,用于管理ViewPager中显示的View控件
class WelcomePagerAdapter extends PagerAdapter{
@Override
public int getCount() {
// TODO 显示返回页面的总大小
return views.size();
}
@Override
public Object instantiateItem(ViewGroup container, int position) {
// TODO 获取指定位置的view,并增加到ViewPager中,同时作为当前页面的数据返回
container.addView(views.get(position));
return views.get(position);//作为当前页面的数据返回
}
@Override
public void destroyItem(ViewGroup container, int position, Object object) {
// TODO 当前 位置与viewpager当中正显示页面的位置的间隔超出了一页时,需要将当前
//位置的页面移除掉.同时 实例化三个页面
container.removeView(views.get(position));
}
//固定写法;
@Override
public boolean isViewFromObject(View arg0, Object arg1) {
// TODO 判断当前显示的页面的UI对象和数据对象是否 一致 return arg0==arg1;
}
}
}

MainActivity.java

 <FrameLayout 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"
tools:context=".MainActivity" > <!-- 使用v4包下的可左右滑动的控件,其显示的页面需要通过PagerAdapter适配器增加或移除 --> <android.support.v4.view.ViewPager
android:id="@+id/viewPager"
android:layout_width="match_parent"
android:layout_height="match_parent" /> <!-- 导航小图片所在的布局 -->
<LinearLayout
android:id="@+id/navLayoutId"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_gravity="bottom"
android:layout_marginBottom="10dp"
android:background="#4000"
android:gravity="center"
android:orientation="horizontal"
android:padding="20dp" /> </FrameLayout>

activity_main.xml

效果图

ViewPager欢迎界面的更多相关文章

  1. android笔记:ViewPager实现界面的滑动

    最近在学习ViewPager实现界面的滑动,拜读了郭神的博客文章,并抽取归纳了自己对ViewPager的理解. ViewPager实现界面滑动的步骤如下: 1.在xml布局内加入控件android.s ...

  2. 自定义viewpager的界面切换动画

    核心操作: 1.创建一个类实现 android.support.v4.view.ViewPager.PageTransformer 根据 position 实现判断哪个界面进行界面切换动画 publi ...

  3. 【笔记】WPF实现ViewPager引导界面效果及问题汇总

    最近在开发项目的首次使用引导界面时,遇到了问题,引导界面类似于安卓手机ViewPager那样的效果,希望通过左右滑动手指来实现切换不同页面,其间伴随动画. 实现思路: 1.界面布局:新建一个UserC ...

  4. ViewPager + Fragment 实现主界面底部导航栏

    1. 四个类似的Frament布局 tab_main_fragment.xml <LinearLayout xmlns:android="http://schemas.android. ...

  5. Android中使用ViewPager实现广告条

    我们在使用电商或视频的手机客户端时,通常会看到广告条的效果.在网上搜索时才知道使用的是ViewPager,于是自己也做了一个Demo. 以下是效果图: 图中包括背景图片.文字描述以及白点. 其中Vie ...

  6. ViewPager空指针错误,android.support.v4.view.ViewPager.onSaveInstanceState

    support.v4 包为我们提供了一个非常实用的滑动控件ViewPager,在使用ViewPager时有一个需要注意的地方: 即: android.support.v4.view.ViewPager ...

  7. ViewPager和View的事件响应规则

    案例背景: 当我们实现viewpager的自动切换界面操作的时候,如果需要增加点击图片viewpager停止自动切换,松开手指viewpager自动切换又继续执行的逻辑,正常思维下实现代码如下所示: ...

  8. Viewpager以及ViewPagerIndicator的相关使用

    ViewPagerIndicator开源框架可以用来在ViewPager上方做标题,可以在ViewPager下方做跟随移动的小圆点,这个类库必须和自己的项目在电脑的同一磁盘盘符下,比如都在D盘或者E盘 ...

  9. ViewPagerWithViewDemo【ViewPager和View搭配以及演示获取里面的值和CheckBox单选效果】

    版权声明:本文为HaiyuKing原创文章,转载请注明出处! 前言 简单记录下ViewPager和自定义布局view的搭配使用以及布局文件中单选效果.获取viewpager布局内部值的功能. 效果图 ...

随机推荐

  1. java设计模式—工厂模式

    一.工厂模式主要是为创建对象提供过渡接口,以便将创建对象的具体过程屏蔽隔离起来,达到提高灵活性的目的. 工厂模式在<Java与模式>中分为三类:1)简单工厂模式(Simple Factor ...

  2. pycharm格式报错: Remove redundant parentheses

    处理:所在代码行,最外层括号去掉

  3. 运维不得不知的 Linux 性能监控、测试、优化工具

    Linux 平台上的性能工具有很多,眼花缭乱,长期的摸索和经验发现最好用的还是那些久经考验的.简单的小工具.系统性能专家 Brendan D. Gregg 在 LinuxCon NA 2014 大会上 ...

  4. 配置IIS,以在局域网内访问发布的web站点

    在windows 7或win8 中 配置IIS, 以在局域网内访问自己发布的web 网站或应用程序.主要配置步骤如下: 1. 打开 win7 或 win8 控制面板,选择: 打开或关闭windws 功 ...

  5. django项目环境设置

    1.连接数据库,如mysql DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', 'NAME': 'django_comi ...

  6. C基本语句和运算符

    1,逗号运算符

  7. bootstrapValidator针对设置赋值进行验证

    bootstrapValidator在提交的时候可以进行验证,但是对于点击输入框进行赋值的时候验证失效. 解决方法: 然后在设置change方法方可解决.

  8. JPA和Hibernate到底是什么关系???

    转自:https://www.cnblogs.com/mosoner/p/9494250.html 在学习框架的过程中,发现学的东西很多,但是感觉他们之间的联系区别都不是很了解,知道JPA可以去实现持 ...

  9. 10 python os&sys 模块

    1.os模块 os模块提供了很多允许你的程序与操作系统直接交互的功能 os模块的主要功能:处理文件和目录,系统相关,执行命令,管理进程 检验给出的路径是否是一个文件:os.path.isfile() ...

  10. 5 Python3 函数进阶&迭代器与生成器

    1.函数进阶 1.1.名称空间 又名name space, 顾名思义就是存放名字的地方,存什么名字呢?举例说明,若变量x=1,1存放于内存中,那名字x存放在哪里呢?名称空间正是存放名字x与1绑定关系的 ...