Android學(xué)習(xí)之AppWidget筆記分享
什么是AppWidget?AppWidget就是我們平常在桌面上見到的那種一個個的小窗口,利用這個小窗口可以給用戶提供一些方便快捷的操作。
今天的目標(biāo)就是怎么創(chuàng)建一個簡單的AppWidget。
首先我先把目錄結(jié)構(gòu)展示一下,方便大家理解。

第一步:我們需要在res目錄下創(chuàng)建一個folder,可以命名為xml(但這并不是必須的,你也可以換成你喜歡的名字)。然后在這么目錄下創(chuàng)建一個xml文件。我的appwidget.xml文件代碼如下:
<appwidget-provider xmlns:android="http://schemas.android.com/apk/res/android" android:minHeight="72dp" android:minWidth="294dp" android:updatePeriodMillis="86400000" android:initialLayout="@layout/example_widget" > </appwidget-provider>
小注解:
在android的命名空間下聲明了appwidget 的最小的高度、寬度、以及更新的時間(注意是以毫秒為單位的)和最重要的綁定的布局文件(所謂布局文件就是展示到桌面上的界面的外觀)。
第二步:下面的這個文件是在上面的appwidget.xml中的initialLayout屬性中綁定的xml布局文件,即example_widget.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/textview1" android:layout_width="match_parent" android:layout_height="wrap_content" android:text="MyFirst Widget Example!" > </TextView> <!--由于只是實現(xiàn)簡單的效果,所以就只用一個TextView吧--> </LinearLayout>
第三步:實現(xiàn)了布局展示界面,下面自然而然的,我們就會想到要怎么讓這個布局界面展示出來,所以就必須有一個provider,因此,下面就需要創(chuàng)建一個繼承了AppWidgetProvider的實例,來完成這一個功能。我的文件名稱命名為Widget.java.
package com.summer.widgettest;
import android.appwidget.AppWidgetManager;
import android.appwidget.AppWidgetProvider;
import android.content.Context;
/**
*在這四個必須的方法中,只是打印出一句話,來觀察其“生命周期”即可
*/
public class Widget extends AppWidgetProvider {
@Override
public void onUpdate(Context context, AppWidgetManager appWidgetManager,
int[] appWidgetIds) {
// TODO Auto-generated method stub
System.out.println("onUpdate");
super.onUpdate(context, appWidgetManager, appWidgetIds);
}
@Override
public void onDeleted(Context context, int[] appWidgetIds) {
// TODO Auto-generated method stub
System.out.println("onDeleted");
super.onDeleted(context, appWidgetIds);
}
@Override
public void onDisabled(Context context) {
// TODO Auto-generated method stub
System.out.println("onDisabled");
super.onDisabled(context);
}
@Override
public void onEnabled(Context context) {
// TODO Auto-generated method stub
System.out.println("onEnabled");
super.onEnabled(context);
}
}
第四步:這也是最為關(guān)鍵的一步,因為前面的工作都是為這一步來打基礎(chǔ)的。那么要怎么做捏?答案就是清單文件,在清單文件中進(jìn)行聲明就可以了。我的代碼如下:
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.summer.widgettest"
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.summer.widgettest.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="com.summer.widgettest.Widget">
<intent-filter >
<action android:name="android.appwidget.action.APPWIDGET_UPDATE"/>
</intent-filter>
<meta-data android:name="android.appwidget.provider"
android:resource="@xml/appwidget_info"/>
</receiver>
</application>
</manifest>
小注解:
在這里我么也不難看出,原來widget也就是個廣播事件啊,所以需要使用receiver ,然后接下來是一個inent-filter過濾器,功能就是過濾出符合要求的action,在這里當(dāng)然是widget動作了。
接下來有一個meta-data元數(shù)據(jù)解釋,作用就是對這個widget進(jìn)行解釋的作用,也是為了讓android系統(tǒng)知道這到底是個什么東西。(偷偷告訴你,一般這兩個要點是固定的表達(dá))
好了,萬事具備,只欠”運行“了,接下來就是程序運行之后的界面。。上面的那一行文字就是程序運行之后

