当前位置:   article > 正文

Android Studio App开发之实现简单的启动引导页ViewPager(附源码 实现App的欢迎页面)_android studio简单欢迎界面

android studio简单欢迎界面

需要源码或图片集请点赞关注收藏后评论区留言~~~

App引导启动页

翻页视图的应用范围很广,当用户安装一个新应用时,首次启动大多出现欢迎页面,这个引导页面通常要往右翻好几页,才会进入应用主页,这种启动引导页就是通过翻页视图实现的。下面就来动手打造一个属于你的第一个App启动欢迎页把。

它的核心在于页面项的XML布局以及适配器,因此首先要设计页面项的布局,一般来说,引导页由两部分组成,一部分是背景图,一部分是页面下方的一排圆点,其中高亮的圆点表示当前位于第几页。除了背景图与一排圆点之外,最后一页往往有个按钮,它便是应用主页的入口,也是页面项的XML文件至少包含三个控件

1:引导页的背景图

2:底部的一排圆点

3:最后一页的入口按钮

写好了页面项的XML布局,还得编写启动引导页得适配器代码 主要完成三项工作

1:根据页面项得XML文件构造每页的视图

2:让当前页码的圆点高亮显示

3:如果翻到了最后一页,就显示中间的入口按钮 

效果如下

 

 

 

最后 代码如下 

 Java类代码

  1. package com.example.chapter08;
  2. import android.os.Bundle;
  3. import androidx.appcompat.app.AppCompatActivity;
  4. import androidx.viewpager.widget.ViewPager;
  5. import com.example.chapter08.adapter.LaunchSimpleAdapter;
  6. public class LaunchSimpleActivity extends AppCompatActivity {
  7. // 声明引导页面的图片数组
  8. private int[] lanuchImageArray = {R.drawable.guide_bg1,
  9. R.drawable.guide_bg2, R.drawable.guide_bg3, R.drawable.guide_bg4};
  10. @Override
  11. protected void onCreate(Bundle savedInstanceState) {
  12. super.onCreate(savedInstanceState);
  13. setContentView(R.layout.activity_launch_simple);
  14. // 从布局视图中获取名叫vp_launch的翻页视图
  15. ViewPager vp_launch = findViewById(R.id.vp_launch);
  16. // 构建一个引导页面的翻页适配器
  17. LaunchSimpleAdapter adapter = new LaunchSimpleAdapter(this, lanuchImageArray);
  18. vp_launch.setAdapter(adapter); // 设置翻页视图的适配器
  19. vp_launch.setCurrentItem(0); // 设置翻页视图显示第一页
  20. }
  21. }

