溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Android怎么實(shí)現(xiàn)啟動(dòng)引導(dǎo)圖

發(fā)布時(shí)間:2022-06-22 09:22:42 來源:億速云 閱讀:157 作者:iii 欄目:開發(fā)技術(shù)

這篇“Android怎么實(shí)現(xiàn)啟動(dòng)引導(dǎo)圖”文章的知識(shí)點(diǎn)大部分人都不太理解,所以小編給大家總結(jié)了以下內(nèi)容,內(nèi)容詳細(xì),步驟清晰,具有一定的借鑒價(jià)值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“Android怎么實(shí)現(xiàn)啟動(dòng)引導(dǎo)圖”文章吧。

1.布局文件:activity_guide.xml

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent">
 
    <android.support.v4.view.ViewPager
        android:id="@+id/guide_vp"
        android:layout_width="match_parent"
        android:layout_height="match_parent" />
 
    <LinearLayout
        android:id="@+id/ll_guide_point"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_alignParentBottom="true"
        android:layout_marginBottom="40dp"
        android:gravity="center_horizontal"
        android:orientation="horizontal" />
 
    <ImageButton
        android:id="@+id/guide_ib_start"
        android:layout_width="wrap_content"
        android:layout_height="60dp"
        android:layout_alignParentBottom="true"
        android:layout_centerHorizontal="true"
        android:layout_gravity="center_vertical"
        android:layout_marginBottom="120dp"
        android:src="@mipmap/img_guide_start"
        android:visibility="gone" />
</RelativeLayout>

2.關(guān)于的ViewPager的適配器GuidePageAdapter.java

/**
 * Created by gdk on 2019/7/22 14:55
 * Describe:安裝apk第一次啟動(dòng)的引導(dǎo)頁
 *
 * @author gdk
 */
public class GuidePageAdapter extends PagerAdapter {
    //存放圖片的集合
    private List<View> viewList;
 
    public GuidePageAdapter(List<View> viewList) {
        this.viewList = viewList;
    }
 
    /**
     * @return 返回頁面的個(gè)數(shù)
     */
    @Override
    public int getCount() {
        if (viewList != null) {
            return viewList.size();
        }
        return 0;
    }
 
    /**
     * 判斷對象是否生成界面
     *
     * @param view
     * @param object
     * @return
     */
    @Override
    public boolean isViewFromObject(View view, Object object) {
        return view == object;
    }
 
    /**
     * 初始化position位置的界面
     *
     * @param container
     * @param position
     * @return
     */
    @Override
    public Object instantiateItem(ViewGroup container, int position) {
        container.addView(viewList.get(position));
        return viewList.get(position);
    }
 
 
    @Override
    public void destroyItem(ViewGroup container, int position, Object object) {
        container.removeView(viewList.get(position));
    }
}

3.引導(dǎo)頁的Activity,GuideActivity.java

/**
 * 第一次安裝的引導(dǎo)頁
 * Created by gdk on 2019-07-22
 *
 * @author gdk
 */
 
public class GuideActivity extends BaseActivity<LoginContract.Presenter> implements LoginContract.View, ViewPager.OnPageChangeListener {
 
    @BindView(R.id.guide_ib_start)
    ImageButton guideIbStart;
    @BindView(R.id.guide_vp)
    ViewPager guideVp;
    @BindView(R.id.ll_guide_point)
    LinearLayout llGuidePoint;
    private int[] imagePositionArray;//圖片資源的數(shù)組
    private List<View> viewList;//圖片資源的集合
 
    //實(shí)例化原點(diǎn)View
    private ImageView iv_point;
    private ImageView[] ivPointArray;
 
    @Override
    public int getLayoutId() {
        return R.layout.activity_guide;
    }
 
    @Override
    public LoginContract.Presenter initPresenter() {
        return new LoginPresenter(this);
    }
 
    @Override
    public void initView() {
        //加載滑動(dòng)的ViewPager
        initViewPager();
        //加載底部圓點(diǎn)
        initPoint();
    }
 
    @OnClick({R.id.ll_guide_point, R.id.guide_ib_start})
    public void onViewClicked(View view) {
        switch (view.getId()) {
            case R.id.guide_ib_start:
                //從啟動(dòng)頁跳轉(zhuǎn)到引導(dǎo)頁,修改保存的值,再次進(jìn)入時(shí)跳過此頁面。
                SpUitlsInfo.putString(GuideActivity.this, "VERSION", "1");
                startActivity(new Intent(GuideActivity.this, MainActivity.class));
                break;
            default:
                break;
        }
    }
 
