ConnectivityManager 提供
了一个 API,让您可以根据
各种条件(包括设备功能和数据传输选项)请求设备连接到网络。
回调实现会向您的应用提供有关设备连接状态以及当前连接的网络的功能的信息。借助该 API,您可以确定设备当前是否连接到满足应用要求的网络。
配置网络请求
如需指定网络的传输类型(例如 Wi-Fi 或移动网络连接)以及当前连接的网络的功能(例如互联网连接),您必须配置网络请求。
声明一个 NetworkRequest,用于
描述应用的网络连接需求。以下代码会创建一个请求,用于请求连接到互联网的网络,并使用 Wi-Fi、以太网或移动网络连接作为传输类型。
Kotlin
val networkRequest = NetworkRequest.Builder() .addCapability(NetworkCapabilities.NET_CAPABILITY_INTERNET) .addTransportType(NetworkCapabilities.TRANSPORT_ETHERNET) .addTransportType(NetworkCapabilities.TRANSPORT_WIFI) .addTransportType(NetworkCapabilities.TRANSPORT_CELLULAR) .build()
Java
NetworkRequest networkRequest = new NetworkRequest.Builder() .addCapability(NetworkCapabilities.NET_CAPABILITY_INTERNET) .addTransportType(NetworkCapabilities.TRANSPORT_ETHERNET) .addTransportType(NetworkCapabilities.TRANSPORT_WIFI) .addTransportType(NetworkCapabilities.TRANSPORT_CELLULAR) .build();
请注意,某些连接可能比其他连接贵得多(例如,移动网络连接通常很贵)。使用
NetworkCapabilities#NET_CAPABILITY_NOT_METERED
确定连接是否昂贵。在使用按流量计费的网络连接时,请尝试减少应用的数据流量消耗,或者延迟到设备连接到不按流量计费的网络后再使用。
配置网络回调
将 NetworkRequest 注册到 ConnectivityManager 时,您必须
实现
NetworkCallback
以接收有关连接状态和网络
功能变化的通知。
NetworkCallback 中最常实现的功能包括以下内容:
onAvailable()表示设备已连接到满足NetworkRequest中指定的功能和传输类型要求的新网络。onLost()表示设备已与网络断开连接。onCapabilitiesChanged()表示网络的功能已更改。TheNetworkCapabilities对象 提供有关网络当前功能的信息。
Kotlin
private val networkCallback = object : ConnectivityManager.NetworkCallback() { // network is available for use override fun onAvailable(network: Network) { super.onAvailable(network) } // Network capabilities have changed for the network override fun onCapabilitiesChanged( network: Network, networkCapabilities: NetworkCapabilities ) { super.onCapabilitiesChanged(network, networkCapabilities) val unmetered = networkCapabilities.hasCapability(NetworkCapabilities.NET_CAPABILITY_NOT_METERED) } // lost network connection override fun onLost(network: Network) { super.onLost(network) } }
Java
private ConnectivityManager.NetworkCallback networkCallback = new ConnectivityManager.NetworkCallback() { @Override public void onAvailable(@NonNull Network network) { super.onAvailable(network); } @Override public void onLost(@NonNull Network network) { super.onLost(network); } @Override public void onCapabilitiesChanged(@NonNull Network network, @NonNull NetworkCapabilities networkCapabilities) { super.onCapabilitiesChanged(network, networkCapabilities); final boolean unmetered = networkCapabilities.hasCapability(NetworkCapabilities.NET_CAPABILITY_NOT_METERED); } };
注册以接收网络更新
声明 NetworkRequest 和 NetworkCallback 后,使用
requestNetwork()
或 registerNetworkCallback()
函数搜索设备中满足
NetworkRequest 的网络以进行连接。然后,系统会将状态报告给 NetworkCallback。
Kotlin
val connectivityManager = getSystemService(ConnectivityManager::class.java) as ConnectivityManager connectivityManager.requestNetwork(networkRequest, networkCallback)
Java
ConnectivityManager connectivityManager = (ConnectivityManager) getSystemService(ConnectivityManager.class); connectivityManager.requestNetwork(networkRequest, networkCallback);