基于支票的Android每日通知

时间:2014-03-30 14:06:04

标签: android notifications

我当前正在开发一款Android应用程序来记住用户的日常操作。 我们的想法是,如果用户尚未执行操作,应用程序会向用户发出通知。通知应每天出现在下午3点。

我的问题是,我如何实施检查。我已经找到了关于如何使用AlarmManager和NotificationManager的教程,但如果用户已经完成,这些将记住用户。 有没有办法开始检查而不是通知,如果检查说应该有通知,它是否已发布?

1 个答案:

答案 0 :(得分:2)

您可以保存指示用户上次完成每日操作的共享首选项。当您的警报触发时,您启动一​​项检查共享首选项状态的服务。如果不到1天前,则用户今天已完成日常操作。

以下是您的检查方式:

SharedPreferences settings = getSharedPreferences(MainActivity.PREFS, MODE_PRIVATE);
if (System.currentTimeMillis() - settings.getLong("lastTimeActionDone", 0) < MILLISECS_PER_DAY) {
    // Action done within last day
} else {        
    // Action not done within last day
}

以下是您保存上一次操作的方式:

SharedPreferences settings = getSharedPreferences(MainActivity.PREFS, MODE_PRIVATE);
SharedPreferences.Editor editor = null;

editor.putLong("lastTimeActionDone", System.currentTimeMillis());
editor.commit();        

编辑:

这是一个样本应用程序,可以完成您想要的大部分工作。正如所写,它只是在每天的同一时间醒来,那个时间是应用程序上次启动的时间。因此,缺少的一个主要部分是在每天的特定时间唤醒警报。为了使该部分工作,在设置(第一)警报时间时,您需要进行一些日期时算术。

MainActivity.java:

package com.example.dailycheck;

import android.app.Activity;
import android.content.Intent;
import android.content.SharedPreferences;
import android.os.Bundle;
import android.util.Log;
import android.view.View;

public class MainActivity extends Activity {

    private final static String TAG = "MainActivity";
    public final static String PREFS = "PrefsFile";

    private SharedPreferences settings = null;
    private SharedPreferences.Editor editor = null;

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

        // Save time of run:
        settings = getSharedPreferences(PREFS, MODE_PRIVATE);
        editor = settings.edit();

        // First time running app?
        if (!settings.contains("lastTimeActionDone"))
            enableNotification(null);

        Log.v(TAG, "Starting CheckRecentRun service...");
        startService(new Intent(this, CheckActionDone.class));
    }

    public void doAction(View v) {
        Log.v(TAG, "Recording time action done");
        editor.putLong("lastTimeActionDone", System.currentTimeMillis());
        editor.commit();        
    }

    public void enableNotification(View v) {
        editor.putBoolean("enabled", true);                
        editor.commit();        
        Log.v(TAG, "Notifications enabled");
    }

    public void disableNotification(View v) {
        editor.putBoolean("enabled", false);                
        editor.commit();        
        Log.v(TAG, "Notifications disabled");
    }
}

CheckActionDone.java:

package com.example.dailycheck;

import android.app.AlarmManager;
import android.app.Notification;
import android.app.NotificationManager;
import android.app.PendingIntent;
import android.app.Service;
import android.content.Context;
import android.content.Intent;
import android.content.SharedPreferences;
import android.os.IBinder;
import android.util.Log;

public class CheckActionDone extends Service {

    private final static String TAG = "CheckRecentPlay";
    private static Long MILLISECS_PER_DAY = 86400000L;

    private static long delay = 60000;                 // 1 minute (for testing)
//    private static long delay = MILLISECS_PER_DAY;   // 1 day

    @Override
    public void onCreate() {
        super.onCreate();

        Log.v(TAG, "Service started");                
        SharedPreferences settings = getSharedPreferences(MainActivity.PREFS, MODE_PRIVATE);

        // Are notifications enabled?
        if (settings.getBoolean("enabled", true)) {
            // And was action not recently done?
            Long lastTimeDone = settings.getLong("lastTimeActionDone", 0);
            if ((System.currentTimeMillis() - lastTimeDone) >= delay) {
                sendNotification();
             } else {
                 Log.i(TAG, "Action recently done");
             }
        } else {        
            Log.i(TAG, "Notifications are disabled");
        }

        // Set an alarm for the next time this service should run:
        setAlarm();

        Log.v(TAG, "Service stopped");        
        stopSelf();
    }

    public void setAlarm() {

        Intent serviceIntent = new Intent(this, CheckActionDone.class);
        PendingIntent pi = PendingIntent.getService(this, 131313, serviceIntent,
                                                    PendingIntent.FLAG_CANCEL_CURRENT);

        AlarmManager am = (AlarmManager) getSystemService(Context.ALARM_SERVICE);
        am.set(AlarmManager.RTC_WAKEUP, System.currentTimeMillis() + delay, pi);
        Log.v(TAG, "Alarm set");        
    }

    public void sendNotification() {

        Intent mainIntent = new Intent(this, MainActivity.class);
        @SuppressWarnings("deprecation")
        Notification noti = new Notification.Builder(this)
            .setAutoCancel(true)
            .setContentIntent(PendingIntent.getActivity(this, 131314, mainIntent,
                              PendingIntent.FLAG_UPDATE_CURRENT))
            .setContentTitle("Action Not Do")
            .setContentText("You didn't do the daily action.")
            .setDefaults(Notification.DEFAULT_ALL)
            .setSmallIcon(R.drawable.ic_launcher)
            .setTicker("You haven;t done the daily action; please do it now.")
            .setWhen(System.currentTimeMillis())
            .getNotification();

        NotificationManager notificationManager
            = (NotificationManager) this.getSystemService(Context.NOTIFICATION_SERVICE);
        notificationManager.notify(131315, noti);

        Log.v(TAG, "Notification sent");        
    }

    @Override
    public IBinder onBind(Intent intent) {
        return null;
    }
}

main_activity.xml:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical" >

    <Button
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:onClick="doAction"
        android:text="@string/do_action" />

    <Button
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:onClick="enableNotification"
        android:text="@string/enable" />

    <Button
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:onClick="disableNotification"
        android:text="@string/disable" />

</LinearLayout>

的strings.xml:

<?xml version="1.0" encoding="utf-8"?>
<resources>

    <string name="app_name">Come Back</string>
    <string name="do_action">Do Action</string>
    <string name="enable">Enable Notifications</string>
    <string name="disable">Disable Notifications</string>

</resources>

的AndroidManifest.xml:

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

    <uses-sdk
        android:minSdkVersion="11"
        android:targetSdkVersion="19" />

    <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.dailycheck.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>
        <service
            android:name="com.example.dailycheck.CheckActionDone" >
        </service>
        </application>

</manifest>