Android寒假实训云笔记总结——欢迎页

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Android寒假实训云笔记总结——欢迎页相关的知识,希望对你有一定的参考价值。

欢迎页使用的是viewpager,需要适配器。

注意点:

1、判断是否是第一次进入这个app。

2、欢迎页小圆点的逻辑。

实现原理:

首先在activity_welcome放入viewpager和固定四个小圆点的图片在下方。

viewpager用于存放多张欢迎页的图。

welcome_selectoer用于当在哪一页对应的小圆点为灰色状态。即设置成不可点时状态为灰色。

viewpager的内容为静态加载进去。

如图:

技术分享

直接贴代码,代码都有注释:

 WelcomeActivity.java

package com.app.note.activity;
import android.app.Activity;
import android.content.Context;
import android.content.Intent;
import android.content.SharedPreferences;
import android.os.Bundle;
import android.support.v4.view.ViewPager;
import android.util.Log;
import android.view.Display;
import android.view.View;
import com.app.note.R;
import com.app.note.adapter.WelcomeAdapter;
import android.support.v4.view.ViewPager.OnPageChangeListener;
import android.view.Window;
import android.view.WindowManager;
import android.view.animation.Animation;
import android.view.animation.ScaleAnimation;
import android.widget.Button;
import android.widget.ImageView;
import android.widget.LinearLayout;
import java.util.ArrayList;
import java.util.List;
import java.util.logging.Handler;

public class WelcomeActivity extends Activity implements OnPageChangeListener,View.OnClickListener {
    private ViewPager viewPager;
    private List<View> viewList;
    private View view1, view2, view3, view4;
    private ImageView points[];//存放小圆圈数组
    private int currentIndex=0;//当前页面,默认首页
    private Button startButton;
    private Boolean isFirstIn = false;
    private SharedPreferences pref;
    private ImageView doge;


    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        //将图片设置为全屏
        getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN, WindowManager.LayoutParams.FLAG_FULLSCREEN);
        //隐藏标题栏
        this.requestWindowFeature(Window.FEATURE_NO_TITLE);
        //判断是否第一次使用app
        //第一个参数是文件名,第二参数是操作模式
       /* Context.MODE_PRIVATE:为默认操作模式,代表该文件是私有数据,只能被应用本身访问,在该模式下,写入的内容会覆盖原文件的内容,如果想把新写入的内容追加到原文件中。可以使用Context.MODE_APPEND
        Context.MODE_APPEND:模式会检查文件是否存在,存在就往文件追加内容,否则就创建新文件。
        Context.MODE_WORLD_READABLE和Context.MODE_WORLD_WRITEABLE用来控制其他应用是否有权限读写该文件。
        MODE_WORLD_READABLE:表示当前文件可以被其他应用读取;
        MODE_WORLD_WRITEABLE:表示当前文件可以被其他应用写入。*/
        pref = getApplicationContext().getSharedPreferences("FirstOrNo", 0 );
        isFirstIn = pref.getBoolean("isFirstIn",true);
        if(isFirstIn)
        {
            setContentView(R.layout.activity_welcome);
            initViewPager();//初始化ViewPager对象
            initPoint();//初始化导航小圆点
            changefirst();
        }else {

                    Intent intent = new Intent(WelcomeActivity.this, LoginActivity.class);
                    startActivity(intent);
                    finish();    }}

    private void changefirst(){
        pref = getApplicationContext().getSharedPreferences("FirstOrNo",0);
        SharedPreferences.Editor editor = pref.edit();
        editor.putBoolean("isFirstIn", false);
        editor.commit();
    }

    private void initPoint() {
        LinearLayout  linearLayout=(LinearLayout) findViewById(R.id.ll);
        points=new ImageView[4];
        for(int i=0;i<points.length;i++){
            points[i]=(ImageView) linearLayout.getChildAt(i);//遍历LinearLayout下的所有ImageView子节点
            points[i].setEnabled(true);//设置当前状态为允许(可点,灰色)
            //设置点击监听
            points[i].setOnClickListener(this);

            //额外设置一个标识符,以便点击小圆点时跳转对应页面
            points[i].setTag(i);//标识符与圆点顺序一致
        }

        currentIndex=0;
        points[currentIndex].setEnabled(false);//设置首页为当前页(小点着色,蓝色)
        startButton.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                Intent intent = new Intent(WelcomeActivity.this,LoginActivity.class);
                startActivity(intent);
                finish();

            }
        });



    }


    private void initViewPager() {
        viewPager=(ViewPager) findViewById(R.id.viewpager);//取得ViewPager实例
        viewList=new ArrayList<View>();//实例化list集合
        startButton=(Button)findViewById(R.id.startbutton);
        //用xml静态添加view
        view1=View.inflate(WelcomeActivity.this, R.layout.view1, null);
        view2=View.inflate(WelcomeActivity.this, R.layout.view2, null);
        view3=View.inflate(WelcomeActivity.this, R.layout.view3, null);
        view4=View.inflate(WelcomeActivity.this, R.layout.view4, null);

        viewList.add(view1);
        viewList.add(view2);
        viewList.add(view3);
        viewList.add(view4);



        //设置适配器
        WelcomeAdapter adapter=new WelcomeAdapter(viewList);

        //绑定适配器
        viewPager.setAdapter(adapter);

        //设置页卡切换监听
        viewPager.setOnPageChangeListener(this);

    }

    @Override
    public void onPageScrollStateChanged(int arg0) {

    }

    @Override
    public void onPageScrolled(int arg0, float arg1, int arg2) {

    }

    @Override
    public void onPageSelected(int position ) {//当前页卡被选择时,position为当前页数
        //当滑动到最后一页时隐藏点
        if(position==3){
            for (int i=0;i<=position;i++)
            {
                points[i].setVisibility(View.GONE);
            }
            startButton.setEnabled(true);
            startButton.setVisibility(View.VISIBLE);
        }
        //当从最后一页往回滑的时候把点显示出来
        if(currentIndex==3){
            for (int i=0;i<=currentIndex;i++)
            {
                points[i].setVisibility(View.VISIBLE);
            }
            startButton.setEnabled(false);
            startButton.setVisibility(View.GONE);
        }
        points[position].setEnabled(false);//不可点
        points[currentIndex].setEnabled(true);//恢复之前页面状态
        currentIndex=position;

    }

    @Override
    public void onClick(View v) {
        viewPager.setCurrentItem((int) v.getTag());
    }

}

 

