AndroID5.0之后提供了JobService和JobScheduler,用于在稍后的某个时间点或者当满足某个特定的条件时执行一个任务。使用JobScheduler,我们可以在用户一段时间没有使用我们的app的情况下,推送本地通知来提高app的用户留存率。废话不多说,上代码:
先在app的MainActivity启动时用JobScheduler来schedule一个job。注意在onCreate中我们把用户启动app的时间记录在了shared preference里面:
@OverrIDeprotected 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定期推送本地通知实例代码所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)