掌上快递之开机启动篇

简介:

启动篇

主要分为开机和功能导航俩部分来总结

先上部分截图图直观感受下



1、开机部分

开机图片比较简单,有个开机图片,图片放在了R.layout.start布局文件中,刚开始老是出现适配问题,后来索性放到LinearLayout的background属性中,然后使用Hnadler创建了一个子线程延时子线程加载后续的跳转Activity(第一次开机跳转功能导航,非第一次跳转主界面)开机的布局文件 R.layout.start(适配比较好)

[html]  view plain  copy
  1. <span style="font-family:Microsoft YaHei;font-size:14px;"><?xml version="1.0" encoding="utf-8"?>  
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  
  3.     xmlns:baiduadsdk="http://schemas.android.com/apk/res/com.weimeijing.feigeshudi"  
  4.     android:layout_width="fill_parent"  
  5.     android:layout_height="fill_parent"  
  6.     android:background="@drawable/startlogo" >  
  7.   
  8. </LinearLayout></span>  


开机的Activity文件StartActivity.Java

其中引导动画逻辑部分,这里采用SharedPreferences方式记录是否第一次启动,来判断是否进入引导画面开机

[java]  view plain  copy
  1. <span style="font-family:Microsoft YaHei;font-size:14px;">package com;  
  2.   
  3. import android.app.Activity;  
  4. import android.content.Intent;  
  5. import android.content.SharedPreferences;  
  6. import android.os.Bundle;  
  7. import android.os.Handler;  
  8.   
  9. import com.kaiji.Viewpage_Activity;  
  10. import com.weimeijing.feigeshudi.R;  
  11.   
  12. public class StartActivity extends Activity {  
  13.     private final int SPLASH_DISPLAY_LENGHT = 2000// 延迟二秒  
  14.   
  15.     @Override  
  16.     public void onCreate(Bundle savedInstanceState) {  
  17.         super.onCreate(savedInstanceState);  
  18.         setContentView(R.layout.start);//在这个显示开机图片  
  19.         // handler线程延时2秒执行run方法,显示开机图片效果  
  20.         new Handler().postDelayed(new Runnable() {  
  21.             @Override  
  22.             public void run() {  
  23.                 // run方法中SharedPreference就是一个xml文件,里面通过键值对来存储相应的用户的设置及其状态。  
  24.                 SharedPreferences setting = getSharedPreferences(  
  25.                         "CitiGame.ini"0);  
  26.                 Boolean user_first = setting.getBoolean("FIRST"true);  
  27.                 if (user_first) {  
  28.                     //第一次加载跳转到功能导航界面  
  29.                     <span style="color:#009900;">setting.edit().putBoolean("FIRST"false).commit()</span>;  
  30.                     Intent intent = new Intent(StartActivity.this,  
  31.                             Viewpage_Activity.class);  
  32.                     StartActivity.this.startActivity(intent);  
  33.                     StartActivity.this.finish();  
  34.                 } else {  
  35.                     //非第一次加载直接跳转主界面  
  36.                     Intent mainIntent = new Intent(StartActivity.this,  
  37.                             MainTabActivity.class);  
  38.                     StartActivity.this.startActivity(mainIntent);  
  39.                     StartActivity.this.finish();  
  40.                 }  
  41.   
  42.             }  
  43.   
  44.         }, SPLASH_DISPLAY_LENGHT);  
  45.     }  
  46. }  
  47. </span>  

1.1、知识点

代码注释的很清楚了,这里主要重点提一下

【1】SharedPreferences,它的本质其实就是xml,但是它可以通过键值对来存储用户相应的设置,算是一个轻量级的存储类,SharedPreferences类似过去Windows系统上的ini配置文件,但是它分为多种权限,可以全局共享访问。

getSharedPreferences(String name, int mode)

name为本组件的配置文件名( 自己定义,也就是一个文件名),当这个文件不存在时,直接创建,如果已经存在,则直接使用,
mode为操作模式,默认的模式为0或MODE_PRIVATE,还可以使用MODE_WORLD_READABLE和MODE_WORLD_WRITEABLE
mode指定为MODE_PRIVATE,则该配置文件只能被自己的应用程序访问。
mode指定为MODE_WORLD_READABLE,则该配置文件除了自己访问外还可以被其它应该程序读取。
mode指定为MODE_WORLD_WRITEABLE,则该配置文件除了自己访问外还可以被其它应该程序读取和写入

【2】SharedPreferences使用

