您好,登錄后才能下訂單哦!
這篇文章給大家介紹Android中怎么利用JobScheduler定期推送本地通知,內(nèi)容非常詳細(xì),感興趣的小伙伴們可以參考借鑒,希望對(duì)大家能有所幫助。
?Android5.0之后提供了JobService和JobScheduler,用于在稍后的某個(gè)時(shí)間點(diǎn)或者當(dāng)滿足某個(gè)特定的條件時(shí)執(zhí)行一個(gè)任務(wù)。使用JobScheduler,我們可以在用戶一段時(shí)間沒(méi)有使用我們的app的情況下,推送本地通知來(lái)提高app的用戶留存率。廢話不多說(shuō),上代碼:
先在app的MainActivity啟動(dòng)時(shí)用JobScheduler來(lái)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來(lái)獲得:
@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是否過(guò)了一定時(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)容上線了,快來(lá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)限:
<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" />
關(guān)于Android中怎么利用JobScheduler定期推送本地通知就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。