17.Android项目引导页

前沿

学习笔记,便于后续查看。

摘抄自这位大神:http://blog.csdn.net/cjm2484836553/article/details/53292150

效果图

hehe.gif

撸代码

  • GuideActivity.xml
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="com.example.meterdesginproject.GuideActivity">

    <android.support.v4.view.ViewPager
        android:id="@+id/viewpager"
        android:layout_width="match_parent"
        android:layout_height="match_parent" />
    <Button
        android:id="@+id/button_skip"
        android:layout_alignParentRight="true"
        android:layout_marginTop="20dp"
        android:layout_marginRight="20dp"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" 
        android:text="跳过"/>
    <RelativeLayout
        android:layout_alignParentBottom="true"
        android:layout_centerHorizontal="true"
        android:layout_marginBottom="40dp"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content">
        <LinearLayout
            android:id="@+id/ll_dot_group"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:orientation="horizontal"/>
        <ImageView
            android:id="@+id/iv_white_dot"
            android:layout_width="10dp"
            android:layout_height="10dp"
            android:background="@drawable/white_dot_shape"/>
    </RelativeLayout>
</RelativeLayout>
  • 第五张图片的View
<?xml version="1.0" encoding="utf-8"?>
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical">

    <ImageView
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:background="@drawable/splash_5" />

    <Button
        android:id="@+id/button_join"
        android:layout_marginBottom="80dp"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="bottom|center_horizontal"
        android:text="立即体验" />
</FrameLayout>
  • 白点和圆圈的shape
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="oval" >
    <solid android:color="#fff"/>
    <corners android:radius="5dp"/>
</shape>
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="oval">
    <size
        android:width="10dp"
        android:height="10dp"/>
    <stroke
        android:width="1dp"
        android:color="@android:color/white"/>
    <solid android:color="@android:color/transparent"/>
</shape>
  • GuideActivity
public class GuideActivity extends AppCompatActivity implements View.OnClickListener{

