diff options
author | Ji-Hwan Lee <jihwan@google.com> | 2014-07-16 23:13:03 +0900 |
---|---|---|
committer | Ji-Hwan Lee <jihwan@google.com> | 2014-07-17 14:40:31 +0900 |
commit | 66bdf247df7b53130a01efe33419e0ce276e5f43 (patch) | |
tree | b191b9a80b59219450baa0610f9b1390cd2b5164 | |
parent | 2883ba69751de69811a38f086ecbe4c2032ca87d (diff) | |
download | frameworks_base-66bdf247df7b53130a01efe33419e0ce276e5f43.zip frameworks_base-66bdf247df7b53130a01efe33419e0ce276e5f43.tar.gz frameworks_base-66bdf247df7b53130a01efe33419e0ce276e5f43.tar.bz2 |
TIF: Add TvInputInfo.getParentId
Bug: 16166859
Change-Id: I07130b6f974ca7b2527aba68b92dc31fb4b5a139
-rw-r--r-- | api/current.txt | 1 | ||||
-rw-r--r-- | media/java/android/media/tv/TvInputInfo.java | 32 |
2 files changed, 28 insertions, 5 deletions
diff --git a/api/current.txt b/api/current.txt index 87c7300..7e64c67 100644 --- a/api/current.txt +++ b/api/current.txt @@ -16548,6 +16548,7 @@ package android.media.tv { method public java.lang.String getId(); method public android.content.Intent getIntentForSettingsActivity(); method public android.content.Intent getIntentForSetupActivity(); + method public java.lang.String getParentId(); method public android.content.pm.ServiceInfo getServiceInfo(); method public int getType(); method public android.graphics.drawable.Drawable loadIcon(android.content.pm.PackageManager); diff --git a/media/java/android/media/tv/TvInputInfo.java b/media/java/android/media/tv/TvInputInfo.java index 5624f3e..cfed976 100644 --- a/media/java/android/media/tv/TvInputInfo.java +++ b/media/java/android/media/tv/TvInputInfo.java @@ -76,6 +76,7 @@ public final class TvInputInfo implements Parcelable { private final ResolveInfo mService; private final String mId; + private final String mParentId; // Attributes from XML meta data. private String mSetupActivity; @@ -114,7 +115,7 @@ public final class TvInputInfo implements Parcelable { "Meta-data does not start with tv-input-service tag in " + si.name); } - TvInputInfo input = new TvInputInfo(context, service); + TvInputInfo input = new TvInputInfo(context, service, null); TypedArray sa = res.obtainAttributes(attrs, com.android.internal.R.styleable.TvInputService); input.mSetupActivity = sa.getString( @@ -154,10 +155,11 @@ public final class TvInputInfo implements Parcelable { * @param service The ResolveInfo returned from the package manager about this TV input service. * @hide */ - private TvInputInfo(Context context, ResolveInfo service) { + private TvInputInfo(Context context, ResolveInfo service, String parentId) { mService = service; ServiceInfo si = service.serviceInfo; mId = generateInputIdForComponentName(new ComponentName(si.packageName, si.name)); + mParentId = parentId; } /** @@ -169,6 +171,24 @@ public final class TvInputInfo implements Parcelable { } /** + * Returns the parent input ID. + * <p> + * When a part of the functionalities of a TV input is actually provided by another TV input, + * we can describe this relationship as the depending input having a "parent". It is primarily + * used for controlling underlying hardware when the current input itself does not have direct + * access to it. Examples include a TV input for a specific HDMI CEC logical device having a + * generic HDMI input as its parent and a HDMI-paired virtual input whose video stream comes + * from an external settop box. Applications may group inputs by parent ID to provide an easier + * access to similar inputs. + * + * @return the ID of the parent input, if exists. Returns {@code null} if the parent input is + * not specified. + */ + public String getParentId() { + return mParentId; + } + + /** * Returns the information of the service that implements this TV input. */ public ServiceInfo getServiceInfo() { @@ -260,9 +280,7 @@ public final class TvInputInfo implements Parcelable { } TvInputInfo obj = (TvInputInfo) o; - return mId.equals(obj.mId) - && mService.serviceInfo.packageName.equals(obj.mService.serviceInfo.packageName) - && mService.serviceInfo.name.equals(obj.mService.serviceInfo.name); + return mId.equals(obj.mId); } @Override @@ -281,9 +299,11 @@ public final class TvInputInfo implements Parcelable { @Override public void writeToParcel(Parcel dest, int flags) { dest.writeString(mId); + dest.writeString(mParentId); mService.writeToParcel(dest, flags); dest.writeString(mSetupActivity); dest.writeString(mSettingsActivity); + dest.writeInt(mType); } /** @@ -317,8 +337,10 @@ public final class TvInputInfo implements Parcelable { private TvInputInfo(Parcel in) { mId = in.readString(); + mParentId = in.readString(); mService = ResolveInfo.CREATOR.createFromParcel(in); mSetupActivity = in.readString(); mSettingsActivity = in.readString(); + mType = in.readInt(); } } |