編輯:關於Android編程
安卓開發中很多控件都是Widget類的,但是我們常說的Widget指的是AppWidget,即一些可以放置在桌面的小部件。
下面用兩個實例來說一下這個AppWidget怎麼來用。
實例一:AppWidget的基本使用
①創建一個AppWidget的布局文件appwidget_layout.xml
②在res文件夾下新建一個xml文件夾,然後在裡面添加一個xml文件appwidgetprovider_info.xml
//刷新時間③新建一個類繼承AppWidgetProvider,重寫幾個重要的方法
package com.example.d_appwidget; import android.appwidget.AppWidgetManager; import android.appwidget.AppWidgetProvider; import android.content.Context; import android.content.Intent; public class AppWidget extends AppWidgetProvider { @Override public void onEnabled(Context context) { //首次添加AppWidget // TODO Auto-generated method stub super.onEnabled(context); System.out.println("---> onEnabled"); } @Override public void onUpdate(Context context, AppWidgetManager appWidgetManager, //更新AppWidget int[] appWidgetIds) { // TODO Auto-generated method stub super.onUpdate(context, appWidgetManager, appWidgetIds); System.out.println("---> onUpdate"); } @Override public void onDeleted(Context context, int[] appWidgetIds) { //刪除AppWidget // TODO Auto-generated method stub super.onDeleted(context, appWidgetIds); System.out.println("---> onDeleted"); } @Override public void onDisabled(Context context) { //刪除所有AppWidget // TODO Auto-generated method stub super.onDisabled(context); System.out.println("---> onDisabled"); } @Override public void onReceive(Context context, Intent intent) { //接收到廣播,比較重要的方法 // TODO Auto-generated method stub super.onReceive(context, intent); System.out.println("---> onReceive"); } }④在AndoridManifest文件中注冊receiver,在application節點中添加
結果:運行後可以看到窗口小部件中我們自定義的部件
執行添加刪除操作,我的理解是:執行不同操作時系統發出不同的廣播,然後執行相應的方法,執行完之後系統再次發出特定廣播。
<喎?/kf/ware/vc/" target="_blank" class="keylink">vcD4KPHA+yrXA/bb+o7rU2tfAw+bJz8C0vfjQ0MrWtefNsrLZ1/ejrLrctuDK1rXnzbK2vNDo0qrPyLTyv6pBcHDIu7rz1NnIpb+qtca52LXGo6zV4tPQtePC6bezo6zL+dLU0afBy9XiuPZBcHBXaWRnZXTWrrrzztK+zdC0uPbV4rj2oaPQ6NKqy7XD97XEysejrLPM0PKxvsntus20sL/a0KGyv7z+yvTT2sG9uPa9+LPMIKOsttS/2Lz+tcTKudPDus3U2rPM0PKxvsntyrnTw8rHsrvNrLXEo6zV4tKyysfX7rjDudjXorXE0ru146Os0rK+zcrHuvPD5tC0tb21xFBlbmRpbmdJbnRlbnS6zVJlbW90ZVZpZXdzwb249sDgoaPHsMPmtcSyvdbous3KtcD90ru089bCz+DNrKOs1vfSqrK7zazKx9TavMyz0MDg1tDW2NC0tcS3vbeooaM8L3A+CjxwPqLZ0MK9qNK7uPayvL7WzsS8/mFwcHdpZGdldF9sYXlvdXQueG1sPC9wPgo8cD48L3A+CjxwcmUgY2xhc3M9"brush:java;">
③新建一個類繼承AppWidgetProvider,重寫幾個重要的方法
package com.example.e_appwidget_flashlight; 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.hardware.Camera; import android.hardware.Camera.Parameters; import android.widget.RemoteViews; public class AppWidget extends AppWidgetProvider { private static final String ACTION_TAG = "leelit.action.flash"; //待發出的廣播 private static boolean flashOn = false; private static Camera camera; private static Camera.Parameters parameters; @Override public void onUpdate(Context context, AppWidgetManager appWidgetManager, int[] appWidgetIds) { // TODO Auto-generated method stub super.onUpdate(context, appWidgetManager, appWidgetIds); System.out.println("---> onUpdate"); Intent intent = new Intent(ACTION_TAG); PendingIntent pendingIntent = PendingIntent.getBroadcast(context, 0, //一定條件下才會觸發的意圖,這個意圖是發出 intent, 0); //廣播 RemoteViews remoteViews = new RemoteViews(context.getPackageName(), //獲得AppWidget的所有控件對象 R.layout.appwidget_layout); remoteViews.setOnClickPendingIntent(R.id.button, pendingIntent); //此處就能點擊觸發上面意圖,綁定為button控件 appWidgetManager.updateAppWidget(appWidgetIds, remoteViews); //執行update,第一個參數代表部件ID,通常都是一個 } @Override public void onReceive(Context context, Intent intent) { // TODO Auto-generated method stub super.onReceive(context, intent); if (intent.getAction().equals(ACTION_TAG)) { //點擊後會發出一個廣播,此處就可接收 RemoteViews remoteViews = new RemoteViews(context.getPackageName(), R.layout.appwidget_layout); //因為要操作AppWidget控件,所以要再次獲取 //remoteviews和執行相應的步驟 AppWidgetManager appWidgetManager = AppWidgetManager .getInstance(context); ComponentName provider = new ComponentName(context, AppWidget.class); flashOn = !flashOn; //打開或關閉電筒 if (flashOn) { turnOnLight(); remoteViews.setTextViewText(R.id.button, "電筒-關"); //改變控件狀態 appWidgetManager.updateAppWidget(provider, remoteViews); } else { turnOffLight(); remoteViews.setTextViewText(R.id.button, "電筒-開"); appWidgetManager.updateAppWidget(provider, remoteViews); } } } private void turnOnLight() { camera = Camera.open(); parameters = camera.getParameters(); parameters.setFlashMode(Parameters.FLASH_MODE_TORCH); camera.setParameters(parameters); camera.release(); //此處必須釋放資源,否則後面關不了手電筒,因為相機資源一直在被占據著 } private void turnOffLight() { camera = Camera.open(); parameters = camera.getParameters(); parameters.setFlashMode(Parameters.FLASH_MODE_OFF); camera.setParameters(parameters); camera.release(); } }
④在AndoridManifest文件中注冊receiver,在application節點中添加。添加相應權限。
結果:桌面添加一個部件,點擊操作就可以打開或關閉手電筒了。
還有其他的一些細節就見上傳的Demo吧
AppWidget_FlashLight.rar
小結:四個步驟:①部件布局,②加載布局的xml文件,③繼承AppWidgetProvider類,重寫方法,④配置AndoridManifest文件
Android AlertDialog關系圖如下: Android主要提供四種對話框: 1:AlertDialog:功能最豐富,實際應用最廣的對話框。 2:P
第1節 Activity的使用Activity幾乎是每個應用必有的組件,所以任何安卓應用的開發幾乎都是從Activity開始的。比如,你希望設計一個計算器應用,要呈現這個
支付寶的快捷支付Android版業務流程比較麻煩,出現的意外情況比較多.在此,簡單說下開發流程以及出現錯誤的解決方案; 1.注冊支付業務.這裡不在贅述.建立數據安全傳輸所
接著上次的問題,已經介紹過,在初始化或者說OnCreate方法中獲取加載的布局的寬高,最後說到,調用view.measure(0, 0);然後在調用getMeasur