    private View lastSplash;
    private ArrayList<ImageView> imageViews;
    private LinearLayout dotGroup;
    private ViewPager viewPager;
    private ImageView whiteDot;
    private int dotDistance;
    private Button mSkip;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        //初始化视图
        initView();
        //初始化数据
        initData();
        //初始化监听
        initListener();
    }

    private void initView() {
        setContentView(R.layout.activity_guide);
        dotGroup = (LinearLayout)findViewById(R.id.ll_dot_group);
        viewPager = (ViewPager)findViewById(R.id.viewpager);
        whiteDot = (ImageView)findViewById(R.id.iv_white_dot);
        mSkip = (Button)findViewById(R.id.button_skip);
        mSkip.setOnClickListener(this);

        //最后一张
        lastSplash = View.inflate(this,R.layout.last_guide_view,null);
    }

    private void initData() {
        imageViews = new ArrayList<>();
        int dotWidth = DensityUtil.dip2px(this,10);
        int[] imagesId = {
                R.drawable.splash_1,
                R.drawable.splash_2,
                R.drawable.splash_3,
                R.drawable.splash_4,
        };
        for (int i = 0; i < imagesId.length+1; i++) {  //这里需要加1
            //创建小圆点
            ImageView dot = new ImageView(this);
            dot.setBackgroundResource(R.drawable.dot_normal_shape);
            LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(dotWidth,dotWidth);
            if (i!=0){
                params.leftMargin =dotWidth;
            }
            dot.setLayoutParams(params);
            //添加小圆点
            dotGroup.addView(dot);

            if(i!=imagesId.length){
                ImageView imageView = new ImageView(this);
                imageView.setBackgroundResource(imagesId[i]);
                imageViews.add(imageView);
            }

            //ViewPager设置适配器
            viewPager.setAdapter(new ViewpagersAdapter());
        }

    }

    public class ViewpagersAdapter extends PagerAdapter{

        @Override
        public int getCount() {
            return imageViews.size()+1;
        }

        @Override
        public boolean isViewFromObject(View view, Object object) {
            return view==object;
        }

        @Override
        public Object instantiateItem(ViewGroup container, int position) {
            View view = null;
            if (position<imageViews.size()){
                view = imageViews.get(position);
            }else {
                view = lastSplash;
            }
            container.addView(view);
            return view;
        }

        @Override
        public void destroyItem(ViewGroup container, int position, Object object) {
            container.removeView((View) object);
        }
    }

    private void initListener(){
        whiteDot.getViewTreeObserver().addOnGlobalLayoutListener(new MyOnGlobalLayoutListener());
        viewPager.addOnPageChangeListener(new MyOnPageChangeListener());
        lastSplash.findViewById(R.id.button_join).setOnClickListener(this);
    }

    private class MyOnGlobalLayoutListener implements ViewTreeObserver.OnGlobalLayoutListener{

        @Override
        public void onGlobalLayout() {
            //默认会调用两次,只需要一次,第一次进入就移除
            whiteDot.getViewTreeObserver().removeOnGlobalLayoutListener(MyOnGlobalLayoutListener.this);
            // 两点间距= 第1个dot距左边的距离 - 第0个dot距左边的距离
            dotDistance = dotGroup.getChildAt(1).getLeft()-dotGroup.getChildAt(0).getLeft();
        }
    }

    private class  MyOnPageChangeListener implements ViewPager.OnPageChangeListener {

        @Override
        public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {
            //红点移动的距离 = ViewPager页面的百分比* 间距
            //坐标 = 起始位置 + 红点移动的距离;
            int leftmagin = (int) (position * dotDistance + (positionOffset * dotDistance));
            RelativeLayout.LayoutParams params = (RelativeLayout.LayoutParams) whiteDot.getLayoutParams();
            params.leftMargin = leftmagin;
            whiteDot.setLayoutParams(params);
        }

        @Override
        public void onPageSelected(int position) {

        }

        @Override
        public void onPageScrollStateChanged(int state) {

        }
    }

    @Override
    public void onClick(View view) {
        switch (view.getId()){
            case R.id.button_skip:
                startActivity(new Intent(GuideActivity.this,MainActivity.class));
                break;
            case R.id.button_join:
                startActivity(new Intent(GuideActivity.this,MainActivity.class));
                break;
        }
    }
}
  • 用到的一个工具类
public class DensityUtil {
    /**
     * 根据手机的分辨率从 dip 的单位 转成为 px(像素)
     */
    public static int dip2px(Context context, float dpValue) {
        final float scale = context.getResources().getDisplayMetrics().density;
        return (int) (dpValue * scale + 0.5f);
    }

    /**
     * 根据手机的分辨率从 px(像素) 的单位 转成为 dp
     */
    public static int px2dip(Context context, float pxValue) {
        final float scale = context.getResources().getDisplayMetrics().density;
        return (int) (pxValue / scale + 0.5f);
    }
}

结束……

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

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 172,018评论 25 707
  • 本人初学Android,最近做了一个实现安卓简单音乐播放功能的播放器,收获不少,于是便记录下来自己的思路与知识总结...
    落日柳风阅读 19,123评论 2 41
  • 前言 目前市场上的APP中,轮播图可以说是很常见的。一个好的轮播图,基本上适用于所有的APP。是时候打造一个自己的...
    带心情去旅行阅读 17,292评论 15 93
  • 为陈医生默哀,并由此有感,本人文笔不好逻辑混乱请见谅。 今天看到了这个新闻,内心觉得很难过又很无奈,只能...
    mango爱吃胡萝卜阅读 866评论 0 4
  • 高效能人第二个习惯。 在处理事情时,应该明白什么是目标,原则,计划。 心中一定要有那个“终”,才会有“始”。其实也...
    迷轩佳阅读 247评论 0 0