它的本质是基于XML文件存储key-value键值对数据,通常用来存储一些简单的配置信息。 其存储位置在/data/data/<包名>/shared_prefs目录下。
 SharedPreferences对象本身只能获取数据而不支持存储和修改,存储修改是通过Editor对象实现。
 实现SharedPreferences存储的步骤如下:   
    一、根据Context获取SharedPreferences对象   
    二、利用edit()方法获取Editor对象。   
    三、通过Editor对象存储key-value键值对数据。   
    四、通过commit()方法提交数据。

【3】代码分析

在创建的SharedPreferences中第一次运行记录为true从而进入第一个if条件进入功能导航:

Boolean user_first = setting.getBoolean("FIRST", true);

然后进入第一个if判断立马将其修改为false:

setting.edit().putBoolean("FIRST", false).commit();

这样下次启动时就直接进入第二个if中直接跳转到主界面

【4】handler开启子线程的达到延时加载的效果

代码中已经表现的很详细了


2、功能导航部分

主要就是采用ViewPager+LayoutInflater (动态加载页面)来实现

主要分为以下2大部分:

2.1、初始化

主要是通过LayoutInflater动态加载导航页面,为了显示效果这里还加入了一些标记圆点,在上图可以看到,代码注释如下

[java]  view plain  copy
  1. // 用来获取整个View并返回  
  2.         LayoutInflater inflater = getLayoutInflater();  
  3.         pageViews = new ArrayList<View>();  
  4.         pageViews.add(inflater.inflate(R.layout.activity_viewpage1, null));  
  5.         pageViews.add(inflater.inflate(R.layout.activity_viewpage2, null));  
  6.         pageViews.add(inflater.inflate(R.layout.activity_viewpage3, null));  
  7.         pageViews.add(inflater.inflate(R.layout.activity_viewpage4, null));  
  8.         pageViews.add(inflater.inflate(R.layout.activity_viewpage5, null));  
  9.         pageViews.add(inflater.inflate(R.layout.activity_viewpage6, null));  
  10.         // 小圆点数大小是图片的个数  
  11.         imageViews = new ImageView[pageViews.size()];  
  12.         // 从指定xml文件中加载视图  
  13.         viewPictures = (ViewGroup) inflater.inflate(  
  14.                 R.layout.activity_viewpagers, null);  
  15.         viewPager = (ViewPager) viewPictures.findViewById(R.id.guidePagers);  
  16.         viewPoints = (ViewGroup) viewPictures.findViewById(R.id.viewPoints);  
  17.         // 添加小圆点导航图片  
  18.         for (int i = 0; i < pageViews.size(); i++) {  
  19.             imageView = new ImageView(Viewpage_Activity.this);  
  20.             imageView.setLayoutParams(new LayoutParams(2020));  
  21.             imageView.setPadding(5050);  
  22.             // 把小圆点放进数组  
  23.             imageViews[i] = imageView;  
  24.             // 默认选中的是第一张图片,此时第一个小圆点是选中状态,其他不是  
  25.             if (i == 0)  
  26.                 imageViews[i].setImageDrawable(getResources().getDrawable(  
  27.                         R.drawable.page_indicator_focused));  
  28.             else  
  29.                 imageViews[i].setImageDrawable(getResources().getDrawable(  
  30.                         R.drawable.page_indicator_unfocused));  
  31.             // 将imageViews添加到小圆点视图组  
  32.             viewPoints.addView(imageViews[i]);  
  33.         }  


2.2、PageAdapter——PageView的适配器

跟ListView一样这玩意也需要适配器

PageAdapter 必须重写的四个函数:
    * boolean isViewFromObject(View arg0, Object arg1)
    * int getCount() 
    * void destroyItem(ViewGroup Container, int position,Object object)
    * Object instantiateItem(ViewGroup container, int position)
具体作用如下代码注释:

[java]  view plain  copy
  1. // 导航view的适配器  
  2.     class NavigationAdapter extends PagerAdapter {  
  3.         // 获取需要滑动view数目  
  4.         @Override  
  5.         public int getCount() {  
  6.             return pageViews.size();  
  7.         }  
  8.   
  9.         @Override  
  10.         public boolean isViewFromObject(View arg0, Object arg1) {  
  11.             return arg0 == arg1;  
  12.         }  
  13.   
  14.         // 2件事情,第一:将当前视图添加到container中,第二:返回当前View  
  15.         @Override  
  16.         public Object instantiateItem(View container, int position) {  
  17.             ((ViewPager) container).addView(pageViews.get(position));  
  18.             return pageViews.get(position);  
  19.         }  
  20.   
  21.         // 销毁每个Item  
  22.         @Override  
  23.         public void destroyItem(View container, int position, Object object) {  
  24.             ((ViewPager) container).removeView(pageViews.get(position));  
  25.         }  
  26.     }  

