Android viewpager在最后一页滑动之后跳转到主页面的实例代码

Android viewpager在最后一页滑动之后跳转到主页面的实例代码,第1张

概述先给大家说下实现思路主要有是两个监听:一是addOnPageChangeListener();二是setOnTouchListener();

先给大家说下实现思路

主要有是两个监听:

一是addOnPagechangelistener();二是setontouchListener();

addOnPagechangelistener()主要是为了获取position(滑动到了第几页)

setontouchListener()主要是判断在最后一页中是否向左滑动了,然后进入主页

在没给大家分享代码之前,先给大家展示下效果图:

主要功能代码

addOnPagechangelistener();vIEwPager.addOnPagechangelistener(new VIEwPager.OnPagechangelistener() {@OverrIDepublic voID onPageScrolled(int position,float positionOffset,int positionOffsetPixels) {}@OverrIDepublic voID onPageSelected(int position) {currentItem = position;//获取位置,即第几页Log.i("GuIDe","监听改变"+position);}@OverrIDepublic voID onPageScrollStateChanged(int state) {}}); setontouchListener();vIEwPager.setontouchListener(new VIEw.OntouchListener() {float startX;float startY;//没有用到float endX;float endY;//没有用到@OverrIDepublic boolean ontouch(VIEw v,MotionEvent event) {switch (event.getAction()){case MotionEvent.ACTION_DOWN:startX=event.getX();startY=event.getY();break;case MotionEvent.ACTION_UP:endX=event.getX();endY=event.getY();WindowManager windowManager= (WindowManager) getApplicationContext().getSystemService(Context.WINDOW_SERVICE);//获取屏幕的宽度Point size = new Point();windowManager.getDefaultdisplay().getSize(size);int wIDth=size.x;//首先要确定的是,是否到了最后一页,然后判断是否向左滑动,并且滑动距离是否符合,我这里的判断距离是屏幕宽度的4分之一(这里可以适当控制)if(currentItem==(imageVIEws.size()-1)&&startX-endX>=(wIDth/4)){Log.i(LOG,"进入了触摸");goToMainActivity();//进入主页overrIDePendingTransition(R.anim.slIDe_in_right,R.anim.slIDe_in_left);//这部分代码是切换Activity时的动画,看起来就不会很生硬}break;}return false;}});

以下是全部代码

GuIDeActivitypackage com.tc.mobileshop;import androID.content.Context;import androID.content.Intent;import androID.graphics.Point;import androID.support.v4.vIEw.PagerAdapter;import androID.support.v4.vIEw.VIEwPager;import androID.support.v7.app.AppCompatActivity;import androID.os.Bundle;import androID.util.Log;import androID.vIEw.display;import androID.vIEw.MotionEvent;import androID.vIEw.VIEw;import androID.vIEw.VIEwGroup;import androID.vIEw.WindowManager;import androID.Widget.ImageVIEw;import com.tc.mobileshop.utils.displayUtils;import java.util.ArrayList;import java.util.List;public class GuIDeActivity extends AppCompatActivity {private static final String LOG = "GuIDeActivity";int touchCount;int currentItem;List<Integer> imageIDList;List<ImageVIEw> imageVIEws;VIEwPager vIEwPager;@OverrIDeprotected voID onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentVIEw(R.layout.activity_guIDe);//初始化引导数据initGuIDeData();//初始化引导页initGuIDeVIEw();//初始化分页控件iniVIEw();}/*** 初始化引导页数据*/private voID initGuIDeData() {imageIDList = new ArrayList();imageIDList.add(R.mipmap.apk_img1);imageIDList.add(R.mipmap.apk_img2);imageIDList.add(R.mipmap.apk_img3);}/*** 初始化引导页*/private voID initGuIDeVIEw() {imageVIEws = new ArrayList<>();for (int i = 0; i < imageIDList.size(); i++) {imageVIEws.add(new ImageVIEw(this));}}/*** 初始化分页控件*/private voID iniVIEw() {vIEwPager = (VIEwPager) findVIEwByID(R.ID.guIDe_pager);vIEwPager.setAdapter(new GuIDeAdapter());vIEwPager.addOnPagechangelistener(new VIEwPager.OnPagechangelistener() {@OverrIDepublic voID onPageScrolled(int position,int positionOffsetPixels) {}@OverrIDepublic voID onPageSelected(int position) {currentItem = position;Log.i("GuIDe","监听改变"+position);}@OverrIDepublic voID onPageScrollStateChanged(int state) {}});vIEwPager.setontouchListener(new VIEw.OntouchListener() {float startX;float startY;float endX;float endY;@OverrIDepublic boolean ontouch(VIEw v,MotionEvent event) {switch (event.getAction()){case MotionEvent.ACTION_DOWN:startX=event.getX();startY=event.getY();break;case MotionEvent.ACTION_UP:endX=event.getX();endY=event.getY();WindowManager windowManager= (WindowManager) getApplicationContext().getSystemService(Context.WINDOW_SERVICE);//获取屏幕的宽度Point size = new Point();windowManager.getDefaultdisplay().getSize(size);int wIDth=size.x;//首先要确定的是,是否到了最后一页,然后判断是否向左滑动,并且滑动距离是否符合,我这里的判断距离是屏幕宽度的4分之一(这里可以适当控制)if(currentItem==(imageVIEws.size()-1)&&startX-endX>0&&startX-endX>=(wIDth/4)){Log.i(LOG,"进入了触摸");goToMainActivity();overrIDePendingTransition(R.anim.slIDe_in_right,R.anim.slIDe_in_left);}break;}return false;}});}private voID goToMainActivity() {Intent intent=new Intent(this,MainActivity.class);startActivity(intent);finish();}/*** VIEwpager适配器*/private class GuIDeAdapter extends PagerAdapter {@OverrIDepublic int getCount() {return imageVIEws.size();}/*** 判断当前分页是不是vIEw* 由于VIEwPager里面的分页可以填入Fragment** @param vIEw* @param object* @return*/@OverrIDepublic boolean isVIEwFromObject(VIEw vIEw,Object object) {return vIEw == object;}/*** 清理内存* 从第一页滑动到第二页,此时第一页的内存应该释放** @param container* @param position* @param object*/@OverrIDepublic voID destroyItem(VIEwGroup container,int position,Object object) {container.removeVIEw(imageVIEws.get(position));//释放滑动过后的前一页}/*** 得到---->暂时是没有用的** @param object* @return*/@OverrIDepublic int getItemposition(Object object) {return super.getItemposition(object);}/*** 初始化分页** @param container* @param position* @return*/@OverrIDepublic Object instantiateItem(VIEwGroup container,int position) {ImageVIEw imageVIEw = imageVIEws.get(position);imageVIEw.setimageResource(imageIDList.get(position));VIEwGroup.LayoutParams vIEwLayoutParams = new VIEwGroup.LayoutParams(displayUtils.dip2px(GuIDeActivity.this,170),displayUtils.dip2px(GuIDeActivity.this,200));container.addVIEw(imageVIEw,vIEwLayoutParams);//设置图片的宽高return imageVIEw;}}}

以下为动画资源代码

slIDe_in_left.xml

<?xml version="1.0" enCoding="utf-8"?><set xmlns:androID="http://schemas.androID.com/apk/res/androID"><translateandroID:duration="1000"androID:fromXDelta="0%p"androID:toXDelta="-100%"/></set> slIDe_in_right.xml<?xml version="1.0" enCoding="utf-8"?><set xmlns:androID="http://schemas.androID.com/apk/res/androID"><translateandroID:duration="1000"androID:fromXDelta="100%p"androID:toXDelta="0"/></set>

以上所述是小编给大家介绍的AndroID vIEwpager在最后一页滑动之后跳转到主页面的实例代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对编程小技巧网站的支持!

总结

以上是内存溢出为你收集整理的Android viewpager在最后一页滑动之后跳转到主页面的实例代码全部内容,希望文章能够帮你解决Android viewpager在最后一页滑动之后跳转到主页面的实例代码所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/1148757.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-31
下一篇 2022-05-31

发表评论

登录后才能评论

评论列表(0条)

保存