BroadcastReceiver не срабатывает при щелчке уведомления

Я пытаюсь создать простое уведомление с определенной для него кнопкой (действием). Мне удалось отобразить его правильно и создать PendingIntent для моего действия. Я также создал BroadcastReceiver, который должен вызываться при нажатии на мое действие. Но метод onReceive() не вызывается. Понятия не имею почему. Я также зарегистрировал BroadcastReceiver в AndroidManifest.xml.

MainActivity.java

public class MainActivity extends AppCompatActivity {

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

    Button notify = (Button) findViewById(R.id.notify);

    notify.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View view) {

            Intent dismissIntent = new Intent("action1");
            dismissIntent.setAction("action1");
            PendingIntent action1intent = PendingIntent.getBroadcast(MainActivity.this, (int) System.currentTimeMillis(), dismissIntent, PendingIntent.FLAG_CANCEL_CURRENT);

            NotificationCompat.Builder mBuilder =
                    new NotificationCompat.Builder(MainActivity.this)
                            .setSmallIcon(R.drawable.ic_menu)
                            .setContentTitle("My notification")
                            .setContentText("Hello World!")
                            .addAction(R.drawable.ic_menu, "action 1", action1intent);

            Intent resultIntent = new Intent(MainActivity.this, MainActivity.class);
            TaskStackBuilder stackBuilder = TaskStackBuilder.create(MainActivity.this);
            stackBuilder.addParentStack(MainActivity.class);
            stackBuilder.addNextIntent(resultIntent);

            PendingIntent resultPendingIntent = stackBuilder.getPendingIntent(0, PendingIntent.FLAG_UPDATE_CURRENT);

            mBuilder.setContentIntent(resultPendingIntent);
            NotificationManager mNotificationManager =
                    (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);

            mNotificationManager.notify(0, mBuilder.build());
        }
    });

}

public class Receiver extends BroadcastReceiver {

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

        Log.d("log", "Receiving somthn");

        String whichAction = intent.getAction();

        if (whichAction.equals("action1")) {
            MainActivity.makeToast("This is action 1", context);
        }
    }
}


public static void makeToast(String string, Context context) {
    Toast.makeText(context, string, Toast.LENGTH_SHORT).show();
}
}

AndroidManifest.xml

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.orglce.notification">

<application
    android:allowBackup="true"
    android:icon="@mipmap/ic_launcher"
    android:label="@string/app_name"
    android:supportsRtl="true"
    android:theme="@style/AppTheme">

    <receiver android:name=".MainActivity$Receiver">
        <intent-filter>
            <action android:name="com.example.orglce.notification.BROADCAST" />
        </intent-filter>
    </receiver>

    <activity android:name=".MainActivity">
        <intent-filter>
            <action android:name="android.intent.action.MAIN" />
            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
    </activity>
</application>




Ответы (1)


Во-первых, если вы собираетесь использовать .MainActivity$Receiver, то Receiver должен быть классом static.

Во-вторых, dismissIntent (избыточно) использует action1 в качестве строки действия, но <intent-filter> использует com.example.orglce.notification.BROADCAST. Эти не совпадают. Я рекомендую избавиться от <intent-filter>, избавиться от action1 и использовать new Intent(this, Receiver.class) для создания явного Intent для идентификации вашего BroadcastReceiver.

person CommonsWare    schedule 12.08.2016
comment
Да, это сработало! Изменение на new Intent(this, Receiver.class). Раньше у меня уже был new Intent(this, MainActivity.class), но он не работал, мне просто не приходило в голову, что я должен связать намерение с Receiver.class, а не с MainActivity.class. Большое спасибо! :) - person orglce; 12.08.2016
comment
Ткс! Обратите внимание, что в Kotlin вложенный класс по умолчанию является статическим, поэтому он будет работать как есть. - person Andy Weinstein; 06.01.2020