android 桌面插件 App Widget

App Widget :自定义的桌面插件,功能:当长时间触摸手机屏幕,可以添加控件,点击添加控件,可以显示出自己编写出的控件



如图,TextText-----------------桌面插件的生成。

下面是实现改功能的步骤

第一步:定义一个AppWidgetProviderInfo: 在res / xml文件夹中定义一个example_appwidget_info.xml的文件

<appwidget-provider xmlns:android="http://schemas.android.com/apk/res/android"
    android:initialLayout="@layout/example_appwidge"
    android:minHeight="72dp"
    android:minWidth="294dp"
    android:updatePeriodMillis="86400000" >

</appwidget-provider>

第二步就是添加一个布局文件

<?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/vidgetTextId"
        android:layout_width="80dp"
        android:layout_height="80dp"
        android:text="TextText--------------"
        android:background="#000000"/>
    

</LinearLayout>

第三步实现AppWidgetProvider

复写五个函数,

onUpdate:  添加App Widget时会调用该方法

onDeleted: 删除App Widget时会调用该方法

onEnabled:  第一个App Widget创建时会调用该方法

onDisabled: 最后一个App Widget 被删除时会调用该方法

onReveice: 接收广播事件,一般很少调用

新建一个类,继承 AppWidgetProvider,复写上面五个函数


package com.example.acti_02_05_appwidge;

import android.appwidget.AppWidgetManager;
import android.appwidget.AppWidgetProvider;
import android.content.Context;
import android.content.Intent;
import android.os.Bundle;


public class ExampleAppWodgetProvider extends AppWidgetProvider {
	
	
	@Override
	public void onAppWidgetOptionsChanged(Context context,
			AppWidgetManager appWidgetManager, int appWidgetId,
			Bundle newOptions) {
		// TODO Auto-generated method stub
		super.onAppWidgetOptionsChanged(context, appWidgetManager, appWidgetId,
				newOptions);
	}

	@Override
	public void onDeleted(Context context, int[] appWidgetIds) {
		// TODO Auto-generated method stub
		super.onDeleted(context, appWidgetIds);
		System.out.println("onDeleted");
	}

	@Override
	public void onDisabled(Context context) {
		// TODO Auto-generated method stub
		super.onDisabled(context);
		System.out.println("onDisable");
	}

	@Override
	public void onEnabled(Context context) {
		// TODO Auto-generated method stub
		super.onEnabled(context);
		System.out.println("onEnabled");
	}

	@Override
	public void onReceive(Context context, Intent intent) {
		// TODO Auto-generated method stub
		super.onReceive(context, intent);
		System.out.println("onReceive");
	}

	@Override
	public void onUpdate(Context context, AppWidgetManager appWidgetManager,
			int[] appWidgetIds) {
		// TODO Auto-generated method stub
		super.onUpdate(context, appWidgetManager, appWidgetIds);
		System.out.println("onUpdate");
	}

	public ExampleAppWodgetProvider() {
		// TODO Auto-generated constructor stub
	}
 
}

第四步在Manifest.xml文件中添加<receiver>,这个<receiver>的名就是第三步新建的类,这个类就是AppWidgerProvider的子类,这里还有个<inter-filter>接收数据的一个过滤器。里面有个属性<action>这里面有一个安卓自带的。下面还有一个<meta-data>这是一个元数据

  <?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.acti_02_05_appwidge"
    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.example.acti_02_05_appwidge.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>

        <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_appwidge_info" />
        </receiver>
    </application>

</manifest>



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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值