ViewPager详解(三)引导页

效果图

  • 部分素材来自互联网,侵权什么的请及时告知,谢谢。
引导页效果图

一、引导页简介

  • 引导页一般是在用户第一次进入app时给用户的友好提示,包括介绍app的基本功能,最近更新的功能等等。

  • 目前市场上的app的引导页大部分都是采用ViewPager滑动的方式实现,每一个页面采用图片或者素材加图片的方式填充。

一、Splash界面的实现

  • Splash界面通常在app启动时弹出的界面,一般在这时做一些数据的初始化操作。
  • 这里进入Splash时,获取用户是否第一次进入,是则进入引导页,不是则进入主页。
1.1 Splash界面逻辑分析图
Splash界面逻辑分析图
1.2 代码实现
  • 先读取出用户是否是第一次进入app的状态,根据状态做不同的处理
    • true:延迟3秒进入引导页

    • false:延迟3秒进入主页

        mSp = getSharedPreferences("config", MODE_PRIVATE);
      
        // 默认进入主页
        boolean firstEnter = mSp.getBoolean("guide", false);
        if (firstEnter) {
            // 进入引导页
            mHandler.postDelayed(new Runnable() {
                @Override
                public void run() {
                    startActivity(new Intent(SplashActivity.this, GuideActivity.class));
                    finish();
                }
            }, 3000);
        } else {
            // 进入主页
            mHandler.postDelayed(new Runnable() {
                @Override
                public void run() {
                    startActivity(new Intent(SplashActivity.this, MainActivity.class));
                    finish();
                }
            }, 3000);
      
        }
      

二、引导页的实现

需求分析:这里的引导页是使用四张图片来进行填充,并且在底部添加了一个小的操作平台,包括了页面指示器,跳过按钮,下一页按钮,滑动时指示器能动态指示当前的页面,点击跳过按钮进入主页,点击下一页进行翻页,最后一页有进入主页的按钮。

实现原理:做一个ViewPager容器填充图片,底部做一个RelativeLayout容器存放按钮和指示器。其中不同按钮的显示是根据当前的页面位置,做隐藏和显示处理。按钮的点击是通过监听做不同的操作,指示器是根据当前页面的偏移来计算白点距离左边的位置,达到实时更新位置的效果。

2.1 ViewPager的编写
  • 布局中申明

      <android.support.v4.view.ViewPager
          android:id="@+id/viewpager"
          android:layout_width="match_parent"
          android:layout_height="match_parent">
      </android.support.v4.view.ViewPager>
    
  • 代码中使用,获取对象,设置适配器,显示图片,这些基本的操作前面都已经介绍过了,这里就不累述了,不知道的请上传送门。
    ViewPager详解(一)简单介绍和使用
    ViewPager详解(二)广告轮播图

2.2 底部圆点的指示器的实现

逻辑分析:看效果图可以知道,白点是浮动在上面的,也就是说,底下灰点是背景,上面白点随着页面的偏移而偏移。那就可以这样设计,灰点用LinearLayout包裹 ,白点用ImageView或View包裹并且浮在LinearLayout上面,在填充图片的时候初始化这两种类型的点,然后监听ViewPager页面的滑动,动态的设置白点的位置。

