/* * Copyright (C) 2012 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package android.hardware.display; import android.os.Parcel; import android.os.Parcelable; import libcore.util.Objects; /** * Describes the properties of a Wifi display. *
* This object is immutable. *
* * @hide */ public final class WifiDisplay implements Parcelable { private final String mDeviceAddress; private final String mDeviceName; private final String mDeviceAlias; public static final WifiDisplay[] EMPTY_ARRAY = new WifiDisplay[0]; public static final Creator* The alias should be used in the UI whenever available. It is the value * provided by the user when renaming the device. *
*/ public String getDeviceAlias() { return mDeviceAlias; } /** * Gets the name to show in the UI. * Uses the device alias if available, otherwise uses the device name. */ public String getFriendlyDisplayName() { return mDeviceAlias != null ? mDeviceAlias : mDeviceName; } @Override public boolean equals(Object o) { return o instanceof WifiDisplay && equals((WifiDisplay)o); } public boolean equals(WifiDisplay other) { return other != null && mDeviceAddress.equals(other.mDeviceAddress) && mDeviceName.equals(other.mDeviceName) && Objects.equal(mDeviceAlias, other.mDeviceAlias); } /** * Returns true if the other display is not null and has the same address as this one. * Can be used to perform identity comparisons on displays ignoring properties * that might change during a connection such as the name or alias. */ public boolean hasSameAddress(WifiDisplay other) { return other != null && mDeviceAddress.equals(other.mDeviceAddress); } @Override public int hashCode() { // The address on its own should be sufficiently unique for hashing purposes. return mDeviceAddress.hashCode(); } @Override public void writeToParcel(Parcel dest, int flags) { dest.writeString(mDeviceAddress); dest.writeString(mDeviceName); dest.writeString(mDeviceAlias); } @Override public int describeContents() { return 0; } // For debugging purposes only. @Override public String toString() { String result = mDeviceName + " (" + mDeviceAddress + ")"; if (mDeviceAlias != null) { result += ", alias " + mDeviceAlias; } return result; } }