2.3、知识点

这个部分需要注意以下知识点

【1】ViewPager

ViewPager类提供了多界面切换的新效果,新效果有如下特征:
<1>当前显示一组界面中的其中一个界面;
<2>当用户通过左右滑动界面时,当前的屏幕显示当前界面和下一个界面的一部分;
<3>滑动结束后,界面自动跳转到当前选择的界面中

【2】LayoutInflater

动态加载页面,注意与findViewById()的区别

LayoutInflater其实是在res/layout/下找到xml布局文件,并且将其实例化,这个和findViewById()有点相似,后者是找xml布局文件下的具体widget控件(如Button、TextView等)
作用:
1、对于一个没有被载入或者想要动态载入的界面,都需要使用LayoutInflater.inflate()来载入;
2、对于一个已经载入的界面,就可以使用Activiyt.findViewById()方法来获得其中的界面元素。


转载:http://blog.csdn.net/xsf50717/article/details/47205259

目录
相关文章
|
4月前
|
安全
银行常用的系统服务
银行常用的系统服务
|
5月前
|
供应链 搜索推荐
零售超市常用软件
零售超市常用软件
|
10月前
|
缓存 算法 数据挖掘
东郊到家系统程序开发预约上门软件功能
目前主流的按摩软件系统会有三个端口:用户端、技师端、商家端,以及管理后台。
|
传感器 监控 数据可视化
拯救快递焦虑,智能快递盒值得拥有
拯救快递焦虑,智能快递盒值得拥有
177 0
拯救快递焦虑,智能快递盒值得拥有
|
机器学习/深度学习 Web App开发 人工智能
解禁在即:美国公司对华为供货两周后重启
据路透社报道:一名美国高级官员称,美国政府即将批准科技公司在两周内重启对华为的销售许可。此举预示着美国政府对华为的解禁即将出现实质性内容。
202 0
解禁在即:美国公司对华为供货两周后重启
|
存储 物联网 网络性能优化
一文教你小区如何自建快递柜
共享快递拟收费事件后,国内小区物业开启一波自建快递柜的浪潮,阿里平台快递柜销量暴涨1400%。那么问题来了,企业如何基于阿里云物联网平台快速构建一套高可用的共享快递柜服务?
381 0
一文教你小区如何自建快递柜
免费快递物流单号查询api接口对接指南(顺丰、中通、圆通、申通、韵达、百世)
• 快递物流查询API接口快递查询接口是指快递查询网对外开放的应用程序接口,开发人员能够通过调用该接口与快递查询网进行交互,并基于该接口开发自己的快递查询应用程序。• 应用场景① 买家物流查询:轨迹跟踪、包裹进度、预计送达时间、派送人联系方式等。
各种物流快递电子面单-Api接口(顺丰、快递鸟、菜鸟)
电子面单是一种通过热敏纸打印输出纸质物流面单的物流服务。通过热感应显示文字,打印速度比传统针式打印速度提升4~6倍。电子面单以接口形式嵌入到自己的系统、网站上,可以在自己的平台操作打印电子面单。电子面单样式: 对接接口各家对比快递电子面单接口:快递公司自己开发的电子面单服务, 商家使用必须快递公司上门做系统对接,使用一家快递则需要对接一次。
|
供应链 API
快递鸟单号查询API接口对接【含顺丰|申通|圆通|中通|百世|韵达|京东|天天|EMS】
快递鸟单号物流轨迹查询API接口,支持418家快递公司接口,高实时、高稳定、高并发,也可以对接单号自动识别快递公司接口,支持申通、韵达、顺丰、圆通、宅急送、韵达、中通、百世、天天、京东、邮政、EMS等国内/国际快递查询。
14301 0
快递鸟电子面单接口对接在线申请账号流程(申通、中通、圆通、韵达、百世)
手写快递单太麻烦了,公司的订单又多,每次都写不过来,还容易出错,直接电子化在打印快递单就快了,不过现在有些人不懂怎么批量对接多个快递的电子面单,这里就给大家讲解讲解,希望对大家有用。 首先需要提前购买电子面单单号才能打印,这里给大家介绍对接电子面单接口对接和在线申请电子面单账号的方法, 一、进入快...

热门文章

最新文章