白点的位置分析:监听ViewPager的滑动,我们会得到一个页面的偏移百分比,有了百分比,我们还差一个白点之间的距离,他俩相乘后累加就会得到白点随着页面滑动的移动轨迹,那我们现在还缺白点之间的距离。白点之间的距离可以在布局完成之后用第二个点的左边距减去第一个点的左边距得到,所以需要的数据就基本分析出来了。

  • 初始化两种类型的圆点

      for (int i = 0; i < mIcons.length; i++) {
          // 设置底部小圆点
          ImageView point = new ImageView(this);
          point.setImageResource(R.drawable.shape_point_normal);
    
          // 设置白点的布局参数
          int pointSize = getResources().getDimensionPixelSize(R.dimen.point_size);
          RelativeLayout.LayoutParams params1 = new RelativeLayout.LayoutParams(pointSize, pointSize);
          
          mWhitePoint.setLayoutParams(params1);
    
          // 设置灰色点的布局参数
          LinearLayout.LayoutParams params2 = new LinearLayout.LayoutParams(pointSize, pointSize);
          if (i > 0) {
              params2.leftMargin = getResources().getDimensionPixelSize(R.dimen.point_margin);
          }
    
          point.setLayoutParams(params2);
    
          // 灰点添加到容器
          mPointGroup.addView(point);
      }
    
  • 获取白点之间的距离,因为要测量边距,所以要保证布局已经完成,这里使用视图树对象来添加一个全局的布局监听。

      // 获取视图树对象,通过监听白点布局的显示,然后获取两个圆点之间的距离
      mWhitePoint.getViewTreeObserver().addOnGlobalLayoutListener(new ViewTreeObserver.OnGlobalLayoutListener() {
          @Override
          public void onGlobalLayout() {
              // 此时layout布局已经显示出来了,可以获取小圆点之间的距离了
              mPointMargin = mPointGroup.getChildAt(1).getLeft() - mPointGroup.getChildAt(0).getLeft();
    
              // 将自己移除掉
              mWhitePoint.getViewTreeObserver().removeOnGlobalLayoutListener(this);
          }
      });
    
  • 监听ViewPager的滑动,在onPageScrolled方法中动态修改白点的左边距,这样白点就会随着页面的滑动而移动。

      @Override
      public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {
          // 页面滑动的时候,动态的获取小圆点的左边距
          int leftMargin = (int) (mPointMargin * (position + positionOffset));
          // Log.d("GuideActivity", "leftMargin:" + leftMargin);
    
          // 获取布局参数,然后设置布局参数
          RelativeLayout.LayoutParams params = (RelativeLayout.LayoutParams) mWhitePoint.getLayoutParams();
          // 修改参数
          params.leftMargin = leftMargin;
          // 重新设置布局参数
          mWhitePoint.setLayoutParams(params);
      }
    

2.2 底部按钮的显示隐藏和点击事件

  • 监听ViewPager的滑动,在onPageSelected方法中判断position的位置来显示隐藏控件。

      @Override
      public void onPageSelected(int position) {
    
          // 最后一页
          if (position == mIcons.length - 1) {
              mBtnSkip.setVisibility(View.GONE);
              mIbNext.setVisibility(View.GONE);
              mBtnDown.setVisibility(View.VISIBLE);
    
          } else {
              // 不是最后一页
              mBtnDown.setVisibility(View.GONE);
              mBtnSkip.setVisibility(View.VISIBLE);
              mIbNext.setVisibility(View.VISIBLE);
          }
      }
    
  • 实现按钮的点击事件,进入主页需要保存进入app的状态。

      // SKIP跳过按钮的点击事件
      mBtnSkip.setOnClickListener(new View.OnClickListener() {
          @Override
          public void onClick(View v) {
              enterMain();
          }
      });
    
      // 下一页点击按钮的点击事件
      mIbNext.setOnClickListener(new View.OnClickListener() {
          @Override
          public void onClick(View v) {
              // 下一页
              mViewPager.setCurrentItem(mViewPager.getCurrentItem() + 1);
          }
      });
    
      // 完成引导按钮的点击事件
      mBtnDown.setOnClickListener(new View.OnClickListener() {
          @Override
          public void onClick(View v) {
              enterMain();
          }
      });
    
经过以上的分析和编码之后,引导页这一块大家自己做出来应该基本没什么问题了,市面上还有一些引导页是动画的效果,包括ViewPager滑动的动画,获取页面上的素材随ViewPager移动的动画等等,这些其实都没什么难的,仔细分析一下就知道怎么做的了。

个人主页
Demo下载地址

Banner相关请查看最新开源项目BannerView

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,732评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,496评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,264评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,807评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,806评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,675评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,029评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,683评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,704评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,666评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,773评论 1 332
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,413评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,016评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,978评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,204评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,083评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,503评论 2 343

推荐阅读更多精彩内容