资讯专栏INFORMATION COLUMN

adnroid——ViewPager制作APP第一次使用时出现的导航介绍

MRZYD / 761人阅读

摘要:今天自己写了一次。这里我用了布局。目的是为了使这几个导航点叠加在页面图片的上面。到了最后一个,按一按。官方的是继续向右滑动就进入到主界面。求大牛指点华丽的分割线到此结束。其中这里用到的个人还不是很能理解。

这个已经不是什么新技术了。今天自己写了一次。做个简单的笔记吧。

上代码。

package com.example.viewpargertest;

import java.util.ArrayList;
import java.util.List;

import android.app.Activity;
import android.content.Intent;
import android.graphics.Color;
import android.os.Bundle;
import android.os.Parcelable;
import android.support.v4.view.PagerAdapter;
import android.support.v4.view.ViewPager;
import android.support.v4.view.ViewPager.OnPageChangeListener;
import android.view.LayoutInflater;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.Window;
import android.widget.Button;
import android.widget.TextView;

public class MainActivity extends Activity {

    private ViewPager myViewPager; //页卡内容

    private List list; // 存放页卡

    private TextView dot1,dot2,dot3;    //这些点都是文字

    private Button startButton;                 //按钮,“开始体验”



    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        requestWindowFeature(Window.FEATURE_NO_TITLE);
        setContentView(R.layout.activity_main);
        initDot();
        initViewPager();
    }

    private void initDot(){
        dot1=(TextView) this.findViewById(R.id.textView1);      //这些点都是文字
        dot2=(TextView) this.findViewById(R.id.textView2);
        dot3=(TextView) this.findViewById(R.id.textView3);
    }

    private void initViewPager(){
        myViewPager=(ViewPager) this.findViewById(R.id.viewPager);
        list=new ArrayList();

        LayoutInflater inflater=getLayoutInflater();

        View view =inflater.inflate(R.layout.lay3, null);       //只是为了等下findviewbuid而独立拿出来赋给view

        list.add(inflater.inflate(R.layout.lay1, null));
        list.add(inflater.inflate(R.layout.lay2, null));
        list.add(view);

        myViewPager.setAdapter(new MyPagerAdapter(list));

        myViewPager.setOnPageChangeListener(new MyPagerChangeListener());

        startButton=(Button) view.findViewById(R.id.start);                  //与上面对应,获取这个按钮

        startButton.setOnClickListener(new OnClickListener() {

            @Override
            public void onClick(View v) {
                Intent intent=new Intent(MainActivity.this,Main.class);

                startActivity(intent);

            }
        });


    }

    class MyPagerAdapter extends PagerAdapter {
        public List mListViews;

        public MyPagerAdapter(List mListViews) {
            this.mListViews = mListViews;
        }

        @Override
        public void destroyItem(View arg0, int arg1, Object arg2) {
            ((ViewPager) arg0).removeView(mListViews.get(arg1));
        }

        @Override
        public void finishUpdate(View arg0) {
        }

        @Override
        public int getCount() {
            return mListViews.size();
        }

        @Override
        public Object instantiateItem(View arg0, int arg1) {
            ((ViewPager) arg0).addView(mListViews.get(arg1), 0);
            return mListViews.get(arg1);
        }

        @Override
        public boolean isViewFromObject(View arg0, Object arg1) {
            return arg0 == (arg1);
        }

        @Override
        public void restoreState(Parcelable arg0, ClassLoader arg1) {
        }

        @Override
        public Parcelable saveState() {
            return null;
        }

        @Override
        public void startUpdate(View arg0) {
        }
    }

    class MyPagerChangeListener implements OnPageChangeListener{


        @Override
        public void onPageSelected(int arg0) {
            // TODO Auto-generated method stub
            switch (arg0) {                           //设置点的颜色
            case 0:
                dot1.setTextColor(Color.WHITE);
                dot2.setTextColor(Color.BLACK);
                dot3.setTextColor(Color.BLACK);
                break;

            case 1:
                dot1.setTextColor(Color.BLACK);
                dot2.setTextColor(Color.WHITE);
                dot3.setTextColor(Color.BLACK);
                break;

            case 2:
                dot1.setTextColor(Color.BLACK);
                dot2.setTextColor(Color.BLACK);
                dot3.setTextColor(Color.WHITE);
                break;

            }
        }

        @Override
        public void onPageScrollStateChanged(int arg0) {
            // TODO Auto-generated method stub

        }

        @Override
        public void onPageScrolled(int arg0, float arg1, int arg2) {
            // TODO Auto-generated method stub

        }



    }
}


