android之App Widget開發(fā)實例代碼解析
Android Widget開發(fā)案例實現(xiàn)是本文要介紹的內(nèi)容,主要是來了解并學(xué)習(xí)Android Widget開發(fā)應(yīng)用,今天我們要寫一下Android Widget的開發(fā),由于快點凌晨,我就不說的太具體了,同志們就模仿吧!
首先繼續(xù)了解下App Widget框架的主要的類:
AppWidgetProvider:繼承自BroadcastReceiver,在App Widget應(yīng)用update,enable,disable和deleted時接受通知。其中onUpdate,onReceive是最常用到的方法。
AppWidgetProviderInfo:描述AppWidget的大小,更新頻率和初始界面等信息,以xml文件的形式存在于應(yīng)用中的res/xml目錄下。
AppWidgetManager:負責(zé)管理AppWidget,向AppWidgetProvider發(fā)送通知。
RemoteViews:一個可以在其他應(yīng)用進程中運行的類,是構(gòu)造AppWidget的核心。
下面開始代碼的編寫,首先在res/xml下建立myappwidetprovider.xml
<?xml version="1.0" encoding="utf-8"?> <appwidget-provider xmlns:android="http://schemas.android.com/apk/res/android" android:minWidth="100dp" android:minHeight="72dp" android:updatePeriodMillis="86400000" android:initialLayout="@layout/myappwidget" > </appwidget-provider>
上面分別是 定義widget的寬度,高度,更新周期,以及l(fā)ayout的widget布局。
下面是我們的布局文件:
<?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:background="@drawable/widget_bg1"
android:gravity="center"
android:id="@+id/layout"
android:orientation="vertical" >
<TextView
android:id="@+id/txtMonth"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textColor="#000000"
android:layout_margin="2dp"
android:text="" />
<TextView
android:id="@+id/txtDay"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textColor="#990033"
android:textSize="25dp"
android:text="" />
<TextView
android:id="@+id/txtWeekDay"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_margin="2dp"
android:textColor="#000000"
android:text="" />
</LinearLayout>
對應(yīng)布局widget要求比較高,大家自行設(shè)計,更加美觀的界面。
接下來是我們的核心代碼ExampleAppWidgetProvider類了:
import android.app.PendingIntent;
import android.appwidget.AppWidgetManager;
import android.appwidget.AppWidgetProvider;
import android.content.Context;
import android.content.Intent;
import android.text.format.Time;
import android.widget.RemoteViews;
import android.widget.Toast;
public class ExampleAppWidgetProvider extends AppWidgetProvider{
private String[] months={"一月","二月","三月","四月","五月","六月","七月","八月","九月","十月","十一月","十二月"};
private String[] days={"星期日","星期一","星期二","星期三","星期四","星期五","星期六"};
@Override
public void onUpdate(Context context, AppWidgetManager appWidgetManager,
int[] appWidgetIds) {
// TODO Auto-generated method stub
RemoteViews remoteViews=new RemoteViews(context.getPackageName(), R.layout.myappwidget);
Time time=new Time();
time.setToNow();
String month=time.year+" "+months[time.month];
remoteViews.setTextViewText(R.id.txtDay, new Integer(time.monthDay).toString());
remoteViews.setTextViewText(R.id.txtMonth, month);
remoteViews.setTextViewText(R.id.txtWeekDay, days[time.weekDay]);
Intent intent=new Intent("cn.com.karl.widget.click");
PendingIntent pendingIntent=PendingIntent.getBroadcast(context, 0, intent, 0);
remoteViews.setOnClickPendingIntent(R.id.layout, pendingIntent);
appWidgetManager.updateAppWidget(appWidgetIds, remoteViews);
super.onUpdate(context, appWidgetManager, appWidgetIds);
}
@Override
public void onReceive(Context context, Intent intent) {
// TODO Auto-generated method stub
super.onReceive(context, intent);
if(intent.getAction().equals("cn.com.karl.widget.click")){
Toast.makeText(context, "點擊了widget日歷", 1).show();
}
}
}
上面代碼忘記做注釋了,在這類分別解釋下,使用remoteViews類分別加載上來布局文件的相應(yīng)ID設(shè)置好值,然PendingIntent 這就沒什么好解釋的了。
最后在manifest中加入:
<receiver android:name="ExampleAppWidgetProvider" >
<intent-filter >
<action android:name="android.appwidget.action.APPWIDGET_UPDATE" />
<action android:name="cn.com.karl.widget.click" >
</action>
</intent-filter>
<meta-data
android:name="android.appwidget.provider"
android:resource="@xml/myappwidetprovider" />
</receiver>
這樣就完成了,運行項目看一下載手機上運行的效果吧:

上面就是我們自己定義的AppWidget顯示效果,點擊它:
這里為了表示點擊了它,使用了Toast打印信息,當(dāng)然我們也可以點擊它之后啟動相應(yīng)的Activity。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Flutter利用ORM框架簡化本地數(shù)據(jù)庫管理詳解
使用?sqflite?相對來說還是有點復(fù)雜,比如遇到數(shù)據(jù)不兼容的時候需要手動轉(zhuǎn)換,增加了不少繁瑣的代碼。本篇我們就來介紹一個?ORM?框架,來簡化數(shù)據(jù)庫的管理,感興趣的可以了解一下2023-04-04
Android Flutter實現(xiàn)淘寶App的搜索推薦
這篇文章主要為大家詳細介紹了Android?Flutter如何模擬實現(xiàn)淘寶App的搜索推薦,文中的示例代碼講解詳細,具有一定的借鑒價值,感興趣的可以了解一下2023-07-07
Android編程滑動效果之Gallery仿圖像集瀏覽實現(xiàn)方法
這篇文章主要介紹了Android編程滑動效果之Gallery仿圖像集瀏覽實現(xiàn)方法,結(jié)合實例形式詳細分析了Gallery瀏覽圖片的原理、步驟與相關(guān)實現(xiàn)技巧,需要的朋友可以參考下2016-02-02
Android編程之繪制文本(FontMetrics)實現(xiàn)方法
這篇文章主要介紹了Android編程之繪制文本(FontMetrics)實現(xiàn)方法,結(jié)合實例形式較為詳細的分析了Android使用FontMetrics對象繪制文本的相關(guān)技巧,需要的朋友可以參考下2015-12-12
學(xué)習(xí)Android自定義Spinner適配器
這篇文章主要為大家詳細介紹了學(xué)習(xí)Android自定義Spinner適配器的相關(guān)資料,感興趣的小伙伴們可以參考一下2016-05-05
Android實戰(zhàn)打飛機游戲之菜單頁面設(shè)計(1)
這篇文章主要為大家詳細介紹了Android實戰(zhàn)打飛機游戲之菜單頁面設(shè)計,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-07-07
Android面向切面基于AOP實現(xiàn)登錄攔截的場景示例
這篇文章主要為大家介紹了Android面向切面基于AOP實現(xiàn)登錄攔截的場景示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-08-08
Android控件之SlidingDrawer(滑動式抽屜)詳解與實例分享
這篇文章詳細介紹了Android控件之SlidingDrawer(滑動式抽屜)與實例,有需要的朋友可以參考一下2013-10-10

