Android引导页面的简单实现
作者:wangwo1991 发布时间:2023-08-06 04:24:32
标签:Android,引导页
第一次进入应用的时候,都会有一个引导页面,引导页面的实现起来也很简单,实现的方式也有很多,下面是自己写的一个引导页面的效果,大致的实现思路为:
最外层是一个FragmentActivity,里面包含4个fragment,在fragment中给ViewPager开一个循环,这样实现了图片播,其实效果就是在FragmentActivity中几个fragment滑动切换,
fragment中ViewPager无限轮播和滑动切换;
下面为代码实现:
public class MainActivity extends ActionBarActivity {
private ViewPager viewpager;
private FragmentManager fm;
private ViewPagerAdapter adapter;
private ArrayList<Object> items = new ArrayList<Object>();
private Button btn_guide;
private View point1, point2, point3, point4;
private int choiceBg = R.drawable.shape_bule_point;// 被选背景
private int unChoiceBg = R.drawable.shape_center_point_red;// 未被选背景
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
requestWindowFeature(Window.FEATURE_NO_TITLE);
setContentView(R.layout.activity_main);
initView();
}
private void initView() {
btn_guide = (Button) findViewById(R.id.btn_guide);
point1 = findViewById(R.id.point1);
point2 = findViewById(R.id.point2);
point3 = findViewById(R.id.point3);
point4 = findViewById(R.id.point4);
viewpager = (ViewPager) findViewById(R.id.viewpager);
fm = this.getSupportFragmentManager();
items.add(new FirstFragment());
items.add(new SecondFragment());
items.add(new ThridFragment());
items.add(new FourFragment());
adapter = new ViewPagerAdapter(fm, items);
viewpager.setAdapter(adapter);
viewpager.setCurrentItem(0, false);
viewpager.setOffscreenPageLimit(items.size());
// 被选设置为蓝色
point1.setBackgroundResource(choiceBg);
viewpager.setOnPageChangeListener(new GuidePageListener());
}
/**
* viewpager的滑动监听
*
* @author Kevin
*
*/
class GuidePageListener implements OnPageChangeListener {
// 滑动事件
@Override
public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {
}
// 某个页面被选中
@Override
public void onPageSelected(int position) {
if (position == 0) {
setPointBg(choiceBg, unChoiceBg, unChoiceBg, unChoiceBg);
} else if (position == 1) {
setPointBg(unChoiceBg, choiceBg, unChoiceBg, unChoiceBg);
} else if (position == 2) {
setPointBg(unChoiceBg, unChoiceBg, choiceBg, unChoiceBg);
} else {
setPointBg(unChoiceBg, unChoiceBg, unChoiceBg, choiceBg);
}
if (position == items.size() - 1) {// 最后一个页面
btn_guide.setVisibility(View.VISIBLE);// 显示开始体验的按钮
} else {
btn_guide.setVisibility(View.INVISIBLE);
}
}
// 滑动状态发生变化
@Override
public void onPageScrollStateChanged(int state) {
}
}
/**
* 设置被选小圆点的背景颜色
*
* @param pointBg1
* @param pointBg2
* @param pointBg3
* @param pointBg4
*/
private void setPointBg(int pointBg1, int pointBg2, int pointBg3, int pointBg4) {
point1.setBackgroundResource(pointBg1);
point2.setBackgroundResource(pointBg2);
point3.setBackgroundResource(pointBg3);
point4.setBackgroundResource(pointBg4);
}
}
在这里要注意ViewPager和fragment在滑动变化时,改变底部小圆点被选的颜色;
public class HomeAdapter extends PagerAdapter {
private List<GuiderInfo> data;
private ImageCycleViewListener mImageCycleViewListener;
private Context context;
public HomeAdapter(Context context, List<GuiderInfo> data, ImageCycleViewListener mImageCycleViewListener) {
this.context = context;
this.mImageCycleViewListener = mImageCycleViewListener;
this.data = new ArrayList<GuiderInfo>();
if (data != null) {
this.data.addAll(data);
}
}
public void notifyData(List<GuiderInfo> data) {
if (data != null) {
this.data.clear();
this.data.addAll(data);
}
notifyDataSetChanged();
}
// 当天viewpager有多少个条目
LinkedList<ImageView> imageList = new LinkedList<ImageView>();
@Override
public int getCount() {
if (data.size() != 0) {
return Integer.MAX_VALUE;// 无限循环
} else {
return 0;
}
}
// 判断返回的对象和加载view对象关系
@Override
public boolean isViewFromObject(View arg0, Object arg1) {
return arg0 == arg1;
}
// 销毁一个条目
@Override
public void destroyItem(ViewGroup container, int position, Object object) {
// super.destroyItem(container, position, object);
ImageView view = (ImageView) object;
imageList.add(view);// 把移除的对象添加到缓存集合中
container.removeView(view);
}
// 创建一个条目
@Override
public Object instantiateItem(ViewGroup container, int position) {
int index = 0;
if (data.size() != 0) {
index = position % data.size();
}
final ImageView image;
if (imageList.size() > 0) {
image = imageList.remove(0);
} else {
image = new ImageView(context);
}
// BitmapUtils bitmapUtils = BitMapHelper.getBitmapUtils();
final GuiderInfo vo = data.get(index);
if (vo != null) {
// String url = vo.url;
// bitmapUtils.display(image, url, new BitmapLoadCallBack<View>() {
//
// @SuppressWarnings("deprecation")
// @Override
// public void onLoadCompleted(View arg0, String arg1, Bitmap bitmap, BitmapDisplayConfig arg3, BitmapLoadFrom arg4) {
// image.setImageBitmap(null);
// BitmapDrawable ob = new BitmapDrawable(context.getResources(), bitmap);
// image.setBackgroundDrawable(ob);
// }
//
// @Override
// public void onLoadFailed(View arg0, String arg1, Drawable arg2) {
// // TODO Auto-generated method stub
//
// }
// });
int imageid = vo.imageid;
image.setImageResource(imageid);
// bitmapUtils.display(image, url);
}
final int pos = index;
if (mImageCycleViewListener != null) {
image.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
mImageCycleViewListener.onImageClick(vo, pos, image);
}
});
}
container.addView(image);// 加载的view对象
return image;// 返回的对象
}
/**
* 轮播控件的监听事件
*
* @author minking
*/
public static interface ImageCycleViewListener {
/**
* 单击图片事件
*
* @param position
* @param imageView
*/
public void onImageClick(GuiderInfo info, int postion, View imageView);
}
}
public class FirstFragment extends Fragment implements ImageCycleViewListener {
private View view;
private ViewPager header_view;
private HomeAdapter adapter;
private List<GuiderInfo> data = new ArrayList<GuiderInfo>();
private boolean flag;
private TextView tv_dis;
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
view = inflater.inflate(R.layout.first_fragment, container, false);
setData();
initView();
return view;
}
@SuppressWarnings("deprecation")
private void initView() {
tv_dis = (TextView) view.findViewById(R.id.tv_dis);
header_view = (ViewPager) view.findViewById(R.id.header_view);
adapter = new HomeAdapter(getActivity(), data, this);
header_view.setAdapter(adapter);
header_view.setOnPageChangeListener(new OnPageChangeListener() {
@Override
public void onPageSelected(int arg0) {
//计算当前选中的图片index
int index = arg0 % 2;
System.out.println("-----------index" + index);
GuiderInfo dtGzsApplyCenterHeader = data.get(index);
tv_dis.setText(""+dtGzsApplyCenterHeader.event_content);
}
@Override
public void onPageScrolled(int arg0, float arg1, int arg2) {
}
@Override
public void onPageScrollStateChanged(int arg0) {
}
});
// 设置中间值
final AuToRunTask run = new AuToRunTask();
header_view.setCurrentItem(1000 * data.size());// 实现左右两边都可以滑动
header_view.setOnTouchListener(new OnTouchListener() {
@Override
public boolean onTouch(View v, MotionEvent event) {
switch (event.getAction()) {
case MotionEvent.ACTION_DOWN:// 按下
run.stop();
break;
case MotionEvent.ACTION_CANCEL:// 事件取消
case MotionEvent.ACTION_UP:// 抬起
run.start();
break;
default:
break;
}
return false;// viewpager触摸事件返回值要是fasle不能为true
}
});
run.start();// 开启轮播
}
@Override
public void onImageClick(GuiderInfo info, int postion, View imageView) {
}
// 自动轮播
class AuToRunTask implements Runnable {
@Override
public void run() {
if (flag) {
// 取消之前的任务
DensityUtil.cancle(this);
// 获取当前条目
int currentItem = header_view.getCurrentItem();
currentItem++;
header_view.setCurrentItem(currentItem);
// 延迟执行当前的一个任务
DensityUtil.postDelayed(this, 2000);// 递归调用
}
}
public void start() {
if (!flag) {
// 取消之前的任务
DensityUtil.cancle(this);
flag = true;
// 延迟执行当前的一个任务
DensityUtil.postDelayed(this, 1000);// 递归调用
}
}
public void stop() {
if (flag) {
flag = false;
DensityUtil.cancle(this);
}
}
}
private void setData() {
GuiderInfo vo = new GuiderInfo();
vo.imageid = R.drawable.shape_red;
vo.event_content="红色";
data.add(vo);
GuiderInfo vo1 = new GuiderInfo();
vo1.imageid = R.drawable.shape_yellow;
vo1.event_content="黄色";
data.add(vo1);
}
}
以上为效果实现的主要代码,效果运行如下:
上面的效果图还有一小部分效果未展示出来,其实上面的圆是循环轮播的,同时也是可以滑动的;