每个页面都是一张图片,在xml定义好几个file,再把它们都实例化inflater为view,加入到list中。再把list加到适配器PagerAdapter 中。myViewPager绑定适配器。OK。已经完成了。运行可以手动滑动转页了。

再下来就是那几个导航的点。

上XML。


这里我用了RelativeLayout 布局。目的是为了使这几个导航点叠加在页面图片的上面。

可以看到,其实这几个点都是TextView。

myViewPager设置监听OnPageChangeListener,在页面变化的时候这几个TextView变一下颜色就可以了。在最后一个页面卡添加多一个按钮 ”开始体验“。到了最后一个,按一按。就可以开始我的QQ空间生活咯。完工。

上图。

这里用到的图都是QQ空间客户端截取下来的。有点就是。官方那几个导航点竟然是图片来的。不是动态的。~呀~~~~~

最后那张图那个按钮是我自己加上去的。官方的是继续向右滑动就进入到主界面。额~这个不知道怎么实现。求大牛指点

———————————————华丽的分割线——————————————

到此结束。欢迎吐槽。其中这里用到的PagerAdapter个人还不是很能理解。继续大牛指点指点吗。~~~~先继续研究官方API去咯。

———————————————华丽的分割线——————————————

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/12019.html

相关文章

  • Fragment中ViewPager嵌套Fragment,共享元素错位解决方案

    摘要:中嵌套,共享元素错位解决方案前言前事告一段落,在新的项目中,觉得采用的方案作为主界面,创建的过程很快,也没有遇到什么问题。 Fragment中ViewPager嵌套Fragment,共享元素错位解决方案 前言 前事告一段落,在新的项目中,觉得采用ViewPager+Fragment的方案作为主界面,创建的过程很快,也没有遇到什么问题。但在实现界面跳转的时候,才发现单Activity多F...

    XBaron 评论0 收藏0
  • Android仿饿了么首页导航栏(ViewPager

    摘要:需求分析在饿了么首页中我们能看到这样的布局如下图。导航点是使用文件画的,灰色为未选中,绿色为选中。因为默认显示的是第一页,所以我们默认第一个的导航点是选中的。 1、需求分析 在饿了么首页中我们能看到这样的布局(如下图)。红框内是一个可以左右滑动的页面,每一个页面类似于九宫格,都有可供点击图标。对于这样的布局,我在网上找了很久都没有找到相关的名称,所以我这里暂时叫它导航页吧。showIm...

    lufficc 评论0 收藏0
  • Android仿饿了么首页导航栏(ViewPager

    摘要:需求分析在饿了么首页中我们能看到这样的布局如下图。导航点是使用文件画的,灰色为未选中,绿色为选中。因为默认显示的是第一页,所以我们默认第一个的导航点是选中的。 1、需求分析 在饿了么首页中我们能看到这样的布局(如下图)。红框内是一个可以左右滑动的页面,每一个页面类似于九宫格,都有可供点击图标。对于这样的布局,我在网上找了很久都没有找到相关的名称,所以我这里暂时叫它导航页吧。showIm...

    iflove 评论0 收藏0
  • 关于android - 收藏集 - 掘金

    摘要:主要解决多类型问题,的掘金一背景随着的碎片化越来越严重,适配成为一个开发中一个痛点。价值虽然说瘦身对于对应用可分配内存的限制影响不大,但是还是有一数据存储方案掘金文件存储类中提供了一个方法,可以用于将数据存储到指定文件中。 LSettingView--- 让你更加快速的实现设置界面 - Android - 掘金设置界面条目封装,同时包含: 设置左侧图标 设置左侧文字 ... ProGu...

    he_xd 评论0 收藏0
  • Android 导航介绍)页面ViewPager内存溢出解决方法

    摘要:现在基本每个都会标配一个启动介绍的页面,或做产品介绍,或做功能展示,既然起导航界面,基本思路就是用实现。重新编写之后测试发现还是占用内存,当时我就傻了。。。终于惊喜的发现内存占用降到之间了。。。 现在基本每个Android App都会标配一个启动介绍的页面,或做产品介绍,或做app功能展示,既然起导航界面,基本思路就是用ViewPager实现。(图片引自UI中国一设计师的设计图片) s...

    jasperyang 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<