谈谈那些精简版的 Android 应用

谈谈那些精简版的 Android 应用,第1张

上个月(7/25),Facebook 宣布其社交平台取得新的里程碑成就:月活跃用户数量达到 20 亿,从 10 亿到 20 亿,仅过去了 5 年的时间。

(我们应该也是这 20 亿人中的一份子)

业界科技媒体给出了这样的评论,解释平台用户数量快速增长的原因:近几年,Facebook 针对低带宽或者网络环境并不理想的地区,专门开发了精简版的应用,已经从亚洲和其他地区收获了 7.46 亿的新用户数量。在这新增长的 10 亿用户中,印度是 Facebook 增长最快的市场,用户已经达到了 1.84 亿,而美国、加拿大只增加了 4100 万。

除了 Facebook 这样的大平台外,我们还看到了不少软件开发商跟进了这一用户市场,推出了很多相当简练、实用的精简版 Android 应用。所以,这是撰写分享文的初衷: 谈谈那些精简版的 Android 应用 ,究竟这些挂着 Lite 标志的应用,有何魅力可以助推大公司在亚洲和其他地区收获如此惊人的用户数量,是否存在功能阉割难用的尴尬问题。

精简版 Apps 的出现解决了哪些需求?正如各大厂商推出这样的应用时,所倡导的:

所以,我们可以通过各大软件开发商所宣传的初衷,总结出两点推出精简版应用的原因:

下面我们挑选了 10 款 Apps 作为代表,大家可以重点留意 Apps 安装包大小和主要功能模块部分的说明。

从我们梳理出来的信息和安装体验来看,可以总结出这样的信息:

从上面表格中,我们选取了两款应用作为这次体验对比的参赛选手,不是要比胜负,只为了让大家更加直观知晓精简版和常规版本应用之间的区别所在。

首先登场的是最年轻的选手 Linkedin Lite,第一次登上世界级赛场的时间是 2017 年 7 月,相信大家对这名选手的情况并不是很了解。随后我们看到了 LL(Linkedin Lite 啥时候改名字了) 的同门大师兄 Linkedin,早些年曾在职场江湖多年,2016 年被一名叫做微软的大师傅所收归门下。

Linkedin 作为职场社交应用,整个应用界面的设计以蓝白色为主,给我第一感觉就是稳重商务。Linkedin 顶栏提供了搜索、个人资料入口和领英 APP 推广入口;顶栏往下是其主要的功能模块,以标签页的形式呈现出来,分别主页关注动态、人脉、消息、通知、收藏和申请职位;主界面右下角以悬浮响应按钮的方式提供了撰写个人动态的入口。

Linkedin Lite 主界面顶栏提供了搜索、消息、通知的入口,主要功能模块移至底部,分别有主页关注动态、工作、朋友通讯录、个人资料,可能是由于 Lite 版是面向非中文的用户,整个应用仅提供了英文界面。相比常规版本,Lite 版以惊人的 652KB 安装包大小实现了完整的职业社交应用功能。

接着登场的是一对神秘的弟兄,他们的外号是 Facebook 和 Facebook Lite,由于来自神秘的番外海域,我等中原人士对其知之甚少,仅有部分人士通过民间口传方式才能获知一二。

Facebook 的安装包达到了 71.42MB,属于这次统计的体积最大的应用,与精简版相比,增加了秘密传收件箱、Instagram 和 Message 推广入口,设定标签页中,提供了相当丰富的功能模块,粗略计算会有超过 40 个小功能。Lite 版本则克制许多,提供了个人动态、邀请、消息、通知、搜寻,以设定选项中 8 个小功能模块。值得一提的是,Facebook Lite 配备了名为 数据使用 的统计功能,用户可以方便看到应用在今天、过去 7 天或者自定义时间段内使用的数据流量情况,还推荐了一款 Onavo Protect 节省流量的 App。

上面介绍的精简版应用,都有共同特点:在官方版本的基础上,针对不同的实际市场情况所推出的简化版本,可能删减不必要的功能模块,并且着重在网络优化方面下功夫,压缩图片显示、选择视频播放素质、应用安装包缩减。

但我们还看到了精简版 Apps 的另一种形态,比如早几年兴起的轻应用,围绕云端化概念,依靠云端部署,不再要求本地化安装,而是通过更加轻便的使用环境去实现原本常规版 Apps 的全部功能。

