AppWidget是创建的桌面窗口小控件,在这个小控件上允许我们进行一些操作(这个视自己的需要而定)。作为菜鸟,我在这里将介绍一下AppWeight的简单使用。

1.在介绍AppWidget之前,我们先来了解一下PendingIntent和RemoteViews;

PendingIntent:A description of an Intent and target action to perform with it. Instances of this class are created with getActivity, getActivities, getBroadcast, and getService; the returned object can be handed to other applications so that they can perform the action you described on your behalf at a later time.

翻译:通过PendingIntent来描述一个Intent和target action,这个类的实例和getActivity,getActivites,getBroadCast,getService一起创建:返回的对象能够传给其他程序,以便它们能在后来执行你想让他们执行的动作。

结合Mars老师的讲解可以这样来理解:PendingIntent能够包含一个Intent对象,能够将这个Intent传递给其他的应用,当满足一定条件时,就会执行这个Intent中包含的动作。getActivity和getActivities是为了启动活动,getBroadcast是为了发送广播,getService是为了开启一个服务。(这个在下面有讲解)

RemoteViews:A class that describes a view hierarchy that can be displayed in another process. The hierarchy is inflated from a layout resource file, and this class provides some basic operations for modifying the content of the inflated hierarchy.

翻译:remoteviews:一个类描述了一个视图的层次结构,可以显示在另一个进程。该层次结构从布局资源文件中增长,该类提供一些基本操作来修改虚化层次结构的内容。
简言之就是RemoteView代表的是显示在桌面上的appwidget这整个布局,包括设置的按钮,图片什么的。。。

2.了解了上面的概念,就可以更好的理解AppWeight了。

实现AppWeige的步骤:

文件的结构:

1).在res下新建一个文件夹,里面新建一个类型为appwidget_provider的xml文件。这个是代表显示在桌面上的整个布局(只是布局的框架,不包含细节,至于显示的内容需要引用另一个布局文件),示例中我的xml文件名为example_appwidget_provider.xml:

<?xml version="1.0" encoding="utf-8"?>
<appwidget-provider xmlns:android="http://schemas.android.com/apk/res/android" android:minWidth = "280dp"
android:minHeight = "100dp"
android:updatePeriodMillis = "864000000"
android:initialLayout="@layout/example_appwidget"> </appwidget-provider>
<!-- 上面设置了布局的宽、高、更新时间周期(毫秒)、包含的布局 -->

  2).在layout中新建一个xml文件来作为在appwidget中的布局显示,就是上面的@layout/example_appwidget中的example_appwidget。

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" > <!-- 这里是显示在桌面的appWidget的布局 -->
<ImageView
android:id="@+id/imageId"
android:layout_width="fill_parent"
android:layout_height="60dp"
android:src="@drawable/cancer"/>
<Button
android:id="@+id/changeButton"
android:layout_width="match_parent"
android:layout_height="40dp"
android:textColor="#00ff00"
android:text="开启另一个活动"/>
</LinearLayout>

  3).新建一个Activity,这个Activity继承AppWidgetProvider,复写其中的方法。在这里注释的代码实现了点击AppWidget中的按钮就启动另一个Activity,未注释的代码实现了ImagView中的Image的替换:值得注意的是,AppWiget所进行的活动并不与当前Main_Activity所在的线程在同一个线程中,因此这里并不能像在主线程中那样操作布局内容,AppWiget的操作方法可以看下面代码。

package com.example.appwight;

