Widgets窗口小部件

Widgets就是指窗口小部件,就是浮动在窗口中的部件.
2.当添加小部件的时候,是发出一个更新广播,对于同一个,窗口小部件可以
  在桌面上放置多个.
---------------------------------------
3.如果只要更新特定某个Widgets,需要给要更新的Widgets指定ip
  如果更新某一种Widgets,需要指定Widgets的名称
----------------------------------------------
4.这里为了演示Widgets应用,借助帮助文档来完成,一个显示时间的窗口小部件.
  帮组文档地址:
  G:\android\android-sdk-windows\docs\guide\topics\appwidgets\index.html
------------------------------------------------------------
a.首先在清单文件中描述:
   Declaring an App Widget in the Manifest
    First, declare the AppWidgetProvider class in your application's AndroidManifest.xml file. For example:
<receiver android:name="ExampleAppWidgetProvider" >  
<intent-filter>     
<action android:name="android.appwidget.action.APPWIDGET_UPDATE" />   
</intent-filter> 
<meta-data android:name="android.appwidget.provider"    
android:resource="@xml/example_appwidget_info" />
</receiver>
  通过这里可以看到,这里:Widgets就是广播接收者,就是通过广播接收者实现的.
--------------------------------------------------------------------------
b.adding the AppWidgetProviderInfo Metadata添加widget的元数据.
  The AppWidgetProviderInfo defines the essential qualities of an App Widget, 
  such as its minimum layout dimensions, its initial layout resource, 
  how often to update the App Widget, and (optionally) a configuration Activity to
  launch at create-time. Define the AppWidgetProviderInfo object in an XML resource 
  using a single <appwidget-provider> element and save it in the project's res/xml/ folder.

For example:
<appwidget-provider xmlns:android=""   
android:minWidth="294dp"  
android:minHeight="72dp"    
android:updatePeriodMillis="86400000" 
android:previewImage="@drawable/preview"//这个用来指定预览的图片    
android:initialLayout="@layout/example_appwidget" 
android:configure="com.example.android.ExampleAppWidgetConfigure"
//这里用来指定一个activity,这个activity用来对widget进行参数配置的
android:resizeMode="horizontal|vertical">//这里是重树模式,水平的还是垂直的
</appwidget-provider>
---------------------------------------------------------
5./widgets/res/layout/time_appwidget.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android=""
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical" 
    android:background="@drawable/rectangle"
    //指定widget的背景图片
    >
<!-- //这个text这个是widget的界面 
-->
    <TextView 
        android:layout_width="match_parent"
     android:layout_height="match_parent"
        android:id="@+id/textView"
        android:textColor="#FFFFFF"
        android:textSize="14dp"
        android:text="我是Widgets"
        />

</LinearLayout>
----------------------------------------------------------------------------
6./widgets/res/drawable/rectangle.xml
  <?xml version="1.0" encoding="utf-8"?>
<shape
    xmlns:android=""
    android:shape="rectangle">//方形
    <corners android:radius="9dp"/>//圆角的半径
    <gradient//渐变色
        android:angle="270"       
        android:endColor="#5EADF4"//红色过度到黄色,结束的颜色
        android:startColor="#B3F0FF" />//开始的颜色
    <padding
        android:left="5dp"//内间距,内容离里边界的距离
        android:top="5dp"
        android:right="5dp"
        android:bottom="5dp" />

    <stroke//边界的颜色.
        android:width="1dp"
        android:color="#0000CC"
        android:dashWidth="10dp"
        android:dashGap="6dp" />
</shape>
<!-- 建立一个方形 -->
-----------------------------------------------------------
下面是一个显示时间的一个widgets的所有源码:
1./widgets/src/com/credream/widget/TimerService.java
  package com.credream.widget;

import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.Timer;
import java.util.TimerTask;

import android.app.PendingIntent;
import android.app.Service;
import android.appwidget.AppWidgetManager;
import android.content.ComponentName;
import android.content.Intent;
import android.net.Uri;
import android.os.IBinder;
import android.widget.RemoteViews;

public class TimerService extends Service {
 //服务要继承Service,要在清单文件中进行配置
/*    <service android:name=".TimerService"></service>
这里的写法是这样的.
 </application>
*/ 
 //1.这里用一个定时器,来定时刷新widget.
 private Timer timer;
 
