這篇文章主要介紹了Android中如何利用JobScheduler定期推送本地通知的相關(guān)知識(shí),內(nèi)容詳細(xì)易懂,操作簡(jiǎn)單快捷,具有一定借鑒價(jià)值,相信大家閱讀完這篇Android中如何利用JobScheduler定期推送本地通知文章都會(huì)有所收獲,下面我們一起來看看吧。
站在用戶的角度思考問題,與客戶深入溝通,找到臥龍網(wǎng)站設(shè)計(jì)與臥龍網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗(yàn),讓設(shè)計(jì)與互聯(lián)網(wǎng)技術(shù)結(jié)合,創(chuàng)造個(gè)性化、用戶體驗(yàn)好的作品,建站類型包括:網(wǎng)站建設(shè)、成都網(wǎng)站制作、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣、域名申請(qǐng)、虛擬主機(jī)、企業(yè)郵箱。業(yè)務(wù)覆蓋臥龍地區(qū)。?Android5.0之后提供了JobService和JobScheduler,用于在稍后的某個(gè)時(shí)間點(diǎn)或者當(dāng)滿足某個(gè)特定的條件時(shí)執(zhí)行一個(gè)任務(wù)。使用JobScheduler,我們可以在用戶一段時(shí)間沒有使用我們的app的情況下,推送本地通知來提高app的用戶留存率。廢話不多說,上代碼:
先在app的MainActivity啟動(dòng)時(shí)用JobScheduler來schedule一個(gè)job。注意在onCreate中我們把用戶啟動(dòng)app的時(shí)間記錄在了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) //任何有網(wǎng)絡(luò)的狀態(tài) .setPersisted(true) //系統(tǒng)重啟后保留job .setPeriodic(1000 * 60 * 60 * 24) //這里的單位是毫秒,1000 * 60 * 60 * 24代表一天(24小時(shí)) .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; //檢查距離用戶上一次啟動(dòng)app是否過了一定時(shí)間 if(intervalSinceLastLaunch > 1000 * 60 * 60 * 24) { NotificationCompat.Builder mBuilder = new NotificationCompat.Builder(NotificationService.this) .setAutoCancel(true) .setSmallIcon(R.mipmap.ic_launcher) .setContentTitle("我的app") .setContentText("又有新的內(nèi)容上線了,快來我們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中注冊(cè)我們的service和申請(qǐng)相關(guān)的權(quán)限:
關(guān)于“Android中如何利用JobScheduler定期推送本地通知”這篇文章的內(nèi)容就介紹到這里,感謝各位的閱讀!相信大家對(duì)“Android中如何利用JobScheduler定期推送本地通知”知識(shí)都有一定的了解,大家如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。