Android學(xué)習(xí)之AppWidget高級(jí)效果
接著AppWidget基礎(chǔ)學(xué)習(xí),今天是一個(gè)“進(jìn)階版”的小例子,用來(lái)檢驗(yàn)一下自己的學(xué)習(xí)效果。于是就做了一個(gè)擲骰子的Widget。
方便大家觀看,先截圖如下:
需要注意的是在drawable文件夾下有幾張圖片,我是在網(wǎng)上下載的別人的素材。
下面就開(kāi)始我們的學(xué)習(xí)之旅吧。
第一步:
是在res/目錄下創(chuàng)建一個(gè)名為xml的文件夾(其實(shí)名字是隨意的,不必拘泥與這一個(gè)名字),然后在里面創(chuàng)建一個(gè)appwidget_info.xml文件,其作用就是向系統(tǒng)進(jìn)行聲明。
<appwidget-provider xmlns:android="http://schemas.android.com/apk/res/android" android:minHeight="72dp" android:minWidth="294dp" android:updatePeriodMillis="86400000" android:initialLayout="@layout/app_widget_layout" > </appwidget-provider>
第二步:
對(duì)布局界面進(jìn)行設(shè)置,我的設(shè)置如下app_widget_layout.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" > <ImageView android:id="@+id/imageview_widget" android:layout_width="match_parent" android:layout_height="wrap_content" android:src="@drawable/ic_launcher" /> <Button android:id="@+id/button_widget" android:layout_width="match_parent" android:layout_height="wrap_content" android:gravity="center" android:text="搖一搖" android:textColor="#6663c6" /> </LinearLayout>
第三步:
創(chuàng)建一個(gè)支撐widget的類(lèi),用來(lái)完成接下來(lái)的邏輯的操作,如下面的WidgetProvider.java.
package com.summer.mywidget; 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.util.Log; import android.widget.RemoteViews; public class WidgetProvider extends AppWidgetProvider{ private static final String MY_UPDATE_ACTION="com.summer.APP_WIDGET_ACTION"; /* *隨機(jī)的獲得一張圖片的int值,為接下來(lái)的變換圖片打基礎(chǔ) */ private static int getRandomPicture(){ int[] pictureArray=new int[]{R.drawable.dice_1,R.drawable.dice_2,R.drawable.dice_3, R.drawable.dice_4,R.drawable.dice_5,R.drawable.dice_6}; int RandomNumber=(int) ((Math.random()*100)%6); return pictureArray[RandomNumber]; } /* *用于接收action,分支是區(qū)別于自定義ACTION和系統(tǒng)action的有效方式 */ @Override public void onReceive(Context context, Intent intent) { // TODO Auto-generated method stub String RESPONSEACTION=intent.getAction(); Log.i("Summer", "------------->>>>>>>>>>>>>>>>>>>>>>>>>>>>>"+RESPONSEACTION); if(MY_UPDATE_ACTION.equals(RESPONSEACTION)){ RemoteViews remoteViews=new RemoteViews(context.getPackageName(),R.layout.app_widget_layout); remoteViews.setImageViewResource(R.id.imageview_widget,getRandomPicture()); AppWidgetManager appWidgetManager=AppWidgetManager.getInstance(context); ComponentName componentName=new ComponentName(context,WidgetProvider.class); appWidgetManager.updateAppWidget(componentName, remoteViews); }else{ super.onReceive(context, intent); } } /* *用一個(gè)循環(huán)的方式是為了應(yīng)對(duì)桌面上添加了好幾個(gè)這樣的Widget的情形 */ @Override public void onUpdate(Context context, AppWidgetManager appWidgetManager, int[] appWidgetIds) { // TODO Auto-generated method stub for(int i=0;i<appWidgetIds.length;i++){ Intent intent=new Intent(); intent.setAction(MY_UPDATE_ACTION); PendingIntent pendingIntent=PendingIntent.getBroadcast(context, -1, intent, 0); RemoteViews remoteViews=new RemoteViews(context.getPackageName(),R.layout.app_widget_layout); remoteViews.setOnClickPendingIntent(R.id.button_widget,pendingIntent); appWidgetManager.updateAppWidget(appWidgetIds[i], remoteViews); } super.onUpdate(context, appWidgetManager, appWidgetIds); } @Override public void onDeleted(Context context, int[] appWidgetIds) { // TODO Auto-generated method stub super.onDeleted(context, appWidgetIds); System.out.println("my app widget ----------------------------->>>>>>>onDeleted"); } @Override public void onEnabled(Context context) { // TODO Auto-generated method stub System.out.println("my app widget ----------------------------->>>>>>>onEnabled"); super.onEnabled(context); } @Override public void onDisabled(Context context) { // TODO Auto-generated method stub System.out.println("my app widget ----------------------------->>>>>>>onDisabled"); super.onDisabled(context); } }
第四步:
在清單文件Manifest.xml文件中進(jìn)行相關(guān)項(xiàng)的聲明。詳如下:
<?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.summer.mywidget" 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.mywidget.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.mywidget.WidgetProvider"> <intent-filter > <action android:name="android.appwidget.action.APPWIDGET_UPDATE"/> </intent-filter> <intent-filter > <action android:name="com.summer.APP_WIDGET_ACTION"></action> </intent-filter> <meta-data android:name="android.appwidget.provider" android:resource="@xml/appwidget_info"> </meta-data> </receiver> </application> </manifest>
第五步:
大功告成,運(yùn)行一下代碼,然后手工的進(jìn)行app_Widget 的添加,然后你就可以擁有一款”骰子“咯。
總結(jié):
這個(gè)小程序雖說(shuō)是實(shí)現(xiàn)了,但是仍然不是比較復(fù)雜。需要對(duì)廣播消息等知識(shí)有一定的了解。
改進(jìn)方向:給每次的點(diǎn)擊事件完成時(shí)添加動(dòng)畫(huà)效果,以獲得更好地用戶(hù)體驗(yàn)。(需要借助于RemoteViews內(nèi)的相關(guān)的方法)。
代碼中不可避免的會(huì)出現(xiàn)一些錯(cuò)誤和不足之處,希望廣大博友看到后予以指出,希望能和你們一起進(jìn)步!
- Android控件AppWidgetProvider使用方法詳解
- Android編程之桌面小部件AppWidgetProvider用法示例
- Android之AppWidget(桌面小部件)開(kāi)發(fā)淺析
- Android UI組件AppWidget控件入門(mén)詳解
- Android學(xué)習(xí)之AppWidget筆記分享
- Android開(kāi)發(fā)入門(mén)之Appwidget用法分析
- 講解Android中的Widget及AppWidget小工具的創(chuàng)建實(shí)例
- Android中的AppWidget入門(mén)教程
- Android開(kāi)發(fā)之AppWidget詳解
相關(guān)文章
Android 7.0中新簽名對(duì)多渠道打包的影響詳解
這篇文章主要介紹了Android 7.0中新簽名對(duì)多渠道打包的影響,文中介紹的很詳細(xì),需要的朋友可以參考借鑒,下面來(lái)一起看看吧。2017-02-02Android 10 啟動(dòng)Init進(jìn)程解析
這篇文章主要為大家介紹了Android 10 啟動(dòng)Init進(jìn)程解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-10-10Android開(kāi)發(fā)筆記之:AsyncTask的應(yīng)用詳解
本篇文章是對(duì)Android中AsyncTask的應(yīng)用進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05Android實(shí)現(xiàn)氣泡布局/彈窗效果 氣泡尖角方向及偏移量可控
這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)氣泡布局/彈窗效果,可控制氣泡尖角方向及偏移量,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-08-08Android使用Retrofit2.0技術(shù)仿微信發(fā)說(shuō)說(shuō)
這篇文章主要為大家詳細(xì)介紹了Android使用Retrofit2.0技術(shù)仿微信發(fā)說(shuō)說(shuō),實(shí)現(xiàn)拍照,選圖庫(kù),多圖案上傳功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-01-01Android Jetpack Compose實(shí)現(xiàn)列表吸頂效果
安卓傳統(tǒng)的Recyclerview打造懸浮頭部StickyHeader的吸頂效果,十分麻煩,而在Compose中就簡(jiǎn)單多了。因此,本文將采用Jetpack Compose實(shí)現(xiàn)列表吸頂效果,需要的可以參考一下2022-02-02Android Widget 桌面組件開(kāi)發(fā)介紹
本篇文章主要介紹了Android中的 widget 桌面組件開(kāi)發(fā)教程,對(duì)AppWidget 框架以及AppWidgetManger類(lèi)進(jìn)行詳細(xì)講解,開(kāi)發(fā)Android widget 開(kāi)發(fā)的朋友可以參考下2016-07-07Android模仿To圈兒個(gè)人資料界面層疊淡入淡出顯示效果
這篇文章主要介紹了Android模仿To圈兒個(gè)人資料界面層疊淡入淡出顯示效果的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-07-07