NetworkInfo
public class NetworkInfo
extends Object
implements Parcelable
java.lang.Object | |
↳ | android.net.NetworkInfo |
This class was deprecated in API level 29.
Callers should instead use the ConnectivityManager.NetworkCallback
API to learn about connectivity changes, or switch to use ConnectivityManager.getNetworkCapabilities
or ConnectivityManager.getLinkProperties
to get information synchronously. Keep in mind that while callbacks are guaranteed to be called for every event in order, synchronous calls have no such constraints, and as such it is unadvisable to use the synchronous methods inside the callbacks as they will often not offer a view of networking that is consistent (that is: they may return a past or a future state with respect to the event being processed by the callback). Instead, callers are advised to only use the arguments of the callbacks, possibly memorizing the specific bits of information they need to keep from one callback to another.
Describes the status of a network interface.
Use ConnectivityManager.getActiveNetworkInfo()
to get an instance that represents the current network connection.
Summary
Inherited constants |
---|
Fields | |
---|---|
public static final Creator<NetworkInfo> | CREATOR
|
Public constructors | |
---|---|
NetworkInfo(int type, int subtype, String typeName, String subtypeName) Create a new instance of NetworkInfo. |
Public methods | |
---|---|
int | describeContents() Describe the kinds of special objects contained in this Parcelable instance's marshaled representation. |
NetworkInfo.DetailedState | getDetailedState() This method is deprecated. Apps should instead use the |
String | getExtraInfo() This method is deprecated. Use other services e.g. WifiManager to get additional information passed up from the lower networking layers. |
String | getReason() This method was deprecated in API level 28. This method does not have a consistent contract that could make it useful to callers. |
NetworkInfo.State | getState() This method was deprecated in API level 28. Apps should instead use the |
int | getSubtype() This method was deprecated in API level 29. Use |
String | getSubtypeName() This method was deprecated in API level 29. Use |
int | getType() This method was deprecated in API level 28. Callers should switch to checking |
String | getTypeName() This method was deprecated in API level 28. Callers should switch to checking |
boolean | isAvailable() This method was deprecated in API level 28. Apps should instead use the |
boolean | isConnected() This method is deprecated. Apps should instead use the |
boolean | isConnectedOrConnecting() This method was deprecated in API level 28. Apps should instead use the |
boolean | isFailover() This method was deprecated in API level 28. This field is not populated in recent Android releases, and does not make a lot of sense in a multi-network world. |
boolean | isRoaming() This method was deprecated in API level 28. Callers should switch to checking |
void | setDetailedState(NetworkInfo.DetailedState detailedState, String reason, String extraInfo) This method was deprecated in API level 29. Use |
String | toString() Returns a string representation of the object. |
void | writeToParcel(Parcel dest, int flags) Flatten this object in to a Parcel. |
Inherited methods | |
---|---|
Fields
CREATOR
public static final Creator<NetworkInfo> CREATOR
Public constructors
NetworkInfo
public NetworkInfo (int type, int subtype, String typeName, String subtypeName)
Create a new instance of NetworkInfo. This may be useful for apps to write unit tests.
Parameters | |
---|---|
type | int : the legacy type of the network, as one of the ConnectivityManager.TYPE_* constants. |
subtype | int : the subtype if applicable, as one of the TelephonyManager.NETWORK_TYPE_* constants. |
typeName | String : a human-readable string for the network type, or an empty string or null. |
subtypeName | String : a human-readable string for the subtype, or an empty string or null. |
Public methods
describeContents
public int describeContents ()
Describe the kinds of special objects contained in this Parcelable instance's marshaled representation. For example, if the object will include a file descriptor in the output of writeToParcel(android.os.Parcel, int)
, the return value of this method must include the CONTENTS_FILE_DESCRIPTOR
bit.
Returns | |
---|---|
int | a bitmask indicating the set of special object types marshaled by this Parcelable object instance. Value is either 0 or CONTENTS_FILE_DESCRIPTOR |
getDetailedState
public NetworkInfo.DetailedState getDetailedState ()
This method is deprecated.
Apps should instead use the ConnectivityManager.NetworkCallback
API to learn about connectivity changes. See ConnectivityManager.registerDefaultNetworkCallback
and ConnectivityManager.registerNetworkCallback
. These will give a more accurate picture of the connectivity state of the device and let apps react more easily and quickly to changes.
Reports the current fine-grained state of the network.
Returns | |
---|---|
NetworkInfo.DetailedState | the fine-grained state This value cannot be null . |
getExtraInfo
public String getExtraInfo ()
This method is deprecated.
Use other services e.g. WifiManager to get additional information passed up from the lower networking layers.
Report the extra information about the network state, if any was provided by the lower networking layers.
Returns | |
---|---|
String | the extra information, or null if not available |
getReason
public String getReason ()
This method was deprecated in API level 28.
This method does not have a consistent contract that could make it useful to callers.
Report the reason an attempt to establish connectivity failed, if one is available.
Returns | |
---|---|
String | the reason for failure, or null if not available |
getState
public NetworkInfo.State getState ()
This method was deprecated in API level 28.
Apps should instead use the ConnectivityManager.NetworkCallback
API to learn about connectivity changes. ConnectivityManager.registerDefaultNetworkCallback
and ConnectivityManager.registerNetworkCallback
. These will give a more accurate picture of the connectivity state of the device and let apps react more easily and quickly to changes.
Reports the current coarse-grained state of the network.
Returns | |
---|---|
NetworkInfo.State | the coarse-grained state |
getSubtype
public int getSubtype ()
This method was deprecated in API level 29.
Use TelephonyManager.getDataNetworkType()
instead.
Return a network-type-specific integer describing the subtype of the network.
Returns | |
---|---|
int | the network subtype |
getSubtypeName
public String getSubtypeName ()
This method was deprecated in API level 29.
Use TelephonyManager.getDataNetworkType()
instead.
Return a human-readable name describing the subtype of the network.
Returns | |
---|---|
String | the name of the network subtype |
getType
public int getType ()
This method was deprecated in API level 28.
Callers should switch to checking NetworkCapabilities.hasTransport
instead with one of the NetworkCapabilities#TRANSPORT_* constants : getType()
and getTypeName()
cannot account for networks using multiple transports. Note that generally apps should not care about transport; NetworkCapabilities.NET_CAPABILITY_NOT_METERED
and NetworkCapabilities.getLinkDownstreamBandwidthKbps
are calls that apps concerned with meteredness or bandwidth should be looking at, as they offer this information with much better accuracy.
Reports the type of network to which the info in this NetworkInfo
pertains.
Returns | |
---|---|
int | one of ConnectivityManager.TYPE_MOBILE , ConnectivityManager.TYPE_WIFI , ConnectivityManager.TYPE_WIMAX , ConnectivityManager.TYPE_ETHERNET , ConnectivityManager.TYPE_BLUETOOTH , or other types defined by ConnectivityManager . |
getTypeName
public String getTypeName ()
This method was deprecated in API level 28.
Callers should switch to checking NetworkCapabilities.hasTransport
instead with one of the NetworkCapabilities#TRANSPORT_* constants : getType()
and getTypeName()
cannot account for networks using multiple transports. Note that generally apps should not care about transport; NetworkCapabilities.NET_CAPABILITY_NOT_METERED
and NetworkCapabilities.getLinkDownstreamBandwidthKbps
are calls that apps concerned with meteredness or bandwidth should be looking at, as they offer this information with much better accuracy.
Return a human-readable name describe the type of the network, for example "WIFI" or "MOBILE".
Returns | |
---|---|
String | the name of the network type |
isAvailable
public boolean isAvailable ()
This method was deprecated in API level 28.
Apps should instead use the ConnectivityManager.NetworkCallback
API to learn about connectivity changes. ConnectivityManager.registerDefaultNetworkCallback
and ConnectivityManager.registerNetworkCallback
. These will give a more accurate picture of the connectivity state of the device and let apps react more easily and quickly to changes.
Indicates whether network connectivity is possible. A network is unavailable when a persistent or semi-persistent condition prevents the possibility of connecting to that network. Examples include
- The device is out of the coverage area for any network of this type.
- The device is on a network other than the home network (i.e., roaming), and data roaming has been disabled.
- The device's radio is turned off, e.g., because airplane mode is enabled.
true
, because the system only returns info for available networks. Returns | |
---|---|
boolean | true if the network is available, false otherwise |
isConnected
public boolean isConnected ()
This method is deprecated.
Apps should instead use the ConnectivityManager.NetworkCallback
API to learn about connectivity changes. See ConnectivityManager.registerDefaultNetworkCallback
and ConnectivityManager.registerNetworkCallback
. These will give a more accurate picture of the connectivity state of the device and let apps react more easily and quickly to changes.
Indicates whether network connectivity exists and it is possible to establish connections and pass data.
Always call this before attempting to perform data transactions.
Returns | |
---|---|
boolean | true if network connectivity exists, false otherwise. |
isConnectedOrConnecting
public boolean isConnectedOrConnecting ()
This method was deprecated in API level 28.
Apps should instead use the ConnectivityManager.NetworkCallback
API to learn about connectivity changes. ConnectivityManager.registerDefaultNetworkCallback
and ConnectivityManager.registerNetworkCallback
. These will give a more accurate picture of the connectivity state of the device and let apps react more easily and quickly to changes.
Indicates whether network connectivity exists or is in the process of being established. This is good for applications that need to do anything related to the network other than read or write data. For the latter, call isConnected()
instead, which guarantees that the network is fully usable.
Returns | |
---|---|
boolean | true if network connectivity exists or is in the process of being established, false otherwise. |
isFailover
public boolean isFailover ()
This method was deprecated in API level 28.
This field is not populated in recent Android releases, and does not make a lot of sense in a multi-network world.
Indicates whether the current attempt to connect to the network resulted from the ConnectivityManager trying to fail over to this network following a disconnect from another network.
Returns | |
---|---|
boolean | true if this is a failover attempt, false otherwise. |
isRoaming
public boolean isRoaming ()
This method was deprecated in API level 28.
Callers should switch to checking NetworkCapabilities.NET_CAPABILITY_NOT_ROAMING
instead, since that handles more complex situations, such as VPNs.
Indicates whether the device is currently roaming on this network. When true
, it suggests that use of data on this network may incur extra costs.
Returns | |
---|---|
boolean | true if roaming is in effect, false otherwise. |
setDetailedState
public void setDetailedState (NetworkInfo.DetailedState detailedState, String reason, String extraInfo)
This method was deprecated in API level 29.
Use NetworkCapabilities
instead.
Sets the fine-grained state of the network. This is only useful for testing.
Parameters | |
---|---|
detailedState | NetworkInfo.DetailedState : the DetailedState . This value cannot be null . |
reason | String : a String indicating the reason for the state change, if one was supplied. May be null . |
extraInfo | String : an optional String providing additional network state information passed up from the lower networking layers. This value may be null . |
toString
public String toString ()
Returns a string representation of the object.
Returns | |
---|---|
String | a string representation of the object. |
writeToParcel
public void writeToParcel (Parcel dest, int flags)
Flatten this object in to a Parcel.
Parameters | |
---|---|
dest | Parcel : The Parcel in which the object should be written. This value cannot be null . |
flags | int : Additional flags about how the object should be written. May be 0 or Parcelable.PARCELABLE_WRITE_RETURN_VALUE . Value is either 0 or a combination of Parcelable.PARCELABLE_WRITE_RETURN_VALUE , and android.os.Parcelable.PARCELABLE_ELIDE_DUPLICATES |