Android學(xué)習(xí)之AppWidget筆記分享
什么是AppWidget?AppWidget就是我們平常在桌面上見(jiàn)到的那種一個(gè)個(gè)的小窗口,利用這個(gè)小窗口可以給用戶提供一些方便快捷的操作。
今天的目標(biāo)就是怎么創(chuàng)建一個(gè)簡(jiǎn)單的AppWidget。
首先我先把目錄結(jié)構(gòu)展示一下,方便大家理解。
第一步:我們需要在res目錄下創(chuàng)建一個(gè)folder,可以命名為xml(但這并不是必須的,你也可以換成你喜歡的名字)。然后在這么目錄下創(chuàng)建一個(gè)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 的最小的高度、寬度、以及更新的時(shí)間(注意是以毫秒為單位的)和最重要的綁定的布局文件(所謂布局文件就是展示到桌面上的界面的外觀)。
第二步:下面的這個(gè)文件是在上面的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> <!--由于只是實(shí)現(xiàn)簡(jiǎn)單的效果,所以就只用一個(gè)TextView吧--> </LinearLayout>
第三步:實(shí)現(xiàn)了布局展示界面,下面自然而然的,我們就會(huì)想到要怎么讓這個(gè)布局界面展示出來(lái),所以就必須有一個(gè)provider,因此,下面就需要?jiǎng)?chuàng)建一個(gè)繼承了AppWidgetProvider的實(shí)例,來(lái)完成這一個(gè)功能。我的文件名稱命名為Widget.java.
package com.summer.widgettest; import android.appwidget.AppWidgetManager; import android.appwidget.AppWidgetProvider; import android.content.Context; /** *在這四個(gè)必須的方法中,只是打印出一句話,來(lái)觀察其“生命周期”即可 */ 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)鍵的一步,因?yàn)榍懊娴墓ぷ鞫际菫檫@一步來(lái)打基礎(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>
小注解:
在這里我么也不難看出,原來(lái)widget也就是個(gè)廣播事件啊,所以需要使用receiver ,然后接下來(lái)是一個(gè)inent-filter過(guò)濾器,功能就是過(guò)濾出符合要求的action,在這里當(dāng)然是widget動(dòng)作了。
接下來(lái)有一個(gè)meta-data元數(shù)據(jù)解釋,作用就是對(duì)這個(gè)widget進(jìn)行解釋的作用,也是為了讓android系統(tǒng)知道這到底是個(gè)什么東西。(偷偷告訴你,一般這兩個(gè)要點(diǎn)是固定的表達(dá))
好了,萬(wàn)事具備,只欠”運(yùn)行“了,接下來(lái)就是程序運(yùn)行之后的界面。。上面的那一行文字就是程序運(yùn)行之后
就可以看到的結(jié)果,也就是我們”自制“的一個(gè)AppWidget了。(說(shuō)實(shí)話,真的是不太好看)。
回顧與總結(jié):
1、怎么實(shí)現(xiàn)的這個(gè)AppWidget?先是在res文件夾下創(chuàng)建一個(gè)xml 文件夾,并在里面添加一個(gè)appwidget-provider文件,再就是寫(xiě)一個(gè)用于呈現(xiàn)內(nèi)容的布局文件。接下來(lái)就是一個(gè)繼承自AppWidgetProvider的類的創(chuàng)建,然后再清單文件中進(jìn)行相關(guān)項(xiàng)的聲明就可以了。
2、邏輯思路很重要,每一步的銜接是思路的引導(dǎo)點(diǎn)。
3、這里僅僅是一個(gè)簡(jiǎn)單的小例子,接下來(lái)要做的就是如何讓這個(gè)widget和我們的系統(tǒng)進(jìn)行交互。
4、好了,大致就是這樣,歡迎廣大博友留言評(píng)論,我一定會(huì)虛心的接受,希望能和你們一起進(jìn)步!
—————————–這里是華麗的分界線——————
上面的是創(chuàng)建一個(gè)簡(jiǎn)單的appWidget的示例,下面是關(guān)于如何實(shí)現(xiàn)這些Widget如何實(shí)現(xiàn)相關(guān)的動(dòng)作偵聽(tīng)的。
知識(shí)點(diǎn)準(zhǔn)備:
我們應(yīng)該知道的是,android的widget的進(jìn)程與程序運(yùn)行的進(jìn)程并不是同一個(gè)進(jìn)程,這就意味著我們不能像往常一樣簡(jiǎn)單的使用一個(gè)setOnClickListener方法了,因?yàn)檫@樣做是完不成相關(guān)的動(dòng)作的偵聽(tīng)的功能的。那么問(wèn)題來(lái)了,我們要怎么實(shí)現(xiàn)這些動(dòng)作的交互呢?
別著急,答案是采用RemoteViews,顧名思義就是采用”遠(yuǎn)程的“方式來(lái)實(shí)現(xiàn)相關(guān)的處理操作。接下來(lái)讓我們一起來(lái)看一下具體的實(shí)現(xiàn)流程吧。--------------------------------------------------------------------------------
第一步:在之前的appWidget的布局文件中添加一個(gè)按鈕,用來(lái)實(shí)現(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這個(gè)AppWidgetProvider的實(shí)現(xiàn)類的onUpdate方法中實(shí)現(xiàn)相關(guān)的代碼。為了更好地展示效果,我們可以新建一個(gè)Activity,用來(lái)呈現(xiàn)點(diǎ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布局是一個(gè)非常簡(jiǎn)單的界面(一個(gè)TextView而已),所以不再貼出代碼 }
第三步:不要忘記在清單文件中進(jìn)行Activity的聲明,否則你是看不到界面的效果的。
<activity android:name="com.summer.widgettest.RenewActivity" android:label="Renew Activity!" > </activity>
效果圖如下所示:
小總結(jié):
在Widget的onUpdate方法中,我們使用到了RemoteViews類的實(shí)例,起作用就不再詳細(xì)的闡述,這里就直接解釋代碼的功能吧。如上,創(chuàng)建其實(shí)例的時(shí)候需要兩個(gè)參數(shù)分別為上下文對(duì)象的包名和widget的”布局“,然后在進(jìn)行對(duì)按鈕的時(shí)間偵聽(tīng)的時(shí)候使用到了一個(gè)叫pendingIntent的實(shí)例,其作用就是將遠(yuǎn)程的消息信息傳達(dá)給相應(yīng)的處理邏輯中,進(jìn)而實(shí)現(xiàn)對(duì)widget上按鈕的動(dòng)作的偵聽(tīng)處理。然后使用appWidgetManager進(jìn)行更新操作就可以了!如此便可以完成我們的代碼的邏輯。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Android控件AppWidgetProvider使用方法詳解
- Android編程之桌面小部件AppWidgetProvider用法示例
- Android之AppWidget(桌面小部件)開(kāi)發(fā)淺析
- Android UI組件AppWidget控件入門詳解
- Android學(xué)習(xí)之AppWidget高級(jí)效果
- Android開(kāi)發(fā)入門之Appwidget用法分析
- 講解Android中的Widget及AppWidget小工具的創(chuàng)建實(shí)例
- Android中的AppWidget入門教程
- Android開(kāi)發(fā)之AppWidget詳解
相關(guān)文章
Android RecyclerView實(shí)現(xiàn)數(shù)據(jù)列表展示效果
這篇文章主要為大家詳細(xì)介紹了Android RecyclerView實(shí)現(xiàn)數(shù)據(jù)列表展示效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-07-07Android WebView 常見(jiàn)問(wèn)題及處理方案
這篇文章主要介紹了Android WebView 常見(jiàn)問(wèn)題及處理方案,需要的朋友可以參考下2015-08-08Android使用NumberPicker實(shí)現(xiàn)滑輪日期選擇器
這篇文章主要為大家介紹了如何使用Android中的NumberPicker控件,以一種簡(jiǎn)單而直觀的方式實(shí)現(xiàn)滑輪式的日期選擇器,需要的小伙伴可以參考一下2023-06-06Android開(kāi)發(fā)系列二之窗口Activity的生命周期
這篇文章主要介紹了Android學(xué)習(xí)系列二之窗口Activity的生命周期的相關(guān)資料,需要的朋友可以參考下2016-05-05Android中ACTION_CANCEL的觸發(fā)機(jī)制與滑出子view的情況
這篇文章主要介紹了Android中ACTION_CANCEL的觸發(fā)機(jī)制與滑出子view的情況,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-09-09Android TV 焦點(diǎn)框移動(dòng)的實(shí)現(xiàn)方法
本篇文章主要介紹了Android TV 焦點(diǎn)框移動(dòng)的實(shí)現(xiàn)方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-06-06Flutter基本組件Basics?Widget學(xué)習(xí)
本文詳細(xì)講解了Flutter基本組件Basics?Widget,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-12-12