热门标签 | HotTags
当前位置:  开发笔记 > Android > 正文

Android引导页面的简单实现

这篇文章主要为大家详细介绍了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 items = new ArrayList();
 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 data;
 private ImageCycleViewListener mImageCycleViewListener;
 private Context context;

 public HomeAdapter(Context context, List data, ImageCycleViewListener mImageCycleViewListener) {
  this.cOntext= context;
  this.mImageCycleViewListener = mImageCycleViewListener;
  this.data = new ArrayList();
  if (data != null) {
   this.data.addAll(data);
  }
 }

 public void notifyData(List data) {
  if (data != null) {
   this.data.clear();
   this.data.addAll(data);
  }
  notifyDataSetChanged();
 }

 // 当天viewpager有多少个条目
 LinkedList imageList = new LinkedList();

 @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() {
//
//    @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 data = new ArrayList();
 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);

 }
}

以上为效果实现的主要代码,效果运行如下:

上面的效果图还有一小部分效果未展示出来,其实上面的圆是循环轮播的,同时也是可以滑动的;

源码:Androidpager

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


推荐阅读
  • Android 九宫格布局详解及实现:人人网应用示例
    本文深入探讨了人人网Android应用中独特的九宫格布局设计,解析其背后的GridView实现原理,并提供详细的代码示例。这种布局方式不仅美观大方,而且在现代Android应用中较为少见,值得开发者借鉴。 ... [详细]
  • 深入解析Android自定义View面试题
    本文探讨了Android Launcher开发中自定义View的重要性,并通过一道经典的面试题,帮助开发者更好地理解自定义View的实现细节。文章不仅涵盖了基础知识,还提供了实际操作建议。 ... [详细]
  • Linux 系统启动故障排除指南:MBR 和 GRUB 问题
    本文详细介绍了 Linux 系统启动过程中常见的 MBR 扇区和 GRUB 引导程序故障及其解决方案,涵盖从备份、模拟故障到恢复的具体步骤。 ... [详细]
  • 本文介绍了如何使用jQuery根据元素的类型(如复选框)和标签名(如段落)来获取DOM对象。这有助于更高效地操作网页中的特定元素。 ... [详细]
  • 本文将详细介绍如何使用剪映应用中的镜像功能,帮助用户轻松实现视频的镜像效果。通过简单的步骤,您可以快速掌握这一实用技巧。 ... [详细]
  • 深入理解Cookie与Session会话管理
    本文详细介绍了如何通过HTTP响应和请求处理浏览器的Cookie信息,以及如何创建、设置和管理Cookie。同时探讨了会话跟踪技术中的Session机制,解释其原理及应用场景。 ... [详细]
  • 本文介绍如何在 Xcode 中使用快捷键和菜单命令对多行代码进行缩进,包括右缩进和左缩进的具体操作方法。 ... [详细]
  • 本文介绍了一款用于自动化部署 Linux 服务的 Bash 脚本。该脚本不仅涵盖了基本的文件复制和目录创建,还处理了系统服务的配置和启动,确保在多种 Linux 发行版上都能顺利运行。 ... [详细]
  • 在Linux系统中配置并启动ActiveMQ
    本文详细介绍了如何在Linux环境中安装和配置ActiveMQ,包括端口开放及防火墙设置。通过本文,您可以掌握完整的ActiveMQ部署流程,确保其在网络环境中正常运行。 ... [详细]
  • Android 渐变圆环加载控件实现
    本文介绍了如何在 Android 中创建一个自定义的渐变圆环加载控件,该控件已在多个知名应用中使用。我们将详细探讨其工作原理和实现方法。 ... [详细]
  • 如何在WPS Office for Mac中调整Word文档的文字排列方向
    本文将详细介绍如何使用最新版WPS Office for Mac调整Word文档中的文字排列方向。通过这些步骤,用户可以轻松更改文本的水平或垂直排列方式,以满足不同的排版需求。 ... [详细]
  • 本文总结了在使用Ionic 5进行Android平台APK打包时遇到的问题,特别是针对QRScanner插件的改造。通过详细分析和提供具体的解决方法,帮助开发者顺利打包并优化应用性能。 ... [详细]
  • 理解存储器的层次结构有助于程序员优化程序性能,通过合理安排数据在不同层级的存储位置,提升CPU的数据访问速度。本文详细探讨了静态随机访问存储器(SRAM)和动态随机访问存储器(DRAM)的工作原理及其应用场景,并介绍了存储器模块中的数据存取过程及局部性原理。 ... [详细]
  • 360SRC安全应急响应:从漏洞提交到修复的全过程
    本文详细介绍了360SRC平台处理一起关键安全事件的过程,涵盖从漏洞提交、验证、排查到最终修复的各个环节。通过这一案例,展示了360在安全应急响应方面的专业能力和严谨态度。 ... [详细]
  • 几何画板展示电场线与等势面的交互关系
    几何画板是一款功能强大的物理教学软件,具备丰富的绘图和度量工具。它不仅能够模拟物理实验过程,还能通过定量分析揭示物理现象背后的规律,尤其适用于难以在实际实验中展示的内容。本文将介绍如何使用几何画板演示电场线与等势面之间的关系。 ... [详细]
author-avatar
阆中猫猫覀_648
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有