編輯:關於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 AlertDialog關系圖如下: Android主要提供四種對話框: 1:AlertDialog:功能最豐富,實際應用最廣的對話框。 2:P
四大組件之Activity(上)——Activity的生命周期、系統回收、系統配置改變的影響
第1節 Activity的使用Activity幾乎是每個應用必有的組件,所以任何安卓應用的開發幾乎都是從Activity開始的。比如,你希望設計一個計算器應用,要呈現這個
Android-支付寶快捷支付
支付寶的快捷支付Android版業務流程比較麻煩,出現的意外情況比較多.在此,簡單說下開發流程以及出現錯誤的解決方案; 1.注冊支付業務.這裡不在贅述.建立數據安全傳輸所
Android初始化的時候獲取加載的布局的寬高(續)--RelativeLayout的陷阱
接著上次的問題,已經介紹過,在初始化或者說OnCreate方法中獲取加載的布局的寬高,最後說到,調用view.measure(0, 0);然後在調用getMeasur