android 在桌面上添加小窗口(AppWidget)

1.AppWidgetProviderInfo对象:
为App Widget提供元数据,包括布局,更新频率等等数据。这个对象被定义在XML文档中;
2.AppWidgetProvider定义了App Widget的基本生命周期函数

AppWidget与主程序没在一个进程中

创建pendingIntent的方法
1.PendingIntent pendingIntent = PendingIntent.getActivity(context, 0, intent, 0);//创建一个新的activity
2.PendingIntent pendingIntent = PendingIntent.getBroadcast(context, 0, intent, 0);//发送一个广播

3.PendingIntent.getService(context, requestCode, intent, flags)//创建一个service

首先是AndroidManifest.xml文件

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.yx.appwidget"
    android:versionCode="1"
    android:versionName="1.0" >

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

    <application
        android:allowBackup="true"
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >
        <activity
            android:name="com.yx.appwidget.MainActivity"
            android:label="@string/app_name" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />
                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        <activity
            android:name="com.yx.appwidget.TargetActivity"
            android:label="@string/app_name" >
        </activity>
        <!--ExampleAppWidgetProvider为一个继承AppWidgetProvider的java文件,在这个文件中实现对AppWidget的控制-->
        <receiver android:name="ExampleAppWidgetProvider">
            <intent-filter>
                <!-- 系统action-->
                <action android:name="android.appwidget.action.APPWIDGET_UPDATE" />
            </intent-filter>
            <intent-filter>
                <!-- 自定义的action-->
                <action android:name="yuexin.AppWidget.UPDATE_APPWIDGET" />
            </intent-filter>
            <meta-data android:name="android.appwidget.provider"
                android:resource="@xml/example_appwidget_info"
                /><!--这里指定xml文件这个文件指定了桌面显示的样式-->

        </receiver>
    </application>

</manifest>


再在res下建立xml文件夹新建example_appwidget_info.xml文件

<appwidget-provider xmlns:android="http://schemas.android.com/apk/res/android"
    android:minWidth="294dp"
    android:minHeight="72dp"
    android:updatePeriodMillis="86400000"
    android:initialLayout="@layout/example_appwidget"
></appwidget-provider>
<!-- android:initialLayout="@layout/example_appwidget" 此句为指定桌面组件的布局文件 -->


example_appwidget.xml文件  指定了布局(自己随便布局)

<?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" >
    <TextView
        android:id="@+id/widgetTextId"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:text="firstWidgetText"
        android:textColor="#000000"
        />
       <Button
        android:id="@+id/widgetButtonId"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:text="测试按钮"
        />
</LinearLayout>
下来就是最主要的了ExampleAppWidgetProvider.java文件

package com.yx.appwidget;

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{
    //定义一个常量字符串,该常量用于命名action,与AndroidManifest.xml文件中的 自定义的action一致,广播是从onUpdate方法中发出,而用onReceive方法接收的。
    private static final String UPDATE_ACTION = "yuexin.AppWidget.UPDATE_APPWIDGET";

    @Override
    public void onDeleted(Context context, int[] appWidgetIds) {
        //当appWidget删除时调用
        System.out.println("onDeleted");
        super.onDeleted(context, appWidgetIds);
    }

    @Override
    public void onDisabled(Context context) {
        //当appWidget全部删除时调用
        System.out.println("onDisabled");
        super.onDisabled(context);
    }

    @Override
    public void onEnabled(Context context) {
        //当appwidget第一次创建时调用
        System.out.println("onEnabled");
        super.onEnabled(context);
    }

    @Override
    public void onReceive(Context context, Intent intent) {
        //接收程序中的广播
        System.out.println("onReceive");
        String action = intent.getAction();
        if(UPDATE_ACTION.equals(action)){
            System.out.println("onReceive--->"+action);
            RemoteViews remoteViews = new RemoteViews(context.getPackageName(),R.layout.example_appwidget);
            remoteViews.setTextViewText(R.id.widgetTextId, "阿哥阿斯顿个");//修改TextView中的东西,RemoteViews中有很多方法可以调用,用来修改AppWidget中的控件内容
            AppWidgetManager appWidgetManager = AppWidgetManager.getInstance(context);
            ComponentName componentName = new ComponentName(context, ExampleAppWidgetProvider.class);
            appWidgetManager.updateAppWidget(componentName, remoteViews);
        }else{
            //保证运行系统的广播
            super.onReceive(context, intent);
        }
    }

    @Override
    public void onUpdate(Context context, AppWidgetManager appWidgetManager,
            int[] appWidgetIds) {
        /*
        //打开一个新的activity
        for(int i=0;i<appWidgetIds.length;i++){
            //创建一个intent对象,目的是跳转到TargetActivity
            Intent intent = new Intent(context,TargetActivity.class);
            //创建一个PendingIntent
            PendingIntent pendingIntent = PendingIntent.getActivity(context, 0, intent, 0);
            RemoteViews remoteViews = new RemoteViews(context.getPackageName(),R.layout.example_appwidget);
            //为按钮绑定事件处理器。第一个参数为控件id,第二个参数指定当控件点击时那个pendingIntent会被执行
            remoteViews.setOnClickPendingIntent(R.id.widgetButtonId, pendingIntent);
            //更新appWidget。第一个参数用于指定Appwidget的id
            appWidgetManager.updateAppWidget(appWidgetIds[i], remoteViews);
        }
         */
        
        //广播
        //创建一个intent对象,并设置action
        Intent intent = new Intent();
        intent.setAction(UPDATE_ACTION);
        //创建一个PendingIntent,当该对象执行时会发送一个广播
        PendingIntent pendingIntent = PendingIntent.getBroadcast(context, 0, intent, 0);
        RemoteViews remoteViews = new RemoteViews(context.getPackageName(),R.layout.example_appwidget);
        //为按钮绑定事件处理器。第一个参数为控件id,第二个参数指定当控件点击时那个pendingIntent会被执行
        remoteViews.setOnClickPendingIntent(R.id.widgetButtonId, pendingIntent);
        //更新appWidget。第一个参数用于指定Appwidget的id
        appWidgetManager.updateAppWidget(appWidgetIds, remoteViews);
        super.onUpdate(context, appWidgetManager, appWidgetIds);
    }

    
}

最后贴上其他一些没有太大关系的代码,使项目完整

MainActivity。java

package com.yx.appwidget;

import android.os.Bundle;
import android.app.Activity;
import android.view.Menu;

public class MainActivity extends Activity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
    }

    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        // Inflate the menu; this adds items to the action bar if it is present.
        getMenuInflater().inflate(R.menu.main, menu);
        return true;
    }

}

TargetActivity.java
package com.yx.appwidget;

import android.app.Activity;
import android.os.Bundle;

public class TargetActivity extends Activity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
    }

    
}

activity_main.xml

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    tools:context=".MainActivity" >

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="@string/hello_world" />

</RelativeLayout>



發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章