网络监听器

2020-09-02  本文已影响0人  陈陈_04d0

当我们项目播放视频或者需要长连接是可能需要监听网络状态,因为最近在研究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;

  }

}

上一篇 下一篇

猜你喜欢

热点阅读