Android开发之Shortcuts, LiveFolder, Widget
2013-07-05
桌面组件包括:快捷方式(Shortcuts),实时文件夹(Live Folder),桌面插件(Widget)。
快捷方式用于启动应用程序的某个组件,例如Activity, Service等。
在桌面上添加快捷方式:长按桌面(或点击MENU->ADD按键)就可以弹出添加桌面组件的选项对话框。
在代码中将应用程序添加到Shortcuts列表中
在AndroidManifest.xml文件中注册Activity时添加android.intent.action.CREATE_SHORTCUT的IntentFilter,然后在Shortcuts列表中就会出现该应用的图标和名字了。
为快捷方式设置名字,图标,事件等
在Activity的onCreate方法中
public void onCreate(Bundle savedInstanceState) {
// 判断该Activity是否要允许添加快捷方式
if(getIntent().getAction().equals(Intent.ACTION_CREATE_SHORTCUT)) {
Intent it = new Intent();
// 设置名字
it.putExtra(Intent.EXTRA_SHORTCUT_NAME, “发生邮件”);
// 设置图标,使用系统的图标
Parcelable icon = Intent.ShortcutIconResource.fromContext(this, R.drawable.mail_edit);
it.putExtra(Intent.EXTRA_SHORTCUT_ICON_RESOURCE, icon);
// 设置事件
Intent mailIt = new Intent(Intent.ACTION_SENDTO, Uri.parse(“mailto:xxx@xxx.com”));
it.putExtra(Intent.EXTRA_SHORTCUT_INTENT, mailIt);
setResult(RESULT_OK, it);
} else {
setResult(RESULT_CANCELED);
}
finish();
}
实时文件夹(Live Folder)是一个查看你的手机中所有电子书,电子邮件,RSS订阅,播放列表的快捷方式,并且这些内容都是实时更新的。
LiveFolder本身不存储任何信息,都是以映射的方式查看ContentProvider所指向的数据信息,并可以自定义显示格式,所以当源数据发生变化时,LiveFolder可以实时更新显示。
在开发时,我们要保证指定数据的URI的ContentProvider支持LiveFolder的查询。
通过LiveFolder调用电话薄的联系人,点击其中一条数据时,便执行呼叫该联系人的动作。
首先在Activity注册时添加Action为android.intent.action.ACTION_CREATE_LIVE_FOLDER的IntentFilter。
然后我们要在代码中设置LiveFolder的数据源,图标,名字等信息,可以通过intent.setData方法来设置。
在onCreate方法中实现
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
if(getIntent().getAction.equals(LiveFolders.ACTION_CREATE_LIVE_FOLDER)) {
Intent it = new Intent();
// 设置数据
it.setData(Uri.parse(“content://contacts/live_folders/people”));
// 设置单击事件
it.putExtra(LiveFolders.EXTRA_LIVE_FOLDER_BASE_INTENT, new Intent(Intent.ACTION_CALL, Contacts.People.CONTENT_URI));
// 设置名字
it.putExtra(LiveFolders.EXTRA_LIVE_FOLDER_NAME, “电话薄”);
// 设置图标
it.putExtra(LiveFolders.EXTRA_LIVE_FOLDER_ICON, Intent.ShortcutIconResource.fromContext(this, R.drawable.contacts));
// 设置显示模式
it.putExtra(LiveFolders.EXTRA_LIVE_FOLDER_DISPLAY_MODE, LiveFolders.DISPLAY_MODE_LIST);
setResult(RESULT_OK, it);
} else {
setResult(RESULT_CANCELED);
}
finish();
}
Widget开发
Widget是一种很小的应用程序,主要作为Web2.0服务或互联网内容的前端。当Widget被拖到桌面上时,指定一个保留的空间来显示应用提供的自定义内容。用户可以通过这个Widget来和应用交互,例如暂停或切换歌曲。
每个Widget就是一个BroadcastReceiver,它们用XML metadata来描述Widget的细节。AppWidget Framework通过Broadcast intents和Widget通信,Widget的更新使用RemoteViews来发送。RemoteViews被包装成一个layout和特定内容显示到桌面上。
开发Widget步骤:
1. 创建布局文件res/layout/appwidget_provider.xml,用来显示桌面布局。
2. 创建一个描述Widget属性的文件res/xml/xmlappwidget_provider.xml。
在这个文件中,只有一个标签:<appwidget-provider />
属性说明:
android:minWidth, android:minHeight分别指定Widghet的最小宽度和最小高度。
android:updatePeriodMillis是自动更新的时间间隔。
android:initialLayout是Widget的布局描述文件。
android:configure是可选的,在启动Widget启动之前启动。
3. 创建一个继承自AppWidgetProvider的子类。
在AppWidgetProvider提供几个方法:
onUpdate, onDeleted, onEnabled, onDisabled
public class TxrjAppWidgetProvider extends AppWidgetProvider {
public void onUpdate(Context context, AppWidgetManager appWidgetManager, int[] appWidgetIds) {
final int n = appWidgetIds.length;
for(int i=0; i<n; i++) {
updateAppWidget(context, appWidgetManager, appWidgetId, titlePrefix);
}
}
public void onDeleted(Context context, int[] appWidgetIds) {
final int n = appWidgetIds.length;
for(int i=0; i<n; i++) { }
}
// 第一个Widget创建时调用
public void onEnabled(Context context) {
PackageManager packageManager = context.getPackageManager();
packageManager.setComponentEnabledSetting(new ComponentName(“xxx”), “.TxrjBoradcastReceiver”,
PackageManager.COMPONENT_ENABLED_STATE_ENABLED, PackageManager.DONT_KILL_APP);
}
// 最后一个Widget创建时调用
public void onDisabled(Context context) {
PackageManager pm = context.getPackageManager();
packageManager.setComponentEnabledSetting(new ComponentName(“xxx”), “.TxrjReceiver”,
PackageManager.COMPONENT_ENABLED_STATE_ENABLED, PackageManager.DONT_KILL_APP);
}
// 在updateAppWidget方法中,我们构建了一个RemoteViews对象来对Widget进行更新,
// setTextViewText用来更新一个TextView的内容
// updateAppWidget提供给AppWidget使其更新到桌面
public static void updateAppWidget(Context context, AppWidgetManager appWidgetManager, int appWidgetId, String titlePrefix) {
RemoteViews views = new RemoteViews(context.getPackagetName, R.layout.appwidget_provider);
views.setTextViewText(R.id.appwidget_text, titlePrefix);
appWidgetManager.updateAppWidget(appWidgetId, views);
}
}
4. 创建一个BroadcastReceiver来接收更新的信息,收到更新的信息之后就更新Widget。
public class TxrjBoradcastReceiver extends BroadcastReceiver {
public void onReceive(Context context, Intent intent) {
String action = intent.getAction();
if(action.equals(Intent.ACTION_TIMEZONE_CHANGED) || action.equals(Intent.ACTION_TIME_CHANGED)) {
AppWidgetManager widgetManger = AppWidgetManager.getInstance(context);
ArrayList<Integer> appWidgetIds = new ArrayList<Integer>();
ArrayList<String> texts = new ArrayList<String>();
// loadAllTitleTitlePrefs(context, appWidgetIds, texts);
}
}
}
5. 处理android:configure设定的Activity。当点击按钮之后,创建一个AppWidgetManager实例,然后调用TxrjAppWidgetManager.updateAppWidget方法来更新Widget。
AppWidgetManager appWidgetManager = AppWidgetManager.getInstance(context);
6. 在AndroidManifest.xml文件中注册Widget, BroadcastReceiver, Activity
// 注册Widget
<receiver android:name=”.widget.TxrjAppWidgetProvider”>
<meta-data android:name=”android.appwidget.provider” android:resource=”@xml/appwidget_provider” />
<intent-filter>
<action android:name=”android.appwidget.action.APPWIDGET_UPDATE” />
</intent-filter>
</receiver>
// 注册BroadCastReceiver
<receiver android:name=”.receiver.TxrjAppWidgetProvider” android:enabled=”false”>
<intent-filter>
<action android:name=”android.intent.ACTION_TIMEZONE_CHANGED” />
<action android:name=”android.intent.ACTION_TIME_CHANGED” />
</intent-filter>
</receiver>
// 注册Activity
<activity android:name=”.activity.TxrjActivity”>
<intent-filter>
<action android:name=”android.appwidget.action.APPWIDGET_CONFIGURE” />
</intent-filter>
</activity>
Android开发之Shortcuts, LiveFolder, Widget的更多相关文章
- Android开发之InstanceState详解
Android开发之InstanceState详解 本文介绍Android中关于Activity的两个神秘方法:onSaveInstanceState() 和 onRestoreInstanceS ...
- 【Android UI】Android开发之View的几种布局方式及实践
引言 通过前面两篇: Android 开发之旅:又见Hello World! Android 开发之旅:深入分析布局文件&又是“Hello World!” 我们对Android应用程序运行原理 ...
- Android开发之PopupWindow
/* * Android开发之PopupWindow * * Created on: 2011-8-8 * Author: blueeagle * Email: liujiaxiang@g ...
- Android 开发之旅:深入分析布局文件&又是“Hello World!”
http://www.cnblogs.com/skynet/archive/2010/05/20/1740277.html 引言 上篇可以说是一个分水岭,它标志着我们从Android应用程序理论进入实 ...
- android开发之Animations的使用(二)
android开发之Animations的使用(二) 本博文主要讲述的是android开发中的animation动画效果的使用,和上一篇博文不同的是,此次四种动画效果,主要使用的是xml文件实现的,提 ...
- Android开发之TextView高级应用
Android开发之TextView高级应用 我们平时使用TextView往往让它作为一个显示文字的容器,但TextView的功能并不局限于此.以下就和大家分享一下TextView的一些使用技巧. A ...
- Android开发之InstanceState详解(转)---利用其保存Activity状态
Android开发之InstanceState详解 本文介绍Android中关于Activity的两个神秘方法:onSaveInstanceState() 和 onRestoreInstanceS ...
- android开发之Animation(五)
android开发之Animation的使用(五) 本博文主要讲述的是Animation中的AnimationLisenter的用法,以及此类的一些生命周期函数的调用,代码实比例如以下: MainAc ...
- Android开发之Java集合类性能分析
对于Android开发者来说深入了解Java的集合类很有必要主要是从Collection和Map接口衍生出来的,目前主要提供了List.Set和 Map这三大类的集合,今天Android吧(ard8. ...
随机推荐
- hust 1590 - 方块游戏 数学
1590 - 方块游戏 Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://acm.hust.edu.cn/problem/show/1590 D ...
- Dart格式化输出
类似于保留几位小数,直接 n.toStringAsFixed() 例如: 1.toStringAsFixed(3); // 1.000 (4321.12345678).toStringAsFixed( ...
- mybatis源码分析(6)-----核心调度对象StatmentHandler
写在前面 通过上一偏文章,我们知道:mybatis 的插件开发,主要是集中在Executor(执行器),ParameterHandler(参数处理器),ResultSetHandler(结果集处理器) ...
- setTimeout递归调用跳转页面
<!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...
- Redmine 邮件配置
高版本号的Redmine是没有email.yml的.是和configuration.yml合并了.仅仅要配置configuration.yml即可了. 首先得说下Redmine的邮件,配置这个邮件,是 ...
- OpenCV2马拉松第12圈——直方图比較
收入囊中 使用4种不同的方法进行直方图比較 葵花宝典 要比較两个直方图, 首先必需要选择一个衡量直方图相似度的对照标准.也就是先说明要在哪个方面做对照. 我们能够想出非常多办法,OpenCV採用了下面 ...
- sysbench 测试MYSQL
http://imysql.cn/tag/%E5%8E%8B%E6%B5%8B http://imysql.cn/node/312 https://www.percona.com/blog/2013/ ...
- B+树索引
结构上 B树中关键字集合分布在整棵树中,叶节点中不包含任何关键字信息,而B+树关键字集合分布在叶子结点中,非叶节点只是叶子结点中关键字的索引: B树中任何一个关键字只出现在一个结点中,而B+树中的关键 ...
- EntityFramework:我想我需要和 Session.Save 语义一样的方法
背景 EntityFramework 中 DbSet.Add 方法不会导致立即执行 insert 语句,这在长事务中非常有用,不过多数用例都是短事务的,为何我需要一个立即执行 insert 语句的方法 ...
- sqlserver锁大全
锁定提示 描述 HOLDLOCK 将共享锁保留到事务完成,而不是在相应的表.行或数据页不再需要时就立即释放锁.HOLDL ...