1 /* 2 * Copyright (C) 2013 The Android Open Source Project 3 * 4 * Licensed under the Apache License, Version 2.0 (the "License"); 5 * you may not use this file except in compliance with the License. 6 * You may obtain a copy of the License at 7 * 8 * http://www.apache.org/licenses/LICENSE-2.0 9 * 10 * Unless required by applicable law or agreed to in writing, software 11 * distributed under the License is distributed on an "AS IS" BASIS, 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13 * See the License for the specific language governing permissions and 14 * limitations under the License. 15 */ 16 package android.support.v7.media; 17 18 import android.os.Bundle; 19 20 /** 21 * Describes the kinds of routes that the media router would like to discover 22 * and whether to perform active scanning. 23 * <p> 24 * This object is immutable once created. 25 * </p> 26 */ 27 public final class MediaRouteDiscoveryRequest { 28 private static final String KEY_SELECTOR = "selector"; 29 private static final String KEY_ACTIVE_SCAN = "activeScan"; 30 31 private final Bundle mBundle; 32 private MediaRouteSelector mSelector; 33 34 /** 35 * Creates a media route discovery request. 36 * 37 * @param selector The route selector that specifies the kinds of routes to discover. 38 * @param activeScan True if active scanning should be performed. 39 */ 40 public MediaRouteDiscoveryRequest(MediaRouteSelector selector, boolean activeScan) { 41 if (selector == null) { 42 throw new IllegalArgumentException("selector must not be null"); 43 } 44 45 mBundle = new Bundle(); 46 mSelector = selector; 47 mBundle.putBundle(KEY_SELECTOR, selector.asBundle()); 48 mBundle.putBoolean(KEY_ACTIVE_SCAN, activeScan); 49 } 50 51 private MediaRouteDiscoveryRequest(Bundle bundle) { 52 mBundle = bundle; 53 } 54 55 /** 56 * Gets the route selector that specifies the kinds of routes to discover. 57 */ 58 public MediaRouteSelector getSelector() { 59 ensureSelector(); 60 return mSelector; 61 } 62 63 private void ensureSelector() { 64 if (mSelector == null) { 65 mSelector = MediaRouteSelector.fromBundle(mBundle.getBundle(KEY_SELECTOR)); 66 if (mSelector == null) { 67 mSelector = MediaRouteSelector.EMPTY; 68 } 69 } 70 } 71 72 /** 73 * Returns true if active scanning should be performed. 74 * 75 * @see MediaRouter#CALLBACK_FLAG_PERFORM_ACTIVE_SCAN 76 */ 77 public boolean isActiveScan() { 78 return mBundle.getBoolean(KEY_ACTIVE_SCAN); 79 } 80 81 /** 82 * Returns true if the discovery request has all of the required fields. 83 */ 84 public boolean isValid() { 85 ensureSelector(); 86 return mSelector.isValid(); 87 } 88 89 @Override 90 public boolean equals(Object o) { 91 if (o instanceof MediaRouteDiscoveryRequest) { 92 MediaRouteDiscoveryRequest other = (MediaRouteDiscoveryRequest)o; 93 return getSelector().equals(other.getSelector()) 94 && isActiveScan() == other.isActiveScan(); 95 } 96 return false; 97 } 98 99 @Override 100 public int hashCode() { 101 return getSelector().hashCode() ^ (isActiveScan() ? 1 : 0); 102 } 103 104 @Override 105 public String toString() { 106 StringBuilder result = new StringBuilder(); 107 result.append("DiscoveryRequest{ selector=").append(getSelector()); 108 result.append(", activeScan=").append(isActiveScan()); 109 result.append(", isValid=").append(isValid()); 110 result.append(" }"); 111 return result.toString(); 112 } 113 114 /** 115 * Converts this object to a bundle for serialization. 116 * 117 * @return The contents of the object represented as a bundle. 118 */ 119 public Bundle asBundle() { 120 return mBundle; 121 } 122 123 /** 124 * Creates an instance from a bundle. 125 * 126 * @param bundle The bundle, or null if none. 127 * @return The new instance, or null if the bundle was null. 128 */ 129 public static MediaRouteDiscoveryRequest fromBundle(Bundle bundle) { 130 return bundle != null ? new MediaRouteDiscoveryRequest(bundle) : null; 131 } 132 } 133