Итак, у меня есть немного опыта в создании приложений для Android. Но теперь я хотел бы создать виджет для Android, который будет сидеть на главном экране и отображать кнопку, и когда кнопка нажата, она воспроизводит звук. Я изучал обучающие онлайн-игры о том, как настроить виджет Android, но я не могу понять, как это сделать. Есть ли хорошие учебники о том, как сделать отдельный виджет таким простым или где-нибудь, где я могу начать? Заранее спасибо, Питер
Как создать простой Android-виджет
Ответ 1
Сначала создайте новый файл макета внутри res/layout под структурой проекта, который определит макет виджета (widgetlayout.xml) в соответствии со следующей структурой.
<TextView android:text="@string/widgettext"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="0.8"
android:layout_gravity="center_vertical"
android:textColor="#000000"></TextView>
<TextView android:text="@string/widgetmoodtext"
android:id="@+id/widgetMood" android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="0.3"
android:layout_gravity="center_vertical"
android:textColor="#000000"></TextView>
<ImageButton android:id="@+id/widgetBtn"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="0.5"
android:src="@drawable/smile_icon"
android:layout_gravity="center_vertical">
</ImageButton>
Создайте папку res/xml в структуре проекта. Создайте файл XML (widgetproviderinfo.xml) со следующими параметрами:
<appwidget-provider
xmlns:android="http://schemas.android.com/apk/res/android"
android:minWidth="220dp"
android:minHeight="72dp"
android:updatePeriodMillis="86400000"
android:initialLayout="@layout/widgetlayout">
</appwidget-provider>
Теперь вы должны создать сервис, который реагирует на взаимодействие с пользователем с помощью кнопки с изображением смайлика (CurrentMoodService.java).
@Override
public int onStartCommand(Intent intent, int flags, int startId) {
super.onStart(intent, startId);
updateMood(intent);
stopSelf(startId);
return START_STICKY;
}
private void updateMood(Intent intent) {
if (intent != null){
String requestedAction = intent.getAction();
if (requestedAction != null && requestedAction.equals(UPDATEMOOD)){
this.currentMood = getRandomMood();
int widgetId = intent.getIntExtra(AppWidgetManager.EXTRA_APPWIDGET_ID, 0);
AppWidgetManager appWidgetMan = AppWidgetManager.getInstance(this);
RemoteViews views = new RemoteViews(this.getPackageName(),R.layout.widgetlayout);
views.setTextViewText(R.id.widgetMood, currentMood);
appWidgetMan.updateAppWidget(widgetId, views);
}
}
}
После определения службы настало время реализовать класс поставщика виджетов (CurrentMoodWidgetProvider.java).
@Override
public void onUpdate(Context context, AppWidgetManager appWidgetManager,
int[] appWidgetIds) {
super.onUpdate(context, appWidgetManager, appWidgetIds);
for (int i=0; i<appWidgetIds.length; i++) {
int appWidgetId = appWidgetIds[i];
RemoteViews views = new RemoteViews(context.getPackageName(), R.layout.widgetlayout);
Intent intent = new Intent(context, CurrentMoodService.class);
intent.setAction(CurrentMoodService.UPDATEMOOD);
intent.putExtra(AppWidgetManager.EXTRA_APPWIDGET_ID, appWidgetId);
PendingIntent pendingIntent = PendingIntent.getService(context, 0, intent, 0);
views.setOnClickPendingIntent(R.id.widgetBtn, pendingIntent);
appWidgetManager.updateAppWidget(appWidgetId, views);
}
}
Наконец, необходимо объявить службу и AppWidgetProvider
в манифесте (AndroidManifest.xml).
<service android:name=".CurrentMoodService">
</service>
<receiver android:name=".CurrentMoodWidgetProvider">
<intent-filter>
<action android:name="android.appwidget.action.APPWIDGET_UPDATE" />
</intent-filter>
<meta-data android:name="android.appwidget.provider"
android:resource="@xml/widgetproviderinfo" />
</receiver>
и если вы хотите скачать весь исходный код, посмотрите URL ниже...
http://sites.google.com/site/androidsourcecode/src/CurrentMoodWidgetProject.rar?attredirects=0