如何构建一个简单的Android小部件

Pet*_*ter 28 android widget

所以我有一些构建Android应用程序的经验.但是现在我想构建一个用于Android的小部件,它将位于主屏幕上并显示一个按钮,当按下该按钮时它会播放声音.我一直在网上看有关如何设置Android小部件的教程,但我似乎无法弄明白.有没有关于如何制作独立小部件的好教程,这个简单或我可以从哪里开始?彼得,先谢谢你

Aka*_*kar 44

首先在项目结构下的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>
Run Code Online (Sandbox Code Playgroud)

在项目结构下创建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>
Run Code Online (Sandbox Code Playgroud)

现在,您应该创建响应用户与笑脸图像按钮(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);  
        }
       }
   }
Run Code Online (Sandbox Code Playgroud)

在定义服务之后,是时候实现widget提供程序类(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);
    }
}   
Run Code Online (Sandbox Code Playgroud)

最后,有必要在Manifest(AndroidManifest.xml)中声明Service和App Widget Provider.

    <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>
Run Code Online (Sandbox Code Playgroud)

如果你想下载整个源代码,那么看看下面的网址...

http://sites.google.com/site/androidsourcecode/src/CurrentMoodWidgetProject.rar?attredirects=0