网络监听器
当我们项目播放视频或者需要长连接是可能需要监听网络状态,因为最近在研究websocket,所以延伸这个问题
1、注册静态广播监听:
(1)mainfest 注册receiver
<receiver android:name=".NetBroadcastReceiver">
<action android:name="android.net.conn.CONNECTIVITY_CHANGE" />
</receiver>
(2)广播接收类
public class NetBroadcastReceiverextends BroadcastReceiver {
@Override
public void onReceive(Context context, Intent intent) {
// 如果相等的话就说明网络状态发生了变化
if (intent.getAction().equals(ConnectivityManager.CONNECTIVITY_ACTION)) {
int netWorkState = NetUtil.getNetWorkState(context);
Log.e("onReceive", netWorkState +"==");
// 接口回调传过去状态的类型
}
}
(3 )//实例化IntentFilter对象
IntentFilter filter =new IntentFilter();
filter.addAction(WifiManager.WIFI_STATE_CHANGED_ACTION);
filter.addAction(WifiManager.NETWORK_STATE_CHANGED_ACTION);
filter.addAction(ConnectivityManager.CONNECTIVITY_ACTION);
filter.addAction("android.net.conn.CONNECTIVITY_CHANGE");
netBroadcastReceiver =new NetBroadcastReceiver();
registerReceiver(netBroadcastReceiver, filter);
最后别忘了页面销毁时解绑广播
2、NetworkCallback监听网络:
activity 初始化
NetworkCallbackImpl networkCallback =new NetworkCallbackImpl();
NetworkRequest request =new NetworkRequest.Builder().build();
ConnectivityManager cmgr = (ConnectivityManager) getSystemService(Context.CONNECTIVITY_SERVICE);
if (cmgr !=null) {
cmgr.registerNetworkCallback(request, networkCallback);
}
/**
* 5.0以上
*/
@RequiresApi(api = Build.VERSION_CODES.LOLLIPOP)
public class NetworkCallbackImplextends ConnectivityManager.NetworkCallback {
private static final StringTAG ="NetworkCallbackImpl";
@Override
public void onAvailable(Network network) {
super.onAvailable(network);
Log.e(TAG, "网络连接了");
}
@Override
public void onLost(Network network) {
super.onLost(network);
Log.e(TAG, "网络断开了");
}
@Override
public void onCapabilitiesChanged(Network network, NetworkCapabilities networkCapabilities) {
super.onCapabilitiesChanged(network, networkCapabilities);
if (networkCapabilities.hasCapability(NetworkCapabilities.NET_CAPABILITY_VALIDATED)) {
if (networkCapabilities.hasTransport(NetworkCapabilities.TRANSPORT_WIFI)) {
Log.e(TAG, "wifi网络已连接");
}else {
Log.e(TAG, "移动网络已连接");
}
}
}
}
3、// JobSchedulerService是自定义的启动Job执行的服务
int JOB_ID =1;
JobInfo.Builder jb =new JobInfo.Builder(JOB_ID, new ComponentName(getPackageName(), JobSchedulerService.class.getName()));
// 指定Job多少毫秒之后执行,与setPeriodic()互斥,同时使用会抛出异常
jb.setMinimumLatency(5000);
// 指定Job在多少毫秒之后执行无论条件是否满足,与setPeriodic()互斥
jb.setOverrideDeadline(10 *1000);
// 是否系统重启后继续该Job执行,清单文件要添加权限android.permission.RECEIVE_BOOT_COMPLETED
jb.setPersisted(true);
// 指定Job每多少毫秒执行一次
jb.setPeriodic(3000);
// 指定启动Job时的网络类型
// JobInfo.NETWORK_TYPE_NONE:启动Job时不需要任何网络连接
// JobInfo.NETWORK_TYPE_ANY:启动Job时只要有网络就可以
// JobInfo.NETWORK_TYPE_NETWORK_TYPE_UNMETERED:启动Job时要连接wifi
jb.setRequiredNetworkType(JobInfo.NETWORK_TYPE_UNMETERED);
// 指定启动Job时是否需要连接电源
jb.setRequiresCharging(false);
// 指定启动Job时是否需要设别处于空闲状态
jb.setRequiresDeviceIdle(false);
// setRequiredNetworkType()、setRequiresCharging()、setRequiresDeviceIdle()同时使用时可能导致Job永远不会执行
// 这时需要设置setOverrideDeadline()确保Job在不满足条件时能被执行一次
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
// 指定启动Job时是否为低电源
jb.setRequiresBatteryNotLow(false);
// 指定启动Job时是否为低存储
jb.setRequiresStorageNotLow(false);
}
JobInfo jobInfo = jb.build();
JobScheduler jobScheduler = (JobScheduler) getSystemService(JOB_SCHEDULER_SERVICE);
// 如果启动成功将返回启动任务的JobId,否则返回其他结果
int jobId = jobScheduler.schedule(jobInfo);
if (jobId <=0) {
// 取消Job
jobScheduler.cancel(jobId);
jobScheduler.cancelAll();
// 获取Job
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) {
JobInfo pendingJob = jobScheduler.getPendingJob(jobId);
}
List allPendingJob = jobScheduler.getAllPendingJobs();
}
@RequiresApi(api = Build.VERSION_CODES.LOLLIPOP)
public class JobSchedulerServiceextends JobService {
/**
* 启动工作
*
* @return
*
* 如果返回true,代表执行的将会是一个耗时任务,工作将会在异步执行,在执行完Job后要手动调用jobFinished()结束Job,否则系统不会再入队其他Job执行,即JobScheduler的执行队列阻塞
*
* 如果返回false,代表处理的Job不是一个耗时任务
*/
@Override
public boolean onStartJob(JobParameters params) {
return false;
}
/**
* 结束工作
*
* 系统收到取消Job请求且这个Job仍然在执行,系统就会调用该方法,即onStartJob()要返回true且执行耗时的Job没有结束时会调用,否则不调用
*/
@Override
public boolean onStopJob(JobParameters params) {
return false;
}
}