BoradcastReceiver Уведомление ссылка на мое приложение - PullRequest
0 голосов
/ 07 октября 2019

Я пытаюсь создать службу, которая каждые x минут проверяет наличие новых сообщений на сервере.

Я был счастлив найти это сообщение: Пример диспетчера аварийных сигналов

MainActivity

package com.example.alarmexample;  

import android.app.Activity;  
import android.app.AlarmManager;  
import android.app.PendingIntent;  
import android.content.Intent;  
import android.os.Bundle;  
import android.view.View;  
import android.view.View.OnClickListener;  
import android.widget.Button;  
import android.widget.EditText;  
import android.widget.Toast;  

public class MainActivity extends Activity {  
Button b1;  

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

        startAlert();  

}   public void startAlert() { 
        int timeInSec = 2;

        Intent intent = new Intent(this, MyBroadcastReceiver.class);  
        PendingIntent pendingIntent = PendingIntent.getBroadcast(  
                                      this.getApplicationContext(), 234, intent, 0);  
        AlarmManager alarmManager = (AlarmManager) getSystemService(ALARM_SERVICE);  
        alarmManager.set(AlarmManager.RTC_WAKEUP, System.currentTimeMillis() + (timeInSec * 1000), pendingIntent);  
        Toast.makeText(this, "Alarm set to after " + i + " seconds",Toast.LENGTH_LONG).show();  
    }  

}

MyBroadcastReceiver.java

import android.content.BroadcastReceiver;  
import android.content.Context;  
import android.content.Intent;  
import android.media.MediaPlayer;  
import android.widget.Toast;  

public class MyBroadcastReceiver extends BroadcastReceiver {  
    MediaPlayer mp;  
    @Override  
    public void onReceive(Context context, Intent intent) {  
        mp=MediaPlayer.create(context, R.raw.alarm);  
        mp.start();  
        Toast.makeText(context, "Alarm", Toast.LENGTH_LONG).show();  
    }  
}  

AndroidManifest.xml

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

    <uses-permission android:name="android.permission.VIBRATE" />  


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

        <activity  
            android:name="com.example.alarmexample.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>  

        <receiver android:name="MyBroadcastReceiver" >  
        </receiver>  
    </application>  

</manifest>  

Это именно то, что я хочу. Но если я попытаюсь использовать Контекст из BroadcastReceiver-класса, чтобы уведомить пользователя. Приложение не запускается, когда пользователь нажимает на уведомление.

Есть ли что-то особенное, что я должен сделать, чтобы заархивировать это?

Ответы [ 2 ]

1 голос
/ 07 октября 2019

Это не прямой ответ на ваш вопрос (нельзя комментировать, потому что репутации недостаточно), но вам действительно нужно проверять сервер каждые x минут на событие? Я ничего не знаю о вашем проекте, но Firebase https://firebase.google.com/docs/cloud-messaging/, вероятно, будет хорошей альтернативой. Он позволяет отправлять push-уведомления вашему клиенту, чтобы клиенту не приходилось постоянно опрашивать.

0 голосов
/ 08 октября 2019

Откройте приложение после нажатия на Уведомление

Вот ответ - я искал не ту сторону от этой проблемы.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...