下面是我们观察到精简版应用新的形态。

第一、小程序。2016 年 9 月开始了微信小程序内测,今年 1 月小程序正式上线,标志着小程序正式和公众见面,还吸引不少人对 小程序能够替代 APP 的讨论。我们姑且不去争辩小程序和原生 Apps 之间是否具体相互替代性,而是放回讨论它们在定位和功能性的差别。

小程序可以视为另一种变形的精简版 Apps,官方定义是:

目前,受到先天性的因素,小程序并不能完全调度手机硬件资源,所以会比较克制地实现更多轻量化、简便化的功能,比如资讯浏览、工具查询。

由于小程序是基于微信这个大平台做的程序开发,流量分发管控都会受到微信方面的影响,所以小程序能否在全球其他地区流行,往往取决于微信在当地的知名度。

第二、国内版和国际版。这一点也算是国内特色,我 π 的选题箱中早早躺着这样的选题:「国际版本和国内版本 App的区别与优劣」,国内应用开发厂商的出海策略,往往是带来某某国际版,用以区分在国内发布的软件版本。国内外有所区别的 Apps 同样可视为另一种精简版形式。为什么这么所,我们对比一下微博应用国内外版本的 App 界面:

从界面上,我们已经很容易看到区别所在,在体验一番之后,感受更加深刻,国际版本明显就是更加精简、更加简化,也更加实用,而国内版则显得「老态龙钟」——安装包巨大、广告和消息推送干扰,无疑对用户体验带来极其不好的影响。

精简版应用在国内并不算流行,它们要解决的痛点,比如 Apps 使用需要照顾到网路基础环境差的实际情况,简单基础的功能恰好能够满足当地市场需求,而这些情况或许在国内并不存在。反而,国内厂商针对本土市场推出的 Apps 出于盈利?出于提供「大而全」功能的考虑?都喜欢出品一些极其臃肿的应用,这反而极大影响了用户使用体验。所以,这篇分享文的目的在于:给大家推荐一些功能体验上相当基础实用的精简版 Apps,偏爱简单实用或者手机硬件性能并不算出色的玩家可以参考文中提到的 Apps Lite。

环境搭建就不讲了,直接说开发。

闹钟程序开发中的要点就是:

1、时间选择对话框(TimePicker)

2、获取闹钟管理器并对其进行设置

3、注册广播接收器

掌握了这两点,写程序就很简单了。

1、新建android项目:Alarm,sdk版本选择2.2,Package name:com.lql.activity,Main Activity:Alarm

2、编写界面:直接修改layout中的main.xml文件,代码如下:

Xml代码

<?xml version="1.0" encoding="utf-8"?>

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"

android:orientation="vertical"

android:layout_width="fill_parent"

android:layout_height="fill_parent"

android:gravity="center_vertical"

>

<Button

android:id="@+id/timeBtn"

android:layout_width="fill_parent"

android:layout_height="wrap_content"

android:text="@string/time"

android:textSize="20sp"

/>

<Button

android:id="@+id/cancelAlarmBtn"

android:layout_width="fill_parent"

android:layout_height="wrap_content"

android:text="@string/cancelAlarm"

/>

</LinearLayout>

界面的效果如下:

3、修改Alarm.java这个activity,在该Activity中需要做这样几件事:

获取界面上的两个按钮组件,并给其绑定事件监听器

第一个时间按钮,点击后,显示时间选择对话框(TimePicker),供选择小时和分钟,并设置闹钟

第二个按钮,点击之后需要当前设定的闹钟

比较难写的代码就是闹钟设置:

//设置时间

Java代码  