 //1.当服务的实例第一次被创建的时候会调用这个方法.
 @Override
 public void onCreate() {
  super.onCreate();
  timer = new Timer();
  // timer.schedule(new TimeUpdateTask(), 0, 1000);
  /*参数的意思是:第一个是定时器要定时执行什么任务,第二个是,要延时多长时间执行,
  第三个是每隔多长时间执行一次.这里1000是代表1秒.
  
  */
  timer.schedule(new TimeUpdateTask(), 0, 1000);
 }
 // 3.定时器要执行的方法。
 private final class TimeUpdateTask extends TimerTask{
  // 4.重写run方法
  public void run() {
   SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
   String time = dateFormat.format(new Date());
   RemoteViews remoteView = new RemoteViews(getPackageName(), R.layout.time_appwidget);
   remoteView.setTextViewText(R.id.textView, time);
   // 7.这里控制,当用户点击这个widget的时候,要激活的哪个activity.哪个应用.
   // PendingIntent.getActivity打开activity对象.
   PendingIntent pendingIntent = PendingIntent.getActivity(getApplicationContext(), 100,
     // 8.指定要激活的activity.Intent.ACTION_CALL指定电话拨号器.0标志.
     new Intent(Intent.ACTION_CALL, Uri.parse("tel:133333333")), 0);
     
   remoteView.setOnClickPendingIntent(R.id.textView, pendingIntent);
   // 5.取得widget管理器.//AppWidgetManager.getInstance()内部实现是通过service得到了一个系统的服务
   // widget是一个远程服务.
   AppWidgetManager appWidgetManager = AppWidgetManager.getInstance(getApplicationContext());
   // 6.new ComponentName(getApplicationContext(), TimeWidgetProvider.class), remoteView)
   //  这里是指会更新所有同类型的桌面上的widget的数据,remoteView这是指widget的类型
   appWidgetManager.updateAppWidget(
     new ComponentName(getApplicationContext(), TimeWidgetProvider.class), remoteView);
  }  
 }
// 7.当服务被摧毁的时候,要取消定时器.
 // 8.当把widget第一次添加到桌面上的时候,就启动服务,当最后一个同类型的widget被停掉了的话,就停止服务.
 
 @Override
 public void onDestroy() {
  timer.cancel();
  timer = null;
  super.onDestroy();
 }

 @Override
 public IBinder onBind(Intent intent) {
  // TODO Auto-generated method stub
  return null;
 }

}
---------------------------------------------------------
2./widgets/src/com/credream/widget/TimeWidgetProvider.java
  package com.credream.widget;


import java.text.SimpleDateFormat;
import java.util.Date;

import android.appwidget.AppWidgetManager;
import android.appwidget.AppWidgetProvider;
import android.content.Context;
import android.content.Intent;
import android.widget.RemoteViews;

public class TimeWidgetProvider extends AppWidgetProvider {
// 5.当widget被删除的时候,不需要再清单文件中对,广播进行订阅,广播接收者也可以接收到这个广播信息
 // 当widget被删除的时候会自动的发出一个删除广播
 
 
 
 //1.当添加完一个widget后,会发送一个广播,然后广播会附带一个参数,这个参数
 //会被系统截获,系统根据参数:这里得到的参数是固定的,是系统规定的一个参数:
 //android:name="android.appwidget.action.APPWIDGET_UPDATE
 //系统得到这个名字后,会调用onUpdate方法
 // 3.当用户在桌面上删除widget的时候,会自动的调用这个方法.
 // 这时候onDeleted不用写内容,因为,当如果桌面上有很多同类型的widget的话,
 // 如果在这个方法里停掉服务,那么同类型的其他widget也没办法运行了.
 @Override
 public void onDeleted(Context context, int[] appWidgetIds) {//当用户从桌面上删除widgets的时候就会调用此方法
  
 }
 // 5.//第一次往桌面添加Widgets的时候才会被调用,往后再往桌面添加同类型Widgets的时候是不会被调用的
 @Override
 public void onEnabled(Context context) {
  // 
  context.startService(new Intent(context, TimerService.class));
 }


转自: http://www.02521.com/cod/28307.html 

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值