import android.app.PendingIntent;
import android.appwidget.AppWidgetManager;
import android.appwidget.AppWidgetProvider;
import android.content.ComponentName;
import android.content.Context;
import android.content.Intent;
import android.widget.RemoteViews; public class ExampleAppWidgetProvider extends AppWidgetProvider{ //广播名称,需要在AppWidget Manifest.xml文件中声明
private static final String UPDATE_INTENT = "com.example.appwidget"; @Override
public void onReceive(Context context, Intent intent) {
//接受广播的时候调用
    //接受广播Action
String action = intent.getAction();
    //当接受到指定的广播时,就执行下main代码
if (UPDATE_INTENT.equals(action)) {
System.out.println("action=======>"+UPDATE_INTENT); RemoteViews remoteViews = new RemoteViews(context.getPackageName(), R.layout.example_appwidget);
       //第一个参数:ImagView的Id,第二个参数:用来替换的图片
remoteViews.setImageViewResource(R.id.imageId, R.drawable.chilli);
AppWidgetManager appWidgetManager = AppWidgetManager.getInstance(context);
//ComponentName也代表AppWidget控件,与RemoteViews不同的是。前者只是代表着“整个”控件,后者包含Button,ImageView,,,等内容
ComponentName componentName = new ComponentName(context, ExampleAppWidgetProvider.class);
appWidgetManager.updateAppWidget(componentName, remoteViews);
}else {
//调用父类的onReceive方法
super.onReceive(context, intent);
}
} @Override
public void onUpdate(Context context, AppWidgetManager appWidgetManager,
int[] appWidgetIds) {
super.onUpdate(context, appWidgetManager, appWidgetIds);
System.out.println("onUpdate");
for (int i = 0; i < appWidgetIds.length; i++) { //Intent intent = new Intent(context, SecondActivity.class);
Intent intent = new Intent();
intent.setAction(UPDATE_INTENT);
/*
* pendingIntent可以包含一个intent
* 第一个参数是当前上下文,第二个参数是包含的intent
* getAcitivity表明这个PendingIntent的目的是为了启动一个activity,此外还有getService(),和getBroadcast()
*PendingIntent pendingIntent = PendingIntent.getActivity(context, 0, intent, 0);
*/
PendingIntent pendingIntent = PendingIntent.getBroadcast(context, 0, intent, 0);
//remoteView代表的是AppWidget的整个布局,第一个参数是包名,第二个参数是AppWidget的布局
RemoteViews remoteViews = new RemoteViews(context.getPackageName(), R.layout.example_appwidget);
//为remoteVIew中的按钮设置点击事件,第一个为按钮的id,第二个参数为要启动的PendingIntent。
remoteViews.setOnClickPendingIntent(R.id.changeButton, pendingIntent);
//更新AppWidget,第一个参数为表明是当前哪个AppWidget(因为可以在桌面上创建多个AppWidget)
//第二个参数为要更新的RemoteViews的对象
appWidgetManager.updateAppWidget(appWidgetIds[i], remoteViews);
}
} @Override
public void onDeleted(Context context, int[] appWidgetIds) {
//删除AppWidget的时候调用
super.onDeleted(context, appWidgetIds);
System.out.println("onDeleted");
} @Override
public void onEnabled(Context context) {
//当AppWidget被创建的时候调用
super.onEnabled(context);
System.out.println("onEnabled");
} @Override
public void onDisabled(Context context) {
//当最后一个AppWidget被删除的时候调用
super.onDisabled(context);
System.out.println("onDisable");
} }

  4).在AndroidManifest.xml文件中的<application 中声明。

<receiver
android:name="com.example.appwight.ExampleAppWidgetProvider">
        //过滤广播
<intent-filter >
<action android:name="android.appwidget.action.APPWIDGET_UPDATE"/>
<action android:name="com.example.appwidget"/>
</intent-filter>
        //元数据,将布局与类绑定
<meta-data android:name="android.appwidget.provider"
android:resource="@xml/example_appwidget_provider"/>
</receiver>

效果图:

