Android小部件是否需要默认活动才能启动?

时间:2013-05-31 22:10:37

标签: android android-widget

我搜索了很多这个问题并尝试了互联网上提到的所有内容,但仍无法找到解决方案。我的小部件已安装,但在点击时不会更新。我还没有为它创建默认活动。 我的问题是我点击按钮的动作没有改变。

这是我的代码: // Android清单

<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.android.pictureapp"
    android:versionCode="1"
    android:versionName="1.0" >

    <uses-sdk
        android:minSdkVersion="7"
        android:targetSdkVersion="17" />

    <application
        android:allowBackup="true"
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >
        <receiver android:name=".MyWidgetProvider" >
            <intent-filter>
                <action android:name="android.appwidget.action.APPWIDGET_UPDATE" />
            </intent-filter>

            <meta-data
                android:name="android.appwidget.provider"
                android:resource="@xml/widget_info" />
        </receiver>
        <receiver
            android:name="MyWidgetIntentReceiver"
            android:exported="false" >
            <intent-filter>
                <action android:name="com.example.android.intent.action.CHANGE_PICTURE" />
            </intent-filter>

            <meta-data
                android:name="android.appwidget.provider"
                android:resource="@xml/widget_info" />
        </receiver>
    </application>

</manifest>

// MyWidgetProvider.java-此类包含onUpdate方法并具有侦听器。

package com.example.android.pictureapp;

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.util.Log;
import android.widget.RemoteViews;

import com.example.android.pictureapp.R;

public class MyWidgetProvider extends AppWidgetProvider {


    @Override
    public void onUpdate(Context context, AppWidgetManager appWidgetManager,int[] appWidgetIds){

        //Log.i("Tag","In onUpdate method");
        System.out.println("Tag In onUpdate method");
        RemoteViews views=new RemoteViews(context.getPackageName(),R.layout.widget_layout);
        views.setOnClickPendingIntent(R.id.widget_button, buildButtonPendingIntent(context));
        Log.i("Tag","Context value after setOnClickPI before pushWIDGET:"+context);

        pushWidgetUpdate(context,views);
        Log.i("Tag","after pushwidget update:"+context);
    }

    public static PendingIntent buildButtonPendingIntent(Context context){

        Intent intent=new Intent();
        intent.setAction("com.example.android.intent.action.CHANGE_PICTURE");

        Log.i("Tag","intent's action:"+intent);
        return PendingIntent.getBroadcast(context, 0, intent, PendingIntent.FLAG_UPDATE_CURRENT);
    }

    public static void pushWidgetUpdate(Context context,RemoteViews views){

        System.out.println("Inside pushwidget");
        ComponentName myWidget=new ComponentName(context, MyWidgetProvider.class);
        AppWidgetManager manager=AppWidgetManager.getInstance(context);
        manager.updateAppWidget(myWidget, views);
    }
}

// MywidgetIntentReceiver.java - 此类包含onReceive方法并执行单击后要执行的功能。

package com.example.android.pictureapp;

import com.example.android.pictureapp.R;

import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.util.Log;
import android.widget.RemoteViews;

public class MyWidgetIntentReceiver extends BroadcastReceiver {

    private static int clickCount = 0;

    @Override
    public void onReceive(Context context, Intent intent) {

        // Log.i("Tag1","In onReceive:"+intent);
        System.out.println("In onReceive()");

        if (intent.getAction().equals(
                "com.example.android.intent.action.CHANGE_PICTURE")) {
            updateWidgetPictureAndButtonListener(context);
        }
    }

    private void updateWidgetPictureAndButtonListener(Context context) {

        RemoteViews views = new RemoteViews(context.getPackageName(),
                R.layout.widget_layout);
        views.setImageViewResource(R.id.widget_image, getImageToSet());

        System.out.println("in updateWidgetPicture method");
        // Log.i("Tag","in updaeWIdgetPicture method");
        // remember to set ur button click listeners
        views.setOnClickPendingIntent(R.id.widget_button,
                MyWidgetProvider.buildButtonPendingIntent(context));

        MyWidgetProvider.pushWidgetUpdate(context.getApplicationContext(),
                views);
    }

    private int getImageToSet() {
        clickCount++;
        Log.i("Tag", "in getImageToSet()" + clickCount);

        return clickCount % 2 == 0 ? R.drawable.paypal_logo : R.drawable.paypaldonation;
    }
}

//布局/ widget_layout.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:orientation="vertical" 
    android:layout_margin="5sp"
    >

    <ImageView 
        android:id="@+id/widget_image"
        android:layout_width="110dp"
        android:layout_height="110dp"
        android:layout_gravity="center"
        android:src="@drawable/paypal_logo"
        />

    <Button 
        android:id="@+id/widget_button"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="center"
        android:text="Change it"
        />

</LinearLayout>

// XML / widget_info.xml

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


</appwidget-provider>

// MainACtivity

package com.example.android.pictureapp;

import com.example.android.pictureapp.R;

import android.app.Activity;
import android.os.Bundle;
import android.view.Menu;

public class MainActivity extends Activity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        //setContentView(R.layout.activity_main);
    }

    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        // Inflate the menu; this adds items to the action bar if it is present.
        //getMenuInflater().inflate(R.menu.main, menu);
        return true;
    }

}

这些是清单的变化:

<activity
            android:name="com.example.android.pictureapp.MainActivity"
            android:label="@string/app_name" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>

1 个答案:

答案 0 :(得分:1)

启动Android 3.1,您的应用必须至少有一个用户可以在接收任何广播之前启动的活动等。

由于您没有活动,因此系统可能认为您的应用处于停止状态,因此可能无法接收您的窗口小部件的广播。尝试添加活动。