适配器代码 

  1. package com.example.chapter08.adapter;
  2. import android.content.Context;
  3. import android.view.LayoutInflater;
  4. import android.view.View;
  5. import android.view.View.OnClickListener;
  6. import android.view.ViewGroup;
  7. import android.view.ViewGroup.LayoutParams;
  8. import android.widget.Button;
  9. import android.widget.ImageView;
  10. import android.widget.RadioButton;
  11. import android.widget.RadioGroup;
  12. import android.widget.Toast;
  13. import androidx.viewpager.widget.PagerAdapter;
  14. import com.example.chapter08.R;
  15. import java.util.ArrayList;
  16. import java.util.List;
  17. public class LaunchSimpleAdapter extends PagerAdapter {
  18. private List<View> mViewList = new ArrayList<View>(); // 声明一个引导页的视图列表
  19. // 引导页适配器的构造方法,传入上下文与图片数组
  20. public LaunchSimpleAdapter(final Context context, int[] imageArray) {
  21. for (int i = 0; i < imageArray.length; i++) {
  22. // 根据布局文件item_launch.xml生成视图对象
  23. View view = LayoutInflater.from(context).inflate(R.layout.item_launch, null);
  24. ImageView iv_launch = view.findViewById(R.id.iv_launch);
  25. RadioGroup rg_indicate = view.findViewById(R.id.rg_indicate);
  26. Button btn_start = view.findViewById(R.id.btn_start);
  27. iv_launch.setImageResource(imageArray[i]); // 设置引导页的全屏图片
  28. // 每个页面都分配一个对应的单选按钮
  29. for (int j = 0; j < imageArray.length; j++) {
  30. RadioButton radio = new RadioButton(context); // 创建一个单选按钮
  31. radio.setLayoutParams(new LayoutParams(
  32. LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT));
  33. radio.setButtonDrawable(R.drawable.launch_guide); // 设置单选按钮的图标
  34. radio.setPadding(10, 10, 10, 10); // 设置单选按钮的四周间距
  35. rg_indicate.addView(radio); // 把单选按钮添加到页面底部的单选组
  36. }
  37. // 当前位置的单选按钮要高亮显示,比如第二个引导页就高亮第二个单选按钮
  38. ((RadioButton) rg_indicate.getChildAt(i)).setChecked(true);
  39. // 如果是最后一个引导页,则显示入口按钮,以便用户点击按钮进入主页
  40. if (i == imageArray.length - 1) {
  41. btn_start.setVisibility(View.VISIBLE);
  42. btn_start.setOnClickListener(new OnClickListener() {
  43. @Override
  44. public void onClick(View v) {
  45. // 这里要跳到应用主页
  46. Toast.makeText(context, "欢迎您开启美好生活",
  47. Toast.LENGTH_SHORT).show();
  48. }
  49. });
  50. }
  51. mViewList.add(view); // 把该图片对应的页面添加到引导页的视图列表
  52. }
  53. }
  54. // 获取页面项的个数
  55. public int getCount() {
  56. return mViewList.size();
  57. }
  58. // 判断当前视图是否来自指定对象
  59. public boolean isViewFromObject(View view, Object object) {
  60. return view == object;
  61. }
  62. // 从容器中销毁指定位置的页面
  63. public void destroyItem(ViewGroup container, int position, Object object) {
  64. container.removeView(mViewList.get(position));
  65. }
  66. // 实例化指定位置的页面,并将其添加到容器中
  67. public Object instantiateItem(ViewGroup container, int position) {
  68. container.addView(mViewList.get(position));
  69. return mViewList.get(position);
  70. }
  71. }

 XML文件如下

  1. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  2. android:layout_width="match_parent"
  3. android:layout_height="match_parent"
  4. android:orientation="vertical">
  5. <androidx.viewpager.widget.ViewPager
  6. android:id="@+id/vp_launch"
  7. android:layout_width="match_parent"
  8. android:layout_height="match_parent" />
  9. </LinearLayout>

item_launchXML

  1. <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
  2. android:layout_width="match_parent"
  3. android:layout_height="match_parent">
  4. <!-- 这是引导图片的图像视图 -->
  5. <ImageView
  6. android:id="@+id/iv_launch"
  7. android:layout_width="match_parent"
  8. android:layout_height="match_parent"
  9. android:scaleType="fitXY" />
  10. <!-- 这里容纳引导页底部的一排圆点 -->
  11. <RadioGroup
  12. android:id="@+id/rg_indicate"
  13. android:layout_width="wrap_content"
  14. android:layout_height="wrap_content"
  15. android:layout_alignParentBottom="true"
  16. android:layout_centerHorizontal="true"
  17. android:orientation="horizontal"
  18. android:paddingBottom="20dp" />
  19. <!-- 这是最后一页的入口按钮 -->
  20. <Button
  21. android:id="@+id/btn_start"
  22. android:layout_width="wrap_content"
  23. android:layout_height="wrap_content"
  24. android:layout_centerInParent="true"
  25. android:text="立即开始美好生活"
  26. android:textColor="#ff3300"
  27. android:textSize="22sp"
  28. android:visibility="gone" />"
  29. </RelativeLayout>

创作不易 觉得有帮助请点赞关注收藏~~~

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/2023面试高手/article/detail/144715
推荐阅读