适配器WelcomeAdapter.java

package com.app.note.adapter;

import android.support.v4.view.PagerAdapter;
import android.view.View;
import android.view.ViewGroup;

import java.util.List;

/**
 * Created by hxdn on 2015/12/29.
 */
public class WelcomeAdapter extends PagerAdapter {
    private List<View> list;

    public WelcomeAdapter(List<View> list) {// 利用构造器接收list集合参数
        this.list = list;
    }

    @Override
    public int getCount() {// 返回页卡数量
        if (list.size() != 0) {
            return list.size();
        }
        return 0;
    }

    @Override
    public boolean isViewFromObject(View arg0, Object arg1) {//判断是否为view对象
        return arg0==arg1;//官方demo给出的建议写法
    }

    @Override
    public Object instantiateItem(ViewGroup container, int position) {//实例化一个页卡,view对象存放在ViewGroup里
        container.addView(list.get(position));
        return list.get(position);
    }

    @Override
    public void destroyItem(ViewGroup container, int position, Object object) {//销毁一个页卡
        container.removeView(list.get(position));
    }

}

  布局代码:activity_welcome.xml

 <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.app.note.activity.WelcomeActivity">

    <android.support.v4.view.ViewPager
        android:id="@+id/viewpager"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent" />

    <LinearLayout
        android:id="@+id/ll"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentBottom="true"
        android:layout_centerHorizontal="true"
        android:layout_marginBottom="20dp"
        android:orientation="horizontal" >

        <ImageView
            android:id="@+id/iv1"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_gravity="center_vertical"
            android:clickable="true"
            android:padding="25dp"
            android:src="@drawable/welcome_selector" />

        <ImageView
            android:id="@+id/iv2"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_gravity="center_vertical"
            android:clickable="true"
            android:padding="25dp"
            android:src="@drawable/welcome_selector" />

        <ImageView
            android:id="@+id/iv3"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_gravity="center_vertical"
            android:clickable="true"
            android:padding="25dp"
            android:src="@drawable/welcome_selector" />

        <ImageView
            android:id="@+id/iv4"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_gravity="center_vertical"
            android:clickable="true"
            android:padding="25dp"
            android:src="@drawable/welcome_selector" />
    </LinearLayout>
    <Button
        android:id="@+id/startbutton"
        android:layout_width="160dp"
        android:layout_height="50dp"
        android:text="点击进入"
        android:textSize="20dp"
        android:textColor="@drawable/button_text"
        style="@style/btn_login"
        android:background="@drawable/bg_login_btn_qq"
        android:visibility="gone"
        android:clickable="false"
        android:layout_above="@+id/ll"
        android:layout_centerHorizontal="true" />

</RelativeLayout>

  四个页面由于都差不多只贴其中一份xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent" android:layout_height="match_parent">
    <ImageView
        android:id="@+id/iv1"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:layout_gravity="center_vertical"
        android:clickable="true"
        android:src="@drawable/welcome1"
        android:scaleType="fitXY"/>
</LinearLayout>

  最重要的选择器的xml:

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item
        android:state_enabled="true" android:drawable="@drawable/v_point_pre"
        ></item>

    <item
        android:state_enabled="false" android:drawable="@drawable/v_point_gray"
        ></item>

</selector>

 

以上是关于Android寒假实训云笔记总结——欢迎页的主要内容,如果未能解决你的问题,请参考以下文章

企业内训一体化解决方案,布道师教学实训云平台开源版上线

寒假实训笔记day01——认识M4单片机之STM32F405RGT6

VSCode插件开发全攻略代码片段设置自定义欢迎页

寒假的Java学习笔记总结2

Android 实现欢迎界面

Android 实现欢迎界面