android 之 桌面的小控件AppWidget的更多相关文章

  1. 怎样在Android实现桌面清理内存简单Widget小控件

    怎样在Android实现桌面清理内存简单Widget小控件 我们常常会看到类似于360.金山手机卫士一类的软件会带一个widget小控件,显示在桌面上,上面会显示现有内存大小,然后会带一个按键功能来一 ...

  2. Android 布局之LinearLayout 子控件weight权重的作用详析(转)

    关于Android开发中的LinearLayout子控件权重android:layout_weigh参数的作用,网上关于其用法有两种截然相反说法: 说法一:值越大,重要性越高,所占用的空间越大: 说法 ...

  3. Android高效率编码-细节,控件,架包,功能,工具,开源汇总,你想要的这里都有

    Android高效率编码-细节,控件,架包,功能,工具,开源汇总 其实写博客的初衷也并不是说什么分享技术,毕竟咱还只是个小程序员,最大的目的就是对自我的知识积累,以后万一编码的时候断片了,也可以翻出来 ...

  4. Android开发工程师文集-相关控件的讲解,五大布局

    前言 大家好,给大家带来Android开发工程师文集-相关控件的讲解,五大布局的概述,希望你们喜欢 TextView控件 TextView控件有哪些属性: android:id->控件的id a ...

  5. Android 布局之LinearLayout 子控件weight权重的作用详析

    关于Android开发中的LinearLayout子控件权重android:layout_weigh参数的作用,网上关于其用法有两种截然相反说法: 说法一:值越大,重要性越高,所占用的空间越大: 说法 ...

  6. android中一个评分的控件

    RatingBar android中一个评分的控件 如何使用 Android Studio下: dependencies { compile 'com.hedgehog.ratingbar:app:1 ...

  7. Android自定义控件之自定义组合控件

    前言: 前两篇介绍了自定义控件的基础原理Android自定义控件之基本原理(一).自定义属性Android自定义控件之自定义属性(二).今天重点介绍一下如何通过自定义组合控件来提高布局的复用,降低开发 ...

  8. Android 开源组件 ----- Android LoopView无限自动轮转控件

    Android 开源组件 ----- Android LoopView无限自动轮转控件 2015-12-28 15:26 by 杰瑞教育, 32 阅读, 0 评论, 收藏, 编辑 一.组件介绍 App ...

  9. android学习日记03--常用控件button/imagebutton

    常用控件 控件是对数据和方法的封装.控件可以有自己的属性和方法.属性是控件数据的简单访问者.方法则是控件的一些简单而可见的功能.所有控件都是继承View类 介绍android原生提供几种常用的控件bu ...

随机推荐

  1. linux 文件与进程

    1. linux查看一个文件正被那些程序使用 fuser -hUsage: fuser [-fMuvw] [-a|-s] [-4|-6] [-c|-m|-n SPACE] [-k [-i] [-SIG ...

  2. 实用手册:130+ 提高开发效率的 vim 常用命令

    Vim 是从 vi 发展出来的一个文本编辑器.代码补完.编译及错误跳转等方便编程的功能特别丰富,在程序员中被广泛使用.和 Emacs 并列成为类 Unix 系统用户最喜欢的编辑器.这里收录了130+程 ...

  3. Cocos2d-x SpriteFrameCache的使用

    根据官方文档与其他c++属性实现的类似书中示例: 图中的小人是会动的. 首先使用texturepacker制作出一张拼图,导出plist等文件: plist类似: 3.x的cocos似乎不再鼓励使用什 ...

  4. java抽象类和接口区别

    深入理解Java的接口和抽象类 对于面向对象编程来说,抽象是它的一大特征之一.在Java中,可以通过两种形式来体现OOP的抽象:接口和抽象类.这两者有太多相似的地方,又有太多不同的地方.很多人在初学的 ...

  5. 分享一下我封装iOS自定义控件的体会,附上三个好用的控件Demo <时间选择器&多行输入框&日期选择器>

    前段时间有小伙伴问到我:"这样的控件该怎么做呢?",我感觉是个比较简单的控件,可能对于入行不久的同志思路没有很清晰吧.趁着最近工作不忙,就来这里分享一下我封装自定义控件的几点体会吧 ...

  6. IIS负载均衡的NLB解决方案

    在现行的许多网络应用中,有时一台服务器往往不能满足客户端的要求,此时只能通过增加服务器来解决问题.那么,有没有一个办法或者技术来解决此类问题呢?使用Windows 2000或Windows Serve ...

  7. IOS开发UI基础 UIAlertView的属性

    UIAlertView1.Title获取或设置UIAlertView上的标题. 2.Message获取或设置UIAlertView上的消息 UIAlertView *alertView = [[UIA ...

  8. Device eth0 does not seem to be present,delaying initialization解决方法

    Bringing up interface eth0:  Device eth0 does not seem to be present, delaying initialization. 在linu ...

  9. android SQLite(安卓数据库的插入显示删除)

    1.利用android自带数据库实现增加.删除.显示用户等操作 只是一个基本模型,为即将的与 复利计算apk整合做牺牲. 就不上传百度云供大家下载了 等整合了复利计算再上传. 数据的插入和显示:   ...

  10. 重构第7天 重命名(Rename )

    理解:重命名就是把一些函数.字段.类.参数的名称 重命名为易于理解,最好是和自身的意义相同的名称.这样更易于理解,也可以减少大量的注释,名字即含义. 详解: 这个重构方法是我经常也是最常用的一种.我们 ...