1

こんにちは私はAndroidでニュースアプリケーションを構築しているので、データベースに新しいデータが入力されるたびに、ユーザーは通知バーで通知を受け取る必要があります。調査の結果、放送受信機とアラームマネージャーを使用する必要があることがわかりました。しかし、私が理解できないのは、アプリケーションが閉じられたときに、新しいデータが入力されたことをどのように知るのかということです。そして、アラームマネージャに新しいデータをチェックするためのアプリケーションをアクティブにする方法を教えてください。たとえば5分ごとに?ありがとうございました。

4

2 に答える 2

2

このプロジェクトでは、AlarmManagerを使用して時刻を設定した後、10000秒ごとに通知を表示できます。

AlarmActivityActivity.java:

package co.in.technoguys.AlarmActivity;

import java.util.Calendar;

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.widget.DatePicker;
import android.widget.TimePicker;
import android.widget.Toast;

public class AlarmActivityActivity extends Activity {
    int notifyID=1;

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);

    }
    public void startAlert(View view) {
        TimePicker tp=(TimePicker)findViewById(R.id.timePicker1);
        DatePicker dp=(DatePicker)findViewById(R.id.datePicker1);
        Calendar Cal = Calendar.getInstance();
        Cal.set(Calendar.YEAR, dp.getYear());  
        Cal.set(Calendar.MONTH, dp.getMonth());         
        Cal.set(Calendar.DAY_OF_MONTH, dp.getDayOfMonth());         
        Cal.set(Calendar.HOUR_OF_DAY, tp.getCurrentHour());            
        Cal.set(Calendar.MINUTE, tp.getCurrentMinute());                
        Cal.set(Calendar.SECOND, 00);
        long when=Cal.getTimeInMillis();
        Intent intent = new Intent(this, MyBroadcastReceiver.class);
        PendingIntent pendingIntent = PendingIntent.getBroadcast(this.getApplicationContext(), 234324243, intent, 0);
        AlarmManager alarmManager = (AlarmManager) getSystemService(ALARM_SERVICE);
        alarmManager.setRepeating(AlarmManager.RTC_WAKEUP,when,20000,pendingIntent);
        Toast.makeText(this, "Notification Triggered on"+tp.getCurrentHour()+":"+tp.getCurrentMinute(),
                Toast.LENGTH_LONG).show();

              }
}

MyBroadcastReceiver.java:

package co.in.technoguys.AlarmActivity;

import android.app.Notification;
import android.app.NotificationManager;
import android.app.PendingIntent;
import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;

public class MyBroadcastReceiver extends BroadcastReceiver {
    int notifyID=1;

  @Override
  public void onReceive(Context context, Intent intent) {
    Intent i=new Intent();
    PendingIntent pi=PendingIntent.getBroadcast(context,0,i,0);
    NotificationManager nm=(NotificationManager)context.getSystemService(Context.NOTIFICATION_SERVICE);
    Notification notify=new Notification(R.drawable.ic_launcher,"Notification Triggered",System.currentTimeMillis());
    CharSequence from="Remainder";
    CharSequence message="Meeting Starts at 9 A.M";
    notify.setLatestEventInfo(context, from, message, pi);
    nm.notify(notifyID,notify);
  }

} 

main.xml:

        <TimePicker
            android:id="@+id/timePicker1"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_centerHorizontal="true"
            android:layout_centerVertical="true" />

        <DatePicker
            android:id="@+id/datePicker1"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_above="@+id/timePicker1"
            android:layout_alignLeft="@+id/timePicker1"
            android:layout_marginBottom="27dp" />

        <Button
            android:id="@+id/startAlert"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_alignLeft="@+id/timePicker1"
            android:layout_below="@+id/timePicker1"
            android:layout_marginTop="36dp"
            android:onClick="startAlert"
            android:text="@string/count" />

    </RelativeLayout>

AndroidManifest.xml:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="co.in.technoguys.AlarmActivity"
    android:versionCode="1"
    android:versionName="1.0" >

    <uses-sdk android:minSdkVersion="10" />
<uses-permission android:name="android.permission.VIBRATE" >
    </uses-permission>
    <application
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name" >
        <activity
            android:name=".AlarmActivityActivity"
            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>
于 2012-11-07T04:54:33.920 に答える
1

私があなたを正しく理解していれば、新しいデータをチェックするためにアプリケーション全体を実行する必要はありません。別のバックグラウンドタスクで実行する必要があるからです。

必要なのは、AlarmManager内に登録されたアラームと、アラームが発生したときに呼び出されるBroadcastReceiverです。受信者は新しいデータをチェックし、条件が満たされた場合、通知アクティビティを開始するインテントを実行します。

データベースへのアクセスにさらに時間がかかる場合は、受信者が開始するサービスで行う方がよいことに注意してください。

cwac-wakeful(https://github.com/commonsguy/cwac-wakeful)を使用すると、コーディングを節約できます(そして、いくつかの一般的な問題を解決できます)。これにより、データベースチェックサービスが稼働している限り、稼働し続けることができます。その仕事をします。それは非常によく文書化されており、いくつかの例が利用可能です。

読む価値のあるいくつかの理論は、http ://www.vogella.com/articles/AndroidServices/article.htmlで見つけることができます。主にサービスに関するものですが、アラームについても説明があります。

于 2012-09-20T17:46:05.483 に答える