Android桌面組件App Widget完整案例
本文實(shí)例講述了Android桌面組件App Widget用法。分享給大家供大家參考。具體如下:
這里模擬一個(gè)案例:把AppWidget添加到桌面后,點(diǎn)擊AppWidget后AppWidget文本會(huì)輪回改變
main.xml布局文件:
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:layout_width="fill_parent" android:layout_height="fill_parent"> <TextView android:id="@+id/tv" android:layout_width="fill_parent" android:layout_height="wrap_content" android:text="程序入口" android:textSize="50dip"/> </LinearLayout>
res/xml/my_appwidget.xml布局文件:
<?xml version="1.0" encoding="utf-8"?> <appwidget-provider xmlns:android="http://schemas.android.com/apk/res/android" android:minWidth="120dp" android:minHeight="60dp" android:updatePeriodMillis="1000" android:initialLayout="@layout/main"> </appwidget-provider>
清單文件:
<?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.ljq.activity" android:versionCode="1" android:versionName="1.0"> <application android:icon="@drawable/icon" android:label="@string/app_name"> <receiver android:name=".TestActivity"> <meta-data android:name="android.appwidget.provider" android:resource="@xml/my_appwidget"> </meta-data> <intent-filter> <action android:name="COM.LJQ.ACTION.WIDGET.CLICK"></action> <action android:name="android.appwidget.action.APPWIDGET_UPDATE" /> </intent-filter> </receiver> </application> <uses-sdk android:minSdkVersion="7" /> </manifest>
變量類(lèi)UtilTool:用來(lái)控件文本改變:
package com.ljq.activity; public class UtilTool { public static boolean isChange=true; }
TestActivity類(lèi),繼承自AppWidgetProvider:
package com.ljq.activity; 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 TestActivity extends AppWidgetProvider { // 自定義一個(gè)Action名 private static final String ACTION_CLICK_NAME = "COM.LJQ.ACTION.WIDGET.CLICK"; private RemoteViews rv; @Override public void onUpdate(Context context, AppWidgetManager appWidgetManager, int[] appWidgetIds) { System.out.println("onUpdate"); //獲取R.layout.main布局,通過(guò)類(lèi)RemoteViews對(duì)布局R.layout.main里的控件進(jìn)行操作 /*rv = new RemoteViews(context.getPackageName(), R.layout.main); Intent intentClick = new Intent(ACTION_CLICK_NAME); PendingIntent pendingIntent = PendingIntent.getBroadcast(context, 0, intentClick, 0); rv.setOnClickPendingIntent(R.id.tv, pendingIntent); ComponentName cmp = new ComponentName(context, TestActivity.class); AppWidgetManager myAppWidgetManager = AppWidgetManager.getInstance(context); myAppWidgetManager.updateAppWidget(cmp, rv);*/ final int N = appWidgetIds.length; for (int i = 0; i < N; i++) { int appWidgetId = appWidgetIds[i]; updateAppWidget(context, appWidgetManager, appWidgetId); } } //AppWidget生命周期: 每接收一次,廣播執(zhí)行一次為一個(gè)生命周期結(jié)束。 //也就是說(shuō)在重寫(xiě)AppWidgetProvider類(lèi)里面聲明全局變量做狀態(tài)判斷, //每次狀態(tài)改變AppWidgetProvider再接收第二次廣播時(shí)即為你重新初始化也就是說(shuō)重新實(shí)例化了一次AppWidgetProvider。 //今天我因?yàn)樵诶锩娣帕艘粋€(gè)boolean值初始化為true,觀察調(diào)試看到每次進(jìn)入都為T(mén)RUE故你在設(shè)置桌面組件時(shí), //全局變量把它聲明在另外一個(gè)實(shí)體類(lèi)用來(lái)判斷是沒(méi)問(wèn)題的,切忌放在本類(lèi)。 @Override public void onReceive(Context context, Intent intent) { System.out.println("onReceive"); if (rv == null) { rv = new RemoteViews(context.getPackageName(), R.layout.main); } if (intent.getAction().equals(ACTION_CLICK_NAME)) { if (UtilTool.isChange) { rv.setTextViewText(R.id.tv, "abc"); } else { rv.setTextViewText(R.id.tv, "123"); } UtilTool.isChange = !UtilTool.isChange; AppWidgetManager appWidgetManger = AppWidgetManager.getInstance(context); int[] appIds = appWidgetManger.getAppWidgetIds(new ComponentName(context, TestActivity.class)); appWidgetManger.updateAppWidget(appIds, rv); }else{ super.onReceive(context, intent); } } private void updateAppWidget(Context context, AppWidgetManager appWidgeManger, int appWidgetId) { rv = new RemoteViews(context.getPackageName(), R.layout.main); Intent intentClick = new Intent(); intentClick.setAction(ACTION_CLICK_NAME); PendingIntent pendingIntent = PendingIntent.getBroadcast(context, 0, intentClick, 0); rv.setOnClickPendingIntent(R.id.tv, pendingIntent); appWidgeManger.updateAppWidget(appWidgetId, rv); } }
希望本文所述對(duì)大家的Android程序設(shè)計(jì)有所幫助。
- Android基于widget組件實(shí)現(xiàn)物體移動(dòng)/控件拖動(dòng)功能示例
- Android UI組件AppWidget控件入門(mén)詳解
- Android Widget 桌面組件開(kāi)發(fā)介紹
- Android桌面組件App Widget用法入門(mén)教程
- Android開(kāi)發(fā)之AppWidget詳解
- Android控件AppWidgetProvider使用方法詳解
- Android TabWidget底部顯示效果
- Android小掛件(APP Widgets)設(shè)計(jì)指導(dǎo)
- 在Android中創(chuàng)建widge組件的步驟
相關(guān)文章
Android ROM升級(jí)包的選項(xiàng)解釋
本文主要解釋 Android刷機(jī)過(guò)程中會(huì)遇到apply sdcard:update.zip(刷ROM升級(jí)包)的選項(xiàng),對(duì)選項(xiàng)解釋,以免造成沒(méi)必要的麻煩,希望對(duì)大家有用!2016-07-07Android實(shí)現(xiàn)QQ新用戶注冊(cè)界面遇到問(wèn)題及解決方法
這篇文章主要介紹了Android實(shí)現(xiàn)QQ新用戶注冊(cè)界面遇到問(wèn)題及解決方法,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-09-09Android開(kāi)發(fā)之媒體播放工具類(lèi)完整示例
這篇文章主要介紹了Android開(kāi)發(fā)之媒體播放工具類(lèi),結(jié)合完整實(shí)例形式分析了基于MediaPlayer的事件監(jiān)聽(tīng)與多媒體文件播放相關(guān)操作技巧,需要的朋友可以參考下2018-02-02Flutter本地存儲(chǔ)之基本的鍵值對(duì)存儲(chǔ)詳解
在原生的?Android?或?iOS?中,都提供了基本的鍵值對(duì)存儲(chǔ)方式,在?Flutter?中,提供了?shared_preferences?這個(gè)插件來(lái)實(shí)現(xiàn)本地鍵值對(duì)數(shù)據(jù)存儲(chǔ),本文就來(lái)和大家簡(jiǎn)單聊聊吧2023-03-03Android開(kāi)發(fā)新手常見(jiàn)的10個(gè)誤區(qū)
這篇文章主要介紹了Android開(kāi)發(fā)新手常見(jiàn)的10個(gè)誤區(qū),我們?nèi)匀豢吹搅四男┬碌腁ndr​​oid開(kāi)發(fā)人員不斷重復(fù)的錯(cuò)誤,這里有10個(gè)最常見(jiàn)的誤區(qū),需要的朋友可以參考下2015-03-03Android拍照保存在系統(tǒng)相冊(cè)不顯示的問(wèn)題解決方法
我們保存相冊(cè)到Android手機(jī)的時(shí)候,然后去打開(kāi)系統(tǒng)圖庫(kù)找不到我們想要的那張圖片,那是因?yàn)槲覀儾迦氲膱D片還沒(méi)有更新的緣故,下面與大家分享下此問(wèn)題的解決方法2013-06-06詳解Retrofit 動(dòng)態(tài)參數(shù)(非固定參數(shù)、非必須參數(shù))(Get、Post請(qǐng)求)
這篇文章主要介紹了詳解Retrofit 動(dòng)態(tài)參數(shù)(非固定參數(shù)、非必須參數(shù))(Get、Post請(qǐng)求),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-04-04