您好,登錄后才能下訂單哦!
這篇文章主要介紹了Android中如何利用JobScheduler定期推送本地通知的相關知識,內容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇Android中如何利用JobScheduler定期推送本地通知文章都會有所收獲,下面我們一起來看看吧。
?Android5.0之后提供了JobService和JobScheduler,用于在稍后的某個時間點或者當滿足某個特定的條件時執行一個任務。使用JobScheduler,我們可以在用戶一段時間沒有使用我們的app的情況下,推送本地通知來提高app的用戶留存率。廢話不多說,上代碼:
先在app的MainActivity啟動時用JobScheduler來schedule一個job。注意在onCreate中我們把用戶啟動app的時間記錄在了shared preference里面:
@Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); sharedPreferences.edit().putLong(Constants.SP_PARAM_LAST_LAUNCH, System.currentTimeMillis()).apply(); scheduleNotifications(); } private void scheduleNotifications() { if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) { try { JobScheduler jobScheduler = (JobScheduler) getSystemService(JOB_SCHEDULER_SERVICE); JobInfo jobInfo = new JobInfo.Builder(1, new ComponentName(getPackageName(), NotificationService.class.getName())) .setRequiresCharging(false) .setRequiredNetworkType(JobInfo.NETWORK_TYPE_ANY) //任何有網絡的狀態 .setPersisted(true) //系統重啟后保留job .setPeriodic(1000 * 60 * 60 * 24) //這里的單位是毫秒,1000 * 60 * 60 * 24代表一天(24小時) .build(); jobScheduler.schedule(jobInfo); } catch (Exception ex) { Log.e("scheduleNotifications failure"); } } }
然后是推送通知的NotificationService,這里SharedPreferences是用的dagger2依賴注入,不用dagger的可以直接用PreferenceManager.getDefaultSharedPreferences來獲得:
@RequiresApi(api = Build.VERSION_CODES.LOLLIPOP) public class NotificationService extends JobService { @DefaultSharedPref @Inject SharedPreferences sharedPreferences; @Override public boolean onStartJob(JobParameters params) { try { long lastLaunchTime = sharedPreferences.getLong(Constants.SP_PARAM_LAST_LAUNCH, -1); if(lastLaunchTime > 0) { long intervalSinceLastLaunch = System.currentTimeMillis() - lastLaunchTime; //檢查距離用戶上一次啟動app是否過了一定時間 if(intervalSinceLastLaunch > 1000 * 60 * 60 * 24) { NotificationCompat.Builder mBuilder = new NotificationCompat.Builder(NotificationService.this) .setAutoCancel(true) .setSmallIcon(R.mipmap.ic_launcher) .setContentTitle("我的app") .setContentText("又有新的內容上線了,快來我們app看看吧!"); Intent resultIntent = new Intent(NotificationService.this, MainActivity.class); TaskStackBuilder stackBuilder = TaskStackBuilder.create(NotificationService.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(1, mBuilder.build()); } } } catch (Exception ex) { Log.e("Exception in NotificationService onStartJob"); } return false; } @Override public boolean onStopJob(JobParameters params) { Log.d("NotificationService onStopJob"); return true; } }
最后需要在Manifest中注冊我們的service和申請相關的權限:
<uses-permission android:name="android.permission.INTERNET" /> <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" /> <uses-permission android:name="android.permission.ACCESS_WIFI_STATE" /> <uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED" /> <service android:name=".NotificationService" android:permission="android.permission.BIND_JOB_SERVICE" />
關于“Android中如何利用JobScheduler定期推送本地通知”這篇文章的內容就介紹到這里,感謝各位的閱讀!相信大家對“Android中如何利用JobScheduler定期推送本地通知”知識都有一定的了解,大家如果還想學習更多知識,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。