热门标签 | HotTags
当前位置:  开发笔记 > Android > 正文

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

这篇文章主要为大家详细介绍了AndroidUI设计与开发之实现应用程序只启动一次引导界面,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

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

其实要想实现这样的效果,只要使用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 //shared_prefs/setting.xml

二、实现的效果图

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

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

第一次启动时的效果图

欢迎界面:

 

引导界面效果图1:

引导界面效果图2:

进入主页面:

以后启动程序的效果图

欢迎界面:

 

程序主页面:

三、程序的目录结构

四、具体的实现编码

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

 
 
  
 

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

<&#63;xml version="1.0" encoding="UTF-8"&#63;> 
 
 

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

<&#63;xml version="1.0" encoding="utf-8"&#63;> 
 
 

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

 
 
  
 

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

<&#63;xml version="1.0" encoding="utf-8"&#63;> 
 
       
   
 

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 views; 
  
 public ViewPagerAdapter (ArrayList 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 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(); 
 
  // 实例化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设计为专题进行详细的实战讲解,希望大家能继续关注该系列文章。

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


推荐阅读
  • 深入理解SAP Fiori及其核心概念
    本文详细介绍了SAP Fiori的基本概念、发展历程、核心特性、应用类型、运行环境以及开发工具等,旨在帮助读者全面了解SAP Fiori的技术框架和应用场景。 ... [详细]
  • Sass 是一种 CSS 的预处理器,通过使用变量、嵌套、继承等高级功能,使得 CSS 的编写更加灵活和高效。本文将介绍 Sass 的基本语法及其安装使用方法。 ... [详细]
  • 本文总结了几个常用的Android开发技巧,包括检测设备上是否安装特定应用、获取应用的版本名称、设置状态栏透明以及如何从一个应用跳转至另一个应用的方法。 ... [详细]
  • 这个报错出现在userDao里面,sessionfactory没有注入。解决办法:spring整合Hibernate使用test测试时要把spring.xml和spring-hib ... [详细]
  • Android开发经验分享:优化用户体验的关键因素
    随着Android市场的不断扩展,用户对于移动应用的期望也在不断提高。本文探讨了在Android开发中如何优化用户体验,以及为何用户体验的重要性超过了技术本身。 ... [详细]
  • 解析 HTTP 头 'Vary: Accept-Encoding' 的作用与重要性
    本文详细探讨了 'Vary: Accept-Encoding' HTTP 头的作用,即指导缓存系统(如代理服务器和 CDN)根据不同的编码需求存储和提供适当的资源版本,确保不同类型的客户端能够接收到适合自己的内容。 ... [详细]
  • 拖拉切割直线 ... [详细]
  • 本文介绍了在Android Studio中通过代码和配置文件两种方法来移除Activity的标题栏,并讨论了当Activity继承自AppCompatActivity时的特殊处理方法。 ... [详细]
  • Activity跳转动画 无缝衔接
    Activity跳转动画 无缝衔接 ... [详细]
  • 深入解析Android Activity生命周期
    本文详细探讨了Android中Activity的生命周期,通过实例代码和详细的步骤说明,帮助开发者更好地理解和掌握Activity各个阶段的行为。 ... [详细]
  • 本文介绍了多种Eclipse插件,包括XML Schema Infoset Model (XSD)、Graphical Editing Framework (GEF)、Eclipse Modeling Framework (EMF)等,涵盖了从Web开发到图形界面编辑的多个方面。 ... [详细]
  • BeautifulSoup4 是一个功能强大的HTML和XML解析库,它能够帮助开发者轻松地从网页中提取信息。本文将介绍BeautifulSoup4的基本功能、安装方法、与其他解析工具的对比以及简单的使用示例。 ... [详细]
  • 本教程旨在指导开发者如何在Android应用中通过ViewPager组件实现图片轮播功能,适用于初学者和有一定经验的开发者,帮助提升应用的视觉吸引力。 ... [详细]
  • 本文介绍了基于Java的在线办公工作流系统的毕业设计方案,涵盖了MyBatis框架的应用、源代码分析、调试与部署流程、数据库设计以及相关论文撰写指导。 ... [详细]
  • [附源码]计算机毕业设计JAVAjsp医药管理信息系统
    [附源码]计算机毕业设计JAVAjsp医药管理信息系统项目运行环境配置:Jdk1.8Tomcat7.0MysqlHBuilderX(Webstor ... [详细]
author-avatar
橘子火4
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有