就可以看到的結(jié)果,也就是我們”自制“的一個AppWidget了。(說實話,真的是不太好看)。
回顧與總結(jié):
1、怎么實現(xiàn)的這個AppWidget?先是在res文件夾下創(chuàng)建一個xml 文件夾,并在里面添加一個appwidget-provider文件,再就是寫一個用于呈現(xiàn)內(nèi)容的布局文件。接下來就是一個繼承自AppWidgetProvider的類的創(chuàng)建,然后再清單文件中進(jìn)行相關(guān)項的聲明就可以了。
2、邏輯思路很重要,每一步的銜接是思路的引導(dǎo)點。
3、這里僅僅是一個簡單的小例子,接下來要做的就是如何讓這個widget和我們的系統(tǒng)進(jìn)行交互。
4、好了,大致就是這樣,歡迎廣大博友留言評論,我一定會虛心的接受,希望能和你們一起進(jìn)步!
—————————–這里是華麗的分界線——————
上面的是創(chuàng)建一個簡單的appWidget的示例,下面是關(guān)于如何實現(xiàn)這些Widget如何實現(xiàn)相關(guān)的動作偵聽的。
知識點準(zhǔn)備:
我們應(yīng)該知道的是,android的widget的進(jìn)程與程序運行的進(jìn)程并不是同一個進(jìn)程,這就意味著我們不能像往常一樣簡單的使用一個setOnClickListener方法了,因為這樣做是完不成相關(guān)的動作的偵聽的功能的。那么問題來了,我們要怎么實現(xiàn)這些動作的交互呢?
別著急,答案是采用RemoteViews,顧名思義就是采用”遠(yuǎn)程的“方式來實現(xiàn)相關(guān)的處理操作。接下來讓我們一起來看一下具體的實現(xiàn)流程吧。--------------------------------------------------------------------------------
第一步:在之前的appWidget的布局文件中添加一個按鈕,用來實現(xiàn)布局。
<Button android:id="@+id/button1" android:layout_width="match_parent" android:layout_height="wrap_content" android:text="Click To Renew!" > </Button>
第二步:然后再Widget.java這個AppWidgetProvider的實現(xiàn)類的onUpdate方法中實現(xiàn)相關(guān)的代碼。為了更好地展示效果,我們可以新建一個Activity,用來呈現(xiàn)點擊按鈕之后跳轉(zhuǎn)的界面的展示。我命名為RenewActivity.java.相關(guān)源碼如下所示
@Override
public void onUpdate(Context context, AppWidgetManager appWidgetManager,
int[] appWidgetIds) {
// TODO Auto-generated method stub
System.out.println("onUpdate");
for(int i=0;i<appWidgetIds.length;i++){
//check which appwidget is enabled!
System.out.println(appWidgetIds[i]);
Intent intent=new Intent(context,RenewActivity.class);
PendingIntent pendingIntent=PendingIntent.getActivity(context, 0, intent, 0);
RemoteViews remoteViews=new RemoteViews(context.getPackageName(), R.layout.example_widget);
remoteViews.setOnClickPendingIntent(R.id.button1, pendingIntent);
appWidgetManager.updateAppWidget(appWidgetIds[i], remoteViews);
}
super.onUpdate(context, appWidgetManager, appWidgetIds);
}
RenewActivity.java
package com.summer.widgettest;
import android.app.Activity;
import android.os.Bundle;
public class RenewActivity extends Activity{
@Override
protected void onCreate(Bundle savedInstanceState) {
// TODO Auto-generated method stub
super.onCreate(savedInstanceState);
setContentView(R.layout.renew);
}
//由于renew布局是一個非常簡單的界面(一個TextView而已),所以不再貼出代碼
}
第三步:不要忘記在清單文件中進(jìn)行Activity的聲明,否則你是看不到界面的效果的。
<activity android:name="com.summer.widgettest.RenewActivity" android:label="Renew Activity!" > </activity>
效果圖如下所示:


小總結(jié):
在Widget的onUpdate方法中,我們使用到了RemoteViews類的實例,起作用就不再詳細(xì)的闡述,這里就直接解釋代碼的功能吧。如上,創(chuàng)建其實例的時候需要兩個參數(shù)分別為上下文對象的包名和widget的”布局“,然后在進(jìn)行對按鈕的時間偵聽的時候使用到了一個叫pendingIntent的實例,其作用就是將遠(yuǎn)程的消息信息傳達(dá)給相應(yīng)的處理邏輯中,進(jìn)而實現(xiàn)對widget上按鈕的動作的偵聽處理。然后使用appWidgetManager進(jìn)行更新操作就可以了!如此便可以完成我們的代碼的邏輯。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Android Studio進(jìn)行APP圖標(biāo)更改的兩種方式總結(jié)
這篇文章主要介紹了Android Studio進(jìn)行APP圖標(biāo)更改的兩種方式總結(jié),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-06-06
Android WorkManager實現(xiàn)后臺定時任務(wù)流程詳解
WorkManager是Android Jetpack的一個強大的組件,用于處理后臺耗時任務(wù)。后臺任務(wù)可以是一次性的,也可以是重復(fù)的,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧2023-01-01
Android之Viewpager+Fragment實現(xiàn)懶加載示例
本篇文章主要介紹了Android之Viewpager+Fragment實現(xiàn)懶加載示例,具有一定的參考價值,感興趣的小伙伴們可以參考一下。2017-03-03
Jetpack?Compose實現(xiàn)對角線滾動效果
這篇文章主要為大家詳細(xì)介紹了如何利用Jetpack?Compose實現(xiàn)一個簡單的對角線滾動效果,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下2023-02-02
Android自定義View實現(xiàn)圓形進(jìn)度條
這篇文章主要為大家詳細(xì)介紹了Android自定義View實現(xiàn)圓形進(jìn)度條,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-06-06
android 對話框彈出位置和透明度的設(shè)置具體實現(xiàn)方法
在android中我們經(jīng)常會用AlertDialog來顯示對話框。通過這個對話框是顯示在屏幕中心的。但在某些程序中,要求對話框可以顯示在不同的位置。2013-07-07
Android自定義View實現(xiàn)自動轉(zhuǎn)圈效果
這篇文章主要為大家詳細(xì)介紹了Android自定義View實現(xiàn)自動轉(zhuǎn)圈效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-05-05