timeBtn.setOnClickListener(new Button.OnClickListener(){

@Override

public void onClick(View arg0) {

Log.d(TAG, "click the time button to set time")

calendar.setTimeInMillis(System.currentTimeMillis())

new TimePickerDialog(Alarm.this,new TimePickerDialog.OnTimeSetListener() {

@Override

public void onTimeSet(TimePicker arg0, int h, int m) {

//更新按钮上的时间

timeBtn.setText(formatTime(h,m))

//设置日历的时间,主要是让日历的年月日和当前同步

calendar.setTimeInMillis(System.currentTimeMillis())

//设置日历的小时和分钟

calendar.set(Calendar.HOUR_OF_DAY, h)

calendar.set(Calendar.MINUTE, m)

//将秒和毫秒设置为0

calendar.set(Calendar.SECOND, 0)

calendar.set(Calendar.MILLISECOND, 0)

//建立Intent和PendingIntent来调用闹钟管理器

Intent intent = new Intent(Alarm.this,AlarmReceiver.class)

PendingIntent pendingIntent = PendingIntent.getBroadcast(Alarm.this, 0, intent, 0)

//获取闹钟管理器

AlarmManager alarmManager = (AlarmManager)getSystemService(ALARM_SERVICE)

//设置闹钟

alarmManager.set(AlarmManager.RTC_WAKEUP, calendar.getTimeInMillis(), pendingIntent)

alarmManager.setRepeating(AlarmManager.RTC_WAKEUP, calendar.getTimeInMillis(), 10*1000, pendingIntent)

Toast.makeText(Alarm.this, "设置闹钟的时间为:"+String.valueOf(h)+":"+String.valueOf(m), Toast.LENGTH_SHORT).show()

Log.d(TAG, "set the time to "+formatTime(h,m))

}

},calendar.get(Calendar.HOUR_OF_DAY),calendar.get(Calendar.MINUTE),true).show()

}

})

代码里面有注释,这里就不多解释了,其中new TimePickerDialog为创建时间选择对话框。为了能够看到效果,我给闹钟添加了重复提醒:alarmManager.setRepeating(AlarmManager.RTC_WAKEUP, calendar.getTimeInMillis(), 10*1000, pendingIntent)。

还要为取消闹钟按钮添加事件监听器:

Java代码  

//取消闹钟按钮事件监听

final Button cancelAlarmBtn = (Button)findViewById(R.id.cancelAlarmBtn)

cancelAlarmBtn.setOnClickListener(new Button.OnClickListener(){

@Override

public void onClick(View arg0) {

Intent intent = new Intent(Alarm.this,AlarmReceiver.class)

PendingIntent pendingIntent = PendingIntent.getBroadcast(Alarm.this, 0, intent, 0)

//获取闹钟管理器

AlarmManager alarmManager = (AlarmManager)getSystemService(ALARM_SERVICE)

alarmManager.cancel(pendingIntent)

Toast.makeText(Alarm.this, "闹钟已经取消!", Toast.LENGTH_SHORT).show()

}

})

在点击取消闹钟按钮时,取消之前设置的闹钟,核心代码就4行。

4、编写广播接收器,用来接收闹钟的广播事件,然后进行相关处理,

Java代码  

public class AlarmReceiver extends BroadcastReceiver {

/* (non-Javadoc)

* @see android.content.BroadcastReceiver#onReceive(android.content.Context, android.content.Intent)

*/

@Override

public void onReceive(Context arg0, Intent data) {

Log.d(Alarm.TAG, "the time is up,start the alarm...")

Toast.makeText(arg0, "闹钟时间到了!", Toast.LENGTH_SHORT).show()

}

}

这个代码就很简单了,主要是要继 承 BroadcastReceiver 这个类,然后重写onRecive方法。onRecive方法在闹钟的时间达到之后会执行,在这里我们可以做自己的事情,比如启动某个程序,或者播放铃声,我这里就是简单的提示一下,使用的是Toast。

5、在android的AndroidManifest.xml文件中注册广播接收器:

<manifest xmlns:android="http://schemas.android.com/apk/res/android"

Xml代码

package="com.ql.activity"

android:versionCode="1"

android:versionName="1.0">

<application android:icon="@drawable/icon" android:label="@string/app_name">

<receiver android:name=".AlarmReceiver" android:process=":remote" />

<activity android:name=".Alarm"

android:label="@string/app_name">

<intent-filter>

<action android:name="android.intent.action.MAIN" />

<category android:name="android.intent.category.LAUNCHER" />

</intent-filter>

</activity>

</application>

<uses-sdk android:minSdkVersion="8" />

</manifest>

核心的配置为<receiver android:name=".AlarmReceiver" android:process=":remote" />,这也是闹钟程序的关键,如果不做这个配置,那么时间到了之后,闹钟将不会提示。

接下来就是到模拟器上测试,运行截图如上图。程序源代码见附件。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/11293457.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-15
下一篇 2023-05-15

发表评论

登录后才能评论

评论列表(0条)

保存