广告
返回顶部
首页 > 资讯 > 移动开发 >Android引导页面的简单实现
  • 950
分享到

Android引导页面的简单实现

Android 2022-06-06 04:06:26 950人浏览 泡泡鱼
摘要

第一次进入应用的时候,都会有一个引导页面,引导页面的实现起来也很简单,实现的方式也有很多,下面是自己写的一个引导页面的效果,大致的实现思路为: 最外层是一个Fragment

第一次进入应用的时候,都会有一个引导页面,引导页面的实现起来也很简单,实现的方式也有很多,下面是自己写的一个引导页面的效果,大致的实现思路为:

最外层是一个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());
 }
 
 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) {
  }
 }
 
 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;// 返回的对象
 }
 
 public static interface ImageCycleViewListener {
  
  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);
 }
}

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

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

源码Androidpager

您可能感兴趣的文章:GuideView的封装实现app功能引导页Android客户端首次启动引导界面android使用ViewPager组件实现app引导查看页面Android绘制炫酷的引导界面Android自定义View实现水波纹引导动画android 引导界面的实现方法Android启动引导页使用ViewPager实现Android开发实战之漂亮的ViewPager引导页Android GuideView实现首次登陆引导


--结束END--

本文标题: Android引导页面的简单实现

本文链接: https://www.lsjlt.com/news/22345.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Android引导页面的简单实现
    第一次进入应用的时候,都会有一个引导页面,引导页面的实现起来也很简单,实现的方式也有很多,下面是自己写的一个引导页面的效果,大致的实现思路为: 最外层是一个Fragment...
    99+
    2022-06-06
    Android
  • Android简单实现引导页
    本文实例为大家分享了Android简单实现引导页的具体代码,供大家参考,具体内容如下 一.思路 我们选择ViewPager + View + ImageView 来实现引导页效果,V...
    99+
    2022-11-12
  • Android Studio实现简单的页面跳转(简单教程)
                     项目实现:(实现Android Studio 基本有两种实现方式:一种为.MainActivity跳转;第二种是Relatelayout布局跳转。                   这里着重介绍第一种:(...
    99+
    2023-09-21
    android studio android ide java androidx
  • android studio实现简单的页面跳转
    运用intent组件实现简单的跳转 主页面 Button button1,button2,button3; //xml文件定义的id @Override protected void onCreate(Bundle savedI...
    99+
    2023-10-11
    android studio android java
  • Android实现简单QQ登录页面
    Android开发实现极为简单的QQ登录页面,供大家参考,具体内容如下 设计一个简单QQ登录页面,无任何功能。然后打包安装到手机。 1.首先创建一个空白页面 2.打开样式设计的页...
    99+
    2022-11-13
  • Android如何实现简单QQ登录页面
    本篇内容介绍了“Android如何实现简单QQ登录页面”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!设计一个简单QQ登录页面,无任何功能。然...
    99+
    2023-06-30
  • android实现轮播图引导页
    android轮播图引导页(因为是引导页,所以不具备自动轮播的功能) 示例: 代码后面有数字,3.1开始就是开始做小圆点 //分为三个部分 (1)布局 activity_lun_b...
    99+
    2022-11-13
  • android 引导界面的实现方法
    代码如下:顺序是: OneAcitivity  -->MainActivity -> TwoActivity 然后第2次进去就是:OneActivity...
    99+
    2022-06-06
    界面 方法 Android
  • Android Studio实现简单页面跳转的详细教程
    目录首先设置Activity_main的文件设置:另一个页面布局的设计: 代码设计:然后是第一个JAVA代码的设计:另一个跳转文件所需要的页面JAVA代码:最后一点着重说明...
    99+
    2023-01-11
    android studio页面跳转代码 androidstudio页面跳转不了 androidstudio点击按钮跳转页面
  • Android实现简单的分页效果
    本文实例为大家分享了Android分页效果的具体代码,供大家参考,具体内容如下 1.实现分页最主要的就是封装分页代码,然后在按钮里实现相关的操作 public class ...
    99+
    2022-06-06
    分页 Android
  • android实现简单底部导航栏
    本文实例为大家分享了android实现底部导航栏的具体代码,供大家参考,具体内容如下 常见的底部导航栏 动态效果 实现步骤 1.底部导航栏样式 我们应该在项目的res文件夹下新建...
    99+
    2022-11-13
  • Android实现APP欢迎页面简单制作思路
    现在的APP一般都会在应用启动时有一个欢迎界面,这种欢迎界面一般有两种情况,一种用来在应用启动时在后台检测网络状态,亦或者是加载网络数据等一些耗时操作,比如QQ、微信。还有一种...
    99+
    2022-06-06
    app Android
  • js页面引导页的实现思路总结
    目录实现思路1实现思路2插件实现思路1 采用png格式的方式,然后高亮部分镂空,其它部分采用,如下图所示,简单误差大 其效果如图所示,点击下一步等没法按照图片中的“下一...
    99+
    2023-05-16
    js 引导页 js新手引导
  • SwiftUI 引导页界面实现示例
    目录引言页面分析-元素构成实战编程-创建项目实战编程-引导图片实战编程-引导文字实战编程-引导按钮实战编程-轮博滚动整体效果-预览本章小结引言 当用户首次启用App时,客户端应用常常...
    99+
    2022-11-13
  • JavaFX登录页面简单实现
    一、准备工作 准备好javaFX开发环境,请详见我上篇文章https://www.sdk.cn/details/wAe9P8mXAq5dbqDl4y 二、项目结构 三、启动类创建Stage public class Main extend...
    99+
    2022-10-22
  • Android实现引导页的圆点指示器
    在App引导界面通常有引导界面提示小圆点,我们使用一个集成的类 来整体封装实现: 使用的方法: 首先在 XML布局中引入这个自定义的控件: <FrameLayout xm...
    99+
    2022-11-12
  • 简单实现Android应用的启动页
    前言: 平时打开手机的应用时,会跳出来3秒钟的广告后,再进入应用。今天我们就来简单实现一下引导页的功能。 1、首先,新建一个activity页面,命名:SplashActivity ...
    99+
    2022-11-13
  • Android启动引导页使用ViewPager实现
    我们在安装某个APP的时候,基本都会有一个引导页的提示,他们可以打广告,或者介绍新功能的加入和使用说明等。 一般都支持滑动并且下面有几个点,显示共有多少页和当前图片的位置,在I...
    99+
    2022-06-06
    引导页 viewpager Android
  • Android用MVP实现一个简单的类淘宝订单页面的示例
    MVP(Model-View-Presenter) 是总所周知MVC模式的一个演变,他们的主要目的都是划分模块职责,降低模块耦合,易测试,提高代码复用,网上有很多相关的知识,这里仅是个人看法。1、层级Model:负责数据相关的操作View:...
    99+
    2023-05-30
    android 淘宝 订单
  • HTML+jQuery实现简单的登录页面
    目录简介公共代码(后端接口)示例1:最简(纯HTML)代码测试示例2:HTML+jQuery(form data)代码测试示例3:HTML+jQuery(json)代码测试简介 本文...
    99+
    2022-11-12
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作