    /**
     * 加載底部圓點(diǎn)
     */
    private void initPoint() {
        //這里實(shí)例化LinearLayout
        llGuidePoint = findViewById(R.id.ll_guide_point);
        //根據(jù)ViewPager的item數(shù)量實(shí)例化數(shù)組
        ivPointArray = new ImageView[viewList.size()];
        //循環(huán)新建底部圓點(diǎn)ImageView,將生成的ImageView保存到數(shù)組中
        int size = viewList.size();
        for (int i = 0; i < size; i++) {
            iv_point = new ImageView(this);
            LinearLayout.LayoutParams lp = new LinearLayout.LayoutParams(LinearLayout.LayoutParams.WRAP_CONTENT,
                    LinearLayout.LayoutParams.WRAP_CONTENT);
            //設(shè)置小圓點(diǎn)的間距
            lp.setMargins(20, 0, 20, 0);
            iv_point.setLayoutParams(lp);
            ivPointArray[i] = iv_point;
            //第一個(gè)頁面需要設(shè)置為選中狀態(tài),這里采用兩張不同的圖片
            if (i == 0) {
                iv_point.setBackgroundResource(R.drawable.guide_dot_select);
            } else {
                iv_point.setBackgroundResource(R.drawable.guide_dot_unselect);
            }
            //將數(shù)組中的ImageView加入到ViewGroup
            llGuidePoint.addView(ivPointArray[i]);
        }
    }
 
    /**
     * 加載圖片ViewPager
     */
    private void initViewPager() {
        //實(shí)例化圖片資源
        imagePositionArray = new int[]{R.mipmap.img_guide_one, R.mipmap.img_guide_two, R.mipmap.img_guide_three,
                R.mipmap.img_guide_four};
        viewList = new ArrayList<>();
        //獲取一個(gè)Layout參數(shù),設(shè)置為全屏
        LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(
                LinearLayout.LayoutParams.MATCH_PARENT, LinearLayout.LayoutParams.MATCH_PARENT);
        //循環(huán)創(chuàng)建View并加入到集合中
        int len = imagePositionArray.length;
        for (int i = 0; i < len; i++) {
            //new ImageView并設(shè)置全屏和圖片資源
            ImageView imageView = new ImageView(this);
            imageView.setLayoutParams(params);
            imageView.setBackgroundResource(imagePositionArray[i]);
            //將ImageView加入到集合中
            viewList.add(imageView);
        }
 
        //View集合初始化好后,設(shè)置Adapter
        guideVp.setAdapter(new GuidePageAdapter(viewList));
        //設(shè)置滑動(dòng)監(jiān)聽
        guideVp.setOnPageChangeListener(this);
    }
 
    @Override
    public void onResult(Object result, String message) {
 
    }
 
    @Override
    public void onError(Throwable throwable, String message) {
 
    }
 
    @Override
    public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {
 
    }
 
    /**
     * 滑動(dòng)后的監(jiān)聽
     *
     * @param position
     */
    @Override
    public void onPageSelected(int position) {
        //循環(huán)設(shè)置當(dāng)前頁的標(biāo)記圖
        int length = imagePositionArray.length;
        for (int i = 0; i < length; i++) {
            ivPointArray[position].setBackgroundResource(R.drawable.guide_dot_select);
            if (position != i) {
                ivPointArray[i].setBackgroundResource(R.drawable.guide_dot_unselect);
            }
        }
        //判斷是否是最后一頁,若是則顯示按鈕
        if (position == imagePositionArray.length - 1) {
            guideIbStart.setVisibility(View.VISIBLE);
        } else {
            guideIbStart.setVisibility(View.GONE);
        }
    }
 
    @Override
    public void onPageScrollStateChanged(int state) {
 
    }
 
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        ButterKnife.bind(this);
    }
 
}

涉及到兩個(gè)布局文件

guide_dot_select.xml

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="oval">
 
    <solid android:color="@color/white"></solid>
    <corners android:radius="3dp" />
    <size
        android:width="8dp"
        android:height="8dp" />
</shape>

guide_dot_unselect.xml

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="oval">
    <solid android:color="@color/colorPrimaryDark"></solid>
    <corners android:radius="3dp" />
    <size
        android:width="8dp"
        android:height="8dp" />
</shape>

以上就是關(guān)于“Android怎么實(shí)現(xiàn)啟動(dòng)引導(dǎo)圖”這篇文章的內(nèi)容,相信大家都有了一定的了解,希望小編分享的內(nèi)容對大家有幫助,若想了解更多相關(guān)的知識(shí)內(nèi)容,請關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI