Android UI设计与开发之实现应用程序只启动一次引导界面

发布时间 - 2026-01-11 03:02:12    点击率:

这篇文章算是对整个引导界面开发专题的一个终结了吧,个人觉得大部分的引导界面基本上都是千篇一律的,只要熟练掌握了一个,基本上也就没什么好说的了,要是在今后的开发中遇到了更好玩,更有趣的引导界面,博主也会在这里及时的跟大家分享,今天的内容主要是教大家的应用程序只有在第一次启动的时候显示引导界面,以后在启动程序的时候就不再显示了。

其实要想实现这样的效果,只要使用SharedPreferences类,就会让程序变的非常简单,下面来详细介绍一下这个类的使用方法

一、SharedPreferences的详细介绍和用法

SharedPreferences介绍:

做软件开发应该都知道,很多软件会有配置文件,里面存放这程序运行当中的各个属性值,由于其配置信息并不多,如果采用数据库来存放并不划算,因为数据库连接跟操作等耗时大大影响了程序的效率,因此我们使用键值这种一一对应的关系来存放这些配置信息。SharedPreferences正是Android中用于实现这中存储方式的技术。

SharedPreferences的使用非常简单,能够轻松的存放数据和读取数据。SharedPreferences只能保存简单类型的数据,例如,String、int等。一般会将复杂类型的数据转换成Base64编码,然后将转换后的数据以字符串的形式保存在 XML文件中,再用SharedPreferences保存。

SharedPreferences使用方法:

<1> 使用Activity类的getSharedPreferences方法获得SharedPreferences对象,其中存储key-value的文件的名称由getSharedPreferences方法的第一个参数指定;
<2> 使用SharedPreferences接口的edit获得SharedPreferences.Editor对象;
<3> 通过SharedPreferences.Editor接口的putXxx方法保存key-value对。其中Xxx表示不同的数据类型。例如:字符串类型的value需要用putString方法;
<4> 通过SharedPreferences.Editor接口的commit方法保存key-value对。commit方法相当于数据库事务中的提交(commit)操作。

具体代码的书写流程为:

A、存放数据信息

<1> 打开Preferences,名称为setting,如果存在则打开它,否则创建新的Preferences
         SharedPreferences settings = getSharedPreferences(“setting”, 0);
<2> 让setting处于编辑状态
         SharedPreferences.Editor editor = settings.edit();
<3> 存放数据
         editor.putString(“name”,”ATAAW”);
         editor.putString(“URL”,”ATAAW.COM”);
<4> 完成提交
         editor.commit();

B、读取数据信息

<1> 获取Preferences
         SharedPreferences settings = getSharedPreferences(“setting”, 0);
<2> 取出数据
         String name = settings.getString(“name”,”默认值”);
         String url = setting.getString(“URL”,”default”);

       以上就是SharedPreferences的使用方法,其中创建的Preferences文件存放位置可以在Eclipse中查看:
DDMS->File Explorer /<package name>/shared_prefs/setting.xml

二、实现的效果图

第一次启动程序:欢迎界面-->引导界面-->主页面

以后启动程序:启动页-->系统主页

第一次启动时的效果图

欢迎界面:

 

引导界面效果图1:

引导界面效果图2:

进入主页面:

以后启动程序的效果图

欢迎界面:

 

程序主页面:

三、程序的目录结构

四、具体的实现编码

1、  在引导布局界面中加入ViewPager组件,activity_guide.xml:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" 
 xmlns:tools="http://schemas.android.com/tools" 
 android:layout_width="wrap_content" 
 android:layout_height="wrap_content" > 
 
 <android.support.v4.view.ViewPager 
  android:id="@+id/viewpager" 
  android:layout_width="fill_parent" 
  android:layout_height="fill_parent" /> 
</RelativeLayout> 

2、接着在guide_view01.xml等几个布局页面中添加引导界面要显示的图片和控件,因为这几个布局界面都大同小异,所以在这里我就不一一贴出来了吧,有需要的同学可以直接下载源码,guide_view01.xml:

<?xml version="1.0" encoding="UTF-8"?> 
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" 
 android:layout_width="fill_parent" 
 android:layout_height="fill_parent" 
 android:background="@drawable/star_img1" 
 android:orientation="vertical" > 
</RelativeLayout> 

3、然后是欢迎界面的布局界面,activity_welcome:

<?xml version="1.0" encoding="utf-8"?> 
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
 android:layout_width="fill_parent" 
 android:layout_height="fill_parent" 
 android:orientation="vertical" 
 android:background="@drawable/welcome_background"> 
</LinearLayout> 

4、最后是主界面的布局,activity_main:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" 
 xmlns:tools="http://schemas.android.com/tools" 
 android:layout_width="wrap_content" 
 android:layout_height="wrap_content" > 
 
 <TextView 
  android:id="@+id/textView1" 
  android:layout_width="wrap_content" 
  android:layout_height="wrap_content" 
  android:layout_alignParentLeft="true" 
  android:layout_alignParentTop="true" 
  android:text="欢迎来到主页面!" 
  android:textSize="25sp"/> 
</RelativeLayout> 

5、在这里还要创建一个xml文件来实现自定义按钮的效果,关于自定义按钮的效果实现我会在后面的文章中专题详细介绍,这里就不在赘述start_btn.xml:

<?xml version="1.0" encoding="utf-8"?> 
<selector xmlns:android="http://schemas.android.com/apk/res/android"> 
 <item android:state_enabled="true" android:state_pressed="true" 
  android:drawable="@drawable/login_button_select" /> <!--按下时的效果-->     
 <item android:state_enabled="true" android:drawable="@drawable/login_button" /> <!--正常状态的效果--> 
</selector> 

6、布局界面已经讲解完毕,接下来让我们进行详细的代码讲解,ViewPager适配器代码,ViewPagerAdapter.Java:

package com.yangyu.myguideview04; 
 
import java.util.ArrayList; 
 
import android.support.v4.view.PagerAdapter; 
import android.support.v4.view.ViewPager; 
import android.view.View; 
 
/** 
 * @author yangyu 
 * 功能描述:ViewPager适配器,用来绑定数据和view 
 */ 
public class ViewPagerAdapter extends PagerAdapter { 
  
 //界面列表 
 private ArrayList<View> views; 
  
 public ViewPagerAdapter (ArrayList<View> views){ 
  this.views = views; 
 } 
   
 /** 
  * 获得当前界面数 
  */ 
 @Override 
 public int getCount() { 
   if (views != null) { 
    return views.size(); 
   }  
   return 0; 
 } 
 
 /** 
  * 初始化position位置的界面 
  */ 
 @Override 
 public Object instantiateItem(View view, int position) { 
   
  ((ViewPager) view).addView(views.get(position), 0); 
   
  return views.get(position); 
 } 
  
 /** 
  * 判断是否由对象生成界面 
  */ 
 @Override 
 public boolean isViewFromObject(View view, Object arg1) { 
  return (view == arg1); 
 } 
 
 /** 
  * 销毁position位置的界面 
  */ 
 @Override 
 public void destroyItem(View view, int position, Object arg2) { 
  ((ViewPager) view).removeView(views.get(position));   
 } 
} 

7、引导界面Activity,GuideActivity.java:

package com.yangyu.myguideview04; 
 
import java.util.ArrayList; 
 
import android.app.Activity; 
import android.content.Intent; 
import android.os.Bundle; 
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.widget.Button; 
 
/** 
 * @author yangyu 
 * 功能描述:引导界面activity类 
 */ 
public class GuideActivity extends Activity implements OnPageChangeListener{ 
 // 定义ViewPager对象 
 private ViewPager viewPager; 
 
 // 定义ViewPager适配器 
 private ViewPagerAdapter vpAdapter; 
 
 // 定义一个ArrayList来存放View 
 private ArrayList<View> views; 
 
 // 定义各个界面View对象 
 private View view1, view2, view3, view4; 
  
 //定义开始按钮对象 
 private Button startBt; 
   
 @Override 
 protected void onCreate(Bundle savedInstanceState) { 
  super.onCreate(savedInstanceState); 
  setContentView(R.layout.activity_guide); 
   
  initView(); 
   
  initData(); 
 } 
 
 /** 
  * 初始化组件 
  */ 
 private void initView() { 
  //实例化各个界面的布局对象 
  LayoutInflater mLi = LayoutInflater.from(this); 
  view1 = mLi.inflate(R.layout.guide_view01, null); 
  view2 = mLi.inflate(R.layout.guide_view02, null); 
  view3 = mLi.inflate(R.layout.guide_view03, null); 
  view4 = mLi.inflate(R.layout.guide_view04, null); 
  
  // 实例化ViewPager 
  viewPager = (ViewPager) findViewById(R.id.viewpager); 
 
  // 实例化ArrayList对象 
  views = new ArrayList<View>(); 
 
  // 实例化ViewPager适配器 
  vpAdapter = new ViewPagerAdapter(views); 
   
  //实例化开始按钮 
  startBt = (Button) view4.findViewById(R.id.startBtn); 
 } 
 
 /** 
  * 初始化数据 
  */ 
 private void initData() { 
  // 设置监听 
  viewPager.setOnPageChangeListener(this); 
  // 设置适配器数据 
  viewPager.setAdapter(vpAdapter); 
 
  //将要分页显示的View装入数组中  
  views.add(view1); 
  views.add(view2); 
  views.add(view3); 
  views.add(view4);   
         
  // 给开始按钮设置监听 
  startBt.setOnClickListener(new OnClickListener() { 
   @Override 
   public void onClick(View v) { 
     startbutton(); 
   } 
  }); 
 } 
 
 @Override 
 public void onPageScrollStateChanged(int arg0) { 
    
 } 
 
 @Override 
 public void onPageScrolled(int arg0, float arg1, int arg2) { 
   
 } 
 
 @Override 
 public void onPageSelected(int arg0) { 
   
 } 
  
 /** 
  * 相应按钮点击事件 
  */ 
 private void startbutton() { 
  Intent intent = new Intent(); 
  intent.setClass(GuideActivity.this,MainActivity.class); 
  startActivity(intent); 
  this.finish(); 
  } 
} 

8、欢迎界面Activity,Welcome.java:

package com.yangyu.myguideview04; 
 
import android.app.Activity; 
import android.content.Intent; 
import android.content.SharedPreferences; 
import android.content.SharedPreferences.Editor; 
import android.os.Bundle; 
 
/** 
 * @author yangyu 
 * 功能描述:欢迎界面 
 */ 
public class Welcome extends Activity implements Runnable { 
  
 //是否是第一次使用 
 private boolean isFirstUse; 
  
 protected void onCreate(Bundle savedInstanceState) { 
  super.onCreate(savedInstanceState); 
  setContentView(R.layout.activity_welcome); 
  /** 
   * 启动一个延迟线程 
   */ 
  new Thread(this).start(); 
 } 
 
 public void run() { 
  try { 
   /** 
    * 延迟两秒时间 
    */ 
   Thread.sleep(2000); 
    
   //读取SharedPreferences中需要的数据 
   SharedPreferences preferences = getSharedPreferences("isFirstUse",MODE_WORLD_READABLE); 
 
   isFirstUse = preferences.getBoolean("isFirstUse", true); 
 
   /** 
    *如果用户不是第一次使用则直接调转到显示界面,否则调转到引导界面 
    */ 
   if (isFirstUse) { 
    startActivity(new Intent(Welcome.this, GuideActivity.class)); 
   } else { 
    startActivity(new Intent(Welcome.this, MainActivity.class)); 
   } 
   finish(); 
    
   //实例化Editor对象 
   Editor editor = preferences.edit(); 
   //存入数据 
   editor.putBoolean("isFirstUse", false); 
   //提交修改 
   editor.commit(); 
 
 
  } catch (InterruptedException e) { 
 
  } 
 } 
} 

在欢迎界面中使用了SharedPreferences来读取用户的信息,判断是否是第一次使用程序,这里的isFirstUse可以根据读者的需要换成任意类型,只要给它加一个判断就行了

9、主界面Activity,这里就加载了一个简单的布局文件,读者可以根据需要对该类进行扩展,MainActivity.java:

package com.yangyu.myguideview04; 
 
import android.app.Activity; 
import android.os.Bundle; 
 
/** 
 * @author yangyu 
 * 功能描述:主程序入口类页面 
 */ 
public class MainActivity extends Activity { 
 
 @Override 
 protected void onCreate(Bundle savedInstanceState) { 
  super.onCreate(savedInstanceState); 
  setContentView(R.layout.activity_main); 
 } 
  
} 

引导界面的专题就告一段落了,接下来会以主页面的UI设计为专题进行详细的实战讲解,希望大家能继续关注该系列文章。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# Android  # UI只启动一次引导界面  # UI引导界面  # Android启动一次引导界面  # Android使用ViewPager实现启动引导页效果  # Android实现渐变启动页和带有指示器的引导页  # android引导用户开启自启动权限的方法  # Android客户端首次启动引导界面  # Android实现过渡动画、引导页 Android判断是否第一次启动App  # Android使用ViewPager实现启动引导页  # Android实现启动引导图  # 在这里  # 自定义  # 详细介绍  # 可以根据  # 都是  # 判断是否  # 几个  # 我就  # 会有  # 我会  # 也会  # 第一个  # 让我们  # 也就  # 主程序  # 要想  # 会让  # 可以直接  # 分页  # 大同小异 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 简单实现Android验证码  Laravel如何设置自定义的日志文件名_Laravel根据日期或用户ID生成动态日志【技巧】  Laravel如何部署到服务器_线上部署Laravel项目的完整流程与步骤  如何利用DOS批处理实现定时关机操作详解  php中::能调用final静态方法吗_final修饰静态方法调用规则【解答】  香港服务器建站指南:免备案优势与SEO优化技巧全解析  如何快速建站并高效导出源代码?  Win11怎么修改DNS服务器 Win11设置DNS加速网络【指南】  Bootstrap整体框架之CSS12栅格系统  Laravel怎么创建控制器Controller_Laravel路由绑定与控制器逻辑编写【指南】  利用python获取某年中每个月的第一天和最后一天  iOS发送验证码倒计时应用  广州网站制作公司哪家好一点,广州欧莱雅百库网络科技有限公司官网?  Laravel怎么写单元测试_PHPUnit在Laravel项目中的基础测试入门  如何快速搭建安全的FTP站点?  Win11怎样安装网易有道词典_Win11安装词典教程【步骤】  js代码实现下拉菜单【推荐】  详解Android——蓝牙技术 带你实现终端间数据传输  JS碰撞运动实现方法详解  Laravel如何发送系统通知?(Notification渠道示例)  佛山企业网站制作公司有哪些,沟通100网上服务官网?  Laravel用户密码怎么加密_Laravel Hash门面使用教程  Laravel如何使用Service Container和依赖注入?(代码示例)  Laravel怎么返回JSON格式数据_Laravel API资源Response响应格式化【技巧】  如何用搬瓦工VPS快速搭建个人网站?  消息称 OpenAI 正研发的神秘硬件设备或为智能笔,富士康代工  如何在香港免费服务器上快速搭建网站?  东莞市网站制作公司有哪些,东莞找工作用什么网站好?  Laravel怎么使用Blade模板引擎_Laravel模板继承与Component组件复用【手册】  Laravel怎么实现模型属性的自动加密  轻松掌握MySQL函数中的last_insert_id()  米侠浏览器网页图片不显示怎么办 米侠图片加载修复  UC浏览器如何设置启动页 UC浏览器启动页设置方法  javascript中对象的定义、使用以及对象和原型链操作小结  Laravel如何生成URL和重定向?(路由助手函数)  详解ASP.NET 生成二维码实例(采用ThoughtWorks.QRCode和QrCode.Net两种方式)  QQ浏览器网页版登录入口 个人中心在线进入  如何在IIS中配置站点IP、端口及主机头?  如何在香港服务器上快速搭建免备案网站?  猪八戒网站制作视频,开发一个猪八戒网站,大约需要多少?或者自己请程序员,需要什么程序员,多少程序员能完成?  如何在万网开始建站?分步指南解析  Laravel Facade的原理是什么_深入理解Laravel门面及其工作机制  用yum安装MySQLdb模块的步骤方法  google浏览器怎么清理缓存_谷歌浏览器清除缓存加速详细步骤  如何制作公司的网站链接,公司想做一个网站,一般需要花多少钱?  Swift中swift中的switch 语句  Laravel如何配置和使用队列处理异步任务_Laravel队列驱动与任务分发实例  Laravel怎么进行数据库事务处理_Laravel DB Facade事务操作确保数据一致性  nginx修改上传文件大小限制的方法  Laravel PHP版本要求一览_Laravel各版本环境要求对照