講解Android中的Widget及AppWidget小工具的建立執行個體_Android

來源:互聯網
上載者:User

1.Widget 、App Widget 、Web App 的概念

Widget最初的概念是98年一個叫Rose的蘋果工程師提出,直到2003年的時候才正式為大家所知,不過隨後無數大公司都開始接受並應用這一思路。 現在我們看到在蘋果系統裡按下F4彈出的Dashboard裡的小工具叫Widget,在Windows 7裡側邊欄上的那些漂亮的小工具叫Gadget(widget變體?),除此以外還有yahoo Widget等等Widget產品。他們有一個共同的特點就是採用前台Web開發用的技術(譬如HTML、CSS、Javascript)來製作的小工 具、小組件。

在Android系統裡,幾乎每個可視化的View組件都叫Widget,起這個名字可能當時是為了趕時髦。

App Widget是從Android 1.5以後才有的東東,就是可以放在Android案頭上的應用程式小工具。這一點上看他的功能很像windows的側邊欄小工具,可惜的是他的採用技術 並不是HTML等技術。當然App Widget才是我們本講的主角,本來他應該順理成章叫做Widget的,至少也要叫做Gadget吧,可惜這個名字已經被他自己的系統佔用了,所以只好 改名叫App Widget。

最後講一下Web App 或者說是Android Web Application,也許叫mobile web application 更準確些。我們發現現在智能機系統平台很多,譬如iOS、Android、Windows Phone 、WebOS、BlackBerry等等,它們採用的技術架構也各不相同,有沒有辦法寫一個程式在各個系統上都能運行呢?答案是肯定的,寫基於 Webkit的瀏覽器的應用即可。我們使用 HTML5、CSS3、JavaScript、WebKit 等技術來寫的Web Application也許是今後的一個大潮流也說不準啊。有機會我們再講講Android Web Application 的開發。

2.建立一個最簡單的Widget

代碼案例:

1)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/tvCurrTime" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="@string/hello"     android:textColor="@color/black"/> </LinearLayout> 

2)hello_widget_provider.xml

<?xml version="1.0" encoding="utf-8"?> <appwidget-provider xmlns:android="http://schemas.android.com/apk/res/android"   android:minWidth="146dip" android:minHeight="72dip" android:initialLayout="@layout/main"> </appwidget-provider> 

3)AndroidManifest.xml

<?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.woody.testWidget" android:versionCode="1"    android:versionName="1.0">   <application android:icon="@drawable/icon" android:label="@string/app_name">      <receiver android:name=".HelloWidgetProvider" android:label="@string/app_name"> <!-- HelloWidgetProvider為那個class(業務處理) -->       <intent-filter>         <action android:name="android.appwidget.action.APPWIDGET_UPDATE" /> <!-- 指定了的 -->       </intent-filter>       <meta-data android:name="android.appwidget.provider"android:resource="@xml/hello_widget_provider" /> <!-- 為上面指定了的widget -->     </receiver>   </application> </manifest> 

4)HelloWidgetProvider.java

public class HelloWidgetProvider extends AppWidgetProvider {   /** Called when the activity is first created. */   @Override   public void onUpdate(Context context, AppWidgetManager appWidgetManager, int[] appWidgetIds) {     Timer timer = new Timer();     timer.scheduleAtFixedRate(new MyTime(context, appWidgetManager), 1, 1000);   }   public class MyTime extends TimerTask {     RemoteViews remoteViews;     AppWidgetManager appWidgetManager;     ComponentName thisWidget;     DateFormat format = SimpleDateFormat.getTimeInstance(SimpleDateFormat.MEDIUM, Locale.getDefault());       public MyTime(Context context, AppWidgetManager appWidgetManager) {       this.appWidgetManager = appWidgetManager;       remoteViews = new RemoteViews(context.getPackageName(), R.layout.main);       thisWidget = new ComponentName(context, HelloWidgetProvider.class);     }     @Override     public void run() {       remoteViews.setTextViewText(R.id.tvCurrTime, "Time = " + format.format(new Date()));       appWidgetManager.updateAppWidget(thisWidget, remoteViews);     }   } }  

代碼解釋:RemoteView是用來描述一個跨進程顯示的view,也就是說這個view是在另外一個進程顯示的。它inflate於layout資源檔。並且提供了可以修改過view內容的一些簡單基礎的操作。

AppWidget---RemoteView,AppWidgetProvider是一個BrocaseReceiver,只是接受到Enable, Update,disale,delete這些message,而真正顯示介面的是AppWidgetHostView(這是在Launcher裡面實現的),這中間就是通過RemoteView來溝通。通過RemoteView告訴Launcher你想要的AppWidget是長什麼樣。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.