猜你喜欢
- 题主要区分清楚内码(internal encoding)和外码(external encoding)就好了。内码是程序内部使用的字符编码,特
- Service的生命周期 (适用于2.1及以上)1. 被startService的无论是否有任何活动绑定到该Service,都在后台运行。o
- 继续练习自定义View,这次带来的圆形进度条控件与之前的圆形百分比控件大同小异,这次涉及到了渐变渲染以及画布旋转等知识点,效果如下:虽然步骤
- log4j配置失效日志中打印Debug信息最近发布项目的时候发现控制台打印的日志较往常多了很多,仔细一看,debug和info信息也赫然在列
- 引言对于Nacos大家应该都不太陌生,出身阿里名声在外,能做动态服务发现、配置管理,非常好用的一个工具。然而这样的技术用的人越多面试被问的概
- 本文实例为大家分享了Unity实现物体左右移动效果的具体代码,供大家参考,具体内容如下效果如下代码:using UnityEngine;us
- 目录一、自定义认证逻辑二、自定义过滤器总结一、自定义认证逻辑生成验证码工具<dependency> &
- maven打包时候修改包名称带上git版本号和打包时间使用 maven 插件 git-commit-id-plugin 可以获取项目的git
- 1、两个相关概念:Git和githubGit是一个开源的分布式 版本控制 系统,用以有效、高速的处理从很小到非常大的项目版本管理。 Git
- 1.背景选择器(位于res/drawable/,使用方法:android:background=”@drawable/XXX”) <?
- 序言for循环语句是java循环语句中最常用的循环语句,一般用在循环次数已知的情况下使用。for循环语句的语法格式如下:java语言 for
- 前置工作:项目配置升到对应的29版本compileSdkVersion: 29,buildToolsVersion: ‘29.0.0'
- 小米系统自带的长截屏应该很多人都用过,效果不错。当长截屏时listview就会自动滚动,当按下停止截屏时,就会得到一张完整的截屏。该篇就介绍
- 1、JObject:基本的json对象/// <summary> /// Gets the j obj
- Android多点触控涉及到的知识点1、ScaleGestureDetector 2、OnScaleGestureListener 3、Ma
- 一、前言做新应用就是这样,会遇到各种问题,昨天刚解决了加载某一个类时候抛出了 class is not visible from class
- 1. 实验目的: 使用线程池的时候,有时候需要考虑服务器的最大线程数目和程序最快
- 本文实例为大家分享了Android Studio实现简单计算器功能的具体代码,供大家参考,具体内容如下程序步骤:(1)在布局文件定义一些计算
- String Command = @"python test.py";String Output = Execute.r
- 1.1 JDK 14详细概述JDK 8 已经在 2014年 3月 18日正式可用,JDK 8作为长期支持(Long-Term-Support