summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJi-Hwan Lee <jihwan@google.com>2014-07-16 23:13:03 +0900
committerJi-Hwan Lee <jihwan@google.com>2014-07-17 14:40:31 +0900
commit66bdf247df7b53130a01efe33419e0ce276e5f43 (patch)
treeb191b9a80b59219450baa0610f9b1390cd2b5164
parent2883ba69751de69811a38f086ecbe4c2032ca87d (diff)
downloadframeworks_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.txt1
-rw-r--r--media/java/android/media/tv/TvInputInfo.java32
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();
}
}