TvContract
public
final
class
TvContract
extends Object
java.lang.Object | |
↳ | android.media.tv.TvContract |
The contract between the TV provider and applications. Contains definitions for the supported URIs and columns.
Overview
TvContract defines a basic database of TV content metadata such as channel and program
information. The information is stored in Channels
and Programs
tables.
- A row in the
Channels
table represents information about a TV channel. The data format can vary greatly from standard to standard or according to service provider, thus the columns here are mostly comprised of basic entities that are usually seen to users regardless of standard such as channel number and name. - A row in the
Programs
table represents a set of data describing a TV program such as program title and start time.
Summary
Nested classes | |
---|---|
interface |
TvContract.BaseTvColumns
Common base for the tables of TV channels/programs. |
class |
TvContract.Channels
Column definitions for the TV channels table. |
class |
TvContract.PreviewPrograms
Column definitions for the preview TV programs table. |
class |
TvContract.Programs
Column definitions for the TV programs table. |
class |
TvContract.RecordedPrograms
Column definitions for the recorded TV programs table. |
class |
TvContract.WatchNextPrograms
Column definitions for the "watch next" TV programs table. |
Constants | |
---|---|
String |
ACTION_INITIALIZE_PROGRAMS
Broadcast Action: sent to the target TV input after it is first installed to notify the input to initialize its channels and programs to the system content provider. |
String |
ACTION_PREVIEW_PROGRAM_ADDED_TO_WATCH_NEXT
Broadcast Action: sent by the system to tell the target TV input that one of its existing preview programs is added to the watch next programs table by user. |
String |
ACTION_PREVIEW_PROGRAM_BROWSABLE_DISABLED
Broadcast Action: sent by the system to tell the target TV input that one of its preview program's browsable state is disabled, i.e., it will no longer be shown to users, which, for example, might be a result of users' interaction with UI. |
String |
ACTION_REQUEST_CHANNEL_BROWSABLE
Activity Action: sent by an application telling the system to make the given channel browsable with user interaction. |
String |
ACTION_WATCH_NEXT_PROGRAM_BROWSABLE_DISABLED
Broadcast Action: sent by the system to tell the target TV input that one of its "watch next" program's browsable state is disabled, i.e., it will no longer be shown to users, which, for example, might be a result of users' interaction with UI. |
String |
AUTHORITY
The authority for the TV provider. |
String |
EXTRA_CHANNEL_ID
The key for a bundle parameter containing a channel ID as a long integer |
String |
EXTRA_PREVIEW_PROGRAM_ID
The key for a bundle parameter containing a program ID as a long integer. |
String |
EXTRA_WATCH_NEXT_PROGRAM_ID
The key for a bundle parameter containing a watch next program ID as a long integer. |
Public methods | |
---|---|
static
Uri
|
buildChannelLogoUri(Uri channelUri)
Builds a URI that points to a channel logo. |
static
Uri
|
buildChannelLogoUri(long channelId)
Builds a URI that points to a channel logo. |
static
Uri
|
buildChannelUri(long channelId)
Builds a URI that points to a specific channel. |
static
Uri
|
buildChannelUriForPassthroughInput(String inputId)
Build a special channel URI intended to be used with pass-through inputs. |
static
Uri
|
buildChannelsUriForInput(String inputId)
Builds a URI that points to all channels from a given TV input. |
static
String
|
buildInputId(ComponentName name)
Builds an ID that uniquely identifies a TV input service. |
static
Uri
|
buildPreviewProgramUri(long previewProgramId)
Builds a URI that points to a specific preview program. |
static
Uri
|
buildPreviewProgramsUriForChannel(Uri channelUri)
Builds a URI that points to all preview programs on a given channel. |
static
Uri
|
buildPreviewProgramsUriForChannel(long channelId)
Builds a URI that points to all preview programs on a given channel. |
static
Uri
|
buildProgramUri(long programId)
Builds a URI that points to a specific program. |
static
Uri
|
buildProgramsUriForChannel(long channelId, long startTime, long endTime)
Builds a URI that points to programs on a specific channel whose schedules overlap with the given time frame. |
static
Uri
|
buildProgramsUriForChannel(long channelId)
Builds a URI that points to all programs on a given channel. |
static
Uri
|
buildProgramsUriForChannel(Uri channelUri)
Builds a URI that points to all programs on a given channel. |
static
Uri
|
buildProgramsUriForChannel(Uri channelUri, long startTime, long endTime)
Builds a URI that points to programs on a specific channel whose schedules overlap with the given time frame. |
static
Uri
|
buildRecordedProgramUri(long recordedProgramId)
Builds a URI that points to a specific recorded program. |
static
Uri
|
buildWatchNextProgramUri(long watchNextProgramId)
Builds a URI that points to a specific watch next program. |
static
boolean
|
isChannelUri(Uri uri)
|
static
boolean
|
isChannelUriForPassthroughInput(Uri uri)
|
static
boolean
|
isChannelUriForTunerInput(Uri uri)
|
static
boolean
|
isProgramUri(Uri uri)
|
static
boolean
|
isRecordedProgramUri(Uri uri)
|
static
void
|
requestChannelBrowsable(Context context, long channelId)
Requests to make a channel browsable. |
Inherited methods | |
---|---|
Constants
ACTION_INITIALIZE_PROGRAMS
public static final String ACTION_INITIALIZE_PROGRAMS
Broadcast Action: sent to the target TV input after it is first installed to notify the input to initialize its channels and programs to the system content provider.
Note that this intent is sent only on devices with
PackageManager.FEATURE_LEANBACK
enabled. Besides that, in order
to receive this intent, the target TV input must:
- Declare a broadcast receiver for this intent in its
AndroidManifest.xml
. - Declare appropriate permissions to write channel and program data in its
AndroidManifest.xml
.
Constant Value: "android.media.tv.action.INITIALIZE_PROGRAMS"
ACTION_PREVIEW_PROGRAM_ADDED_TO_WATCH_NEXT
public static final String ACTION_PREVIEW_PROGRAM_ADDED_TO_WATCH_NEXT
Broadcast Action: sent by the system to tell the target TV input that one of its existing preview programs is added to the watch next programs table by user.
The intent must contain the following bundle parameters:
EXTRA_PREVIEW_PROGRAM_ID
: the ID of the existing preview program.EXTRA_WATCH_NEXT_PROGRAM_ID
: the ID of the new watch next program.
Constant Value: "android.media.tv.action.PREVIEW_PROGRAM_ADDED_TO_WATCH_NEXT"
ACTION_PREVIEW_PROGRAM_BROWSABLE_DISABLED
public static final String ACTION_PREVIEW_PROGRAM_BROWSABLE_DISABLED
Broadcast Action: sent by the system to tell the target TV input that one of its preview program's browsable state is disabled, i.e., it will no longer be shown to users, which, for example, might be a result of users' interaction with UI. The input is expected to delete the preview program from the content provider.
The intent must contain the following bundle parameter:
EXTRA_PREVIEW_PROGRAM_ID
: the disabled preview program ID.
Constant Value: "android.media.tv.action.PREVIEW_PROGRAM_BROWSABLE_DISABLED"
ACTION_REQUEST_CHANNEL_BROWSABLE
public static final String ACTION_REQUEST_CHANNEL_BROWSABLE
Activity Action: sent by an application telling the system to make the given channel
browsable with user interaction. The system may show UI to ask user to approve the channel.
This is only relevant to channels with Channels.TYPE_PREVIEW
type. Use
Activity.startActivityForResult
to get the result of the request.
The intent must contain the following bundle parameters:
EXTRA_CHANNEL_ID
: ID for theChannels.TYPE_PREVIEW
channel as a long integer.
Constant Value: "android.media.tv.action.REQUEST_CHANNEL_BROWSABLE"
ACTION_WATCH_NEXT_PROGRAM_BROWSABLE_DISABLED
public static final String ACTION_WATCH_NEXT_PROGRAM_BROWSABLE_DISABLED
Broadcast Action: sent by the system to tell the target TV input that one of its "watch next" program's browsable state is disabled, i.e., it will no longer be shown to users, which, for example, might be a result of users' interaction with UI. The input is expected to delete the "watch next" program from the content provider.
The intent must contain the following bundle parameter:
EXTRA_WATCH_NEXT_PROGRAM_ID
: the disabled "watch next" program ID.
Constant Value: "android.media.tv.action.WATCH_NEXT_PROGRAM_BROWSABLE_DISABLED"
AUTHORITY
public static final String AUTHORITY
The authority for the TV provider.
Constant Value: "android.media.tv"
EXTRA_CHANNEL_ID
public static final String EXTRA_CHANNEL_ID
The key for a bundle parameter containing a channel ID as a long integer
Constant Value: "android.media.tv.extra.CHANNEL_ID"
EXTRA_PREVIEW_PROGRAM_ID
public static final String EXTRA_PREVIEW_PROGRAM_ID
The key for a bundle parameter containing a program ID as a long integer.
Constant Value: "android.media.tv.extra.PREVIEW_PROGRAM_ID"
EXTRA_WATCH_NEXT_PROGRAM_ID
public static final String EXTRA_WATCH_NEXT_PROGRAM_ID
The key for a bundle parameter containing a watch next program ID as a long integer.
Constant Value: "android.media.tv.extra.WATCH_NEXT_PROGRAM_ID"
Public methods
buildChannelLogoUri
public static Uri buildChannelLogoUri (Uri channelUri)
Builds a URI that points to a channel logo. See Channels.Logo
.
Parameters | |
---|---|
channelUri |
Uri : The URI of the channel whose logo is pointed to. |
Returns | |
---|---|
Uri |
buildChannelLogoUri
public static Uri buildChannelLogoUri (long channelId)
Builds a URI that points to a channel logo. See Channels.Logo
.
Parameters | |
---|---|
channelId |
long : The ID of the channel whose logo is pointed to. |
Returns | |
---|---|
Uri |
buildChannelUri
public static Uri buildChannelUri (long channelId)
Builds a URI that points to a specific channel.
Parameters | |
---|---|
channelId |
long : The ID of the channel to point to. |
Returns | |
---|---|
Uri |
buildChannelUriForPassthroughInput
public static Uri buildChannelUriForPassthroughInput (String inputId)
Build a special channel URI intended to be used with pass-through inputs. (e.g. HDMI)
Parameters | |
---|---|
inputId |
String : The ID of the pass-through input to build a channels URI for. |
Returns | |
---|---|
Uri |
See also:
buildChannelsUriForInput
public static Uri buildChannelsUriForInput (String inputId)
Builds a URI that points to all channels from a given TV input.
Parameters | |
---|---|
inputId |
String : The ID of the TV input to build a channels URI for. If null , builds a
URI for all the TV inputs. |
Returns | |
---|---|
Uri |
buildInputId
public static String buildInputId (ComponentName name)
Builds an ID that uniquely identifies a TV input service.
Parameters | |
---|---|
name |
ComponentName : The ComponentName of the TV input service to build ID for. |
Returns | |
---|---|
String |
the ID for the given TV input service. |
buildPreviewProgramUri
public static Uri buildPreviewProgramUri (long previewProgramId)
Builds a URI that points to a specific preview program.
Parameters | |
---|---|
previewProgramId |
long : The ID of the preview program to point to. |
Returns | |
---|---|
Uri |
buildPreviewProgramsUriForChannel
public static Uri buildPreviewProgramsUriForChannel (Uri channelUri)
Builds a URI that points to all preview programs on a given channel.
Parameters | |
---|---|
channelUri |
Uri : The URI of the channel to return preview programs for. |
Returns | |
---|---|
Uri |
buildPreviewProgramsUriForChannel
public static Uri buildPreviewProgramsUriForChannel (long channelId)
Builds a URI that points to all preview programs on a given channel.
Parameters | |
---|---|
channelId |
long : The ID of the channel to return preview programs for. |
Returns | |
---|---|
Uri |
buildProgramUri
public static Uri buildProgramUri (long programId)
Builds a URI that points to a specific program.
Parameters | |
---|---|
programId |
long : The ID of the program to point to. |
Returns | |
---|---|
Uri |
buildProgramsUriForChannel
public static Uri buildProgramsUriForChannel (long channelId, long startTime, long endTime)
Builds a URI that points to programs on a specific channel whose schedules overlap with the given time frame.
Parameters | |
---|---|
channelId |
long : The ID of the channel to return programs for. |
startTime |
long : The start time used to filter programs. The returned programs will have a
Programs.COLUMN_END_TIME_UTC_MILLIS that is greater than or equal to
startTime . |
endTime |
long : The end time used to filter programs. The returned programs will have
Programs.COLUMN_START_TIME_UTC_MILLIS that is less than or equal to
endTime . |
Returns | |
---|---|
Uri |
buildProgramsUriForChannel
public static Uri buildProgramsUriForChannel (long channelId)
Builds a URI that points to all programs on a given channel.
Parameters | |
---|---|
channelId |
long : The ID of the channel to return programs for. |
Returns | |
---|---|
Uri |
buildProgramsUriForChannel
public static Uri buildProgramsUriForChannel (Uri channelUri)
Builds a URI that points to all programs on a given channel.
Parameters | |
---|---|
channelUri |
Uri : The URI of the channel to return programs for. |
Returns | |
---|---|
Uri |
buildProgramsUriForChannel
public static Uri buildProgramsUriForChannel (Uri channelUri, long startTime, long endTime)
Builds a URI that points to programs on a specific channel whose schedules overlap with the given time frame.
Parameters | |
---|---|
channelUri |
Uri : The URI of the channel to return programs for. |
startTime |
long : The start time used to filter programs. The returned programs should have
Programs.COLUMN_END_TIME_UTC_MILLIS that is greater than this time. |
endTime |
long : The end time used to filter programs. The returned programs should have
Programs.COLUMN_START_TIME_UTC_MILLIS that is less than this time. |
Returns | |
---|---|
Uri |
buildRecordedProgramUri
public static Uri buildRecordedProgramUri (long recordedProgramId)
Builds a URI that points to a specific recorded program.
Parameters | |
---|---|
recordedProgramId |
long : The ID of the recorded program to point to. |
Returns | |
---|---|
Uri |
buildWatchNextProgramUri
public static Uri buildWatchNextProgramUri (long watchNextProgramId)
Builds a URI that points to a specific watch next program.
Parameters | |
---|---|
watchNextProgramId |
long : The ID of the watch next program to point to. |
Returns | |
---|---|
Uri |
isChannelUri
public static boolean isChannelUri (Uri uri)
Parameters | |
---|---|
uri |
Uri : This value cannot be null . |
Returns | |
---|---|
boolean |
true if uri is a channel URI. |
isChannelUriForPassthroughInput
public static boolean isChannelUriForPassthroughInput (Uri uri)
Parameters | |
---|---|
uri |
Uri : This value cannot be null . |
Returns | |
---|---|
boolean |
true if uri is a channel URI for a pass-through input. |
isChannelUriForTunerInput
public static boolean isChannelUriForTunerInput (Uri uri)
Parameters | |
---|---|
uri |
Uri : This value cannot be null . |
Returns | |
---|---|
boolean |
true if uri is a channel URI for a tuner input. |
isProgramUri
public static boolean isProgramUri (Uri uri)
Parameters | |
---|---|
uri |
Uri : This value cannot be null . |
Returns | |
---|---|
boolean |
true if uri is a program URI. |
isRecordedProgramUri
public static boolean isRecordedProgramUri (Uri uri)
Parameters | |
---|---|
uri |
Uri : This value cannot be null . |
Returns | |
---|---|
boolean |
true if uri is a recorded program URI. |
requestChannelBrowsable
public static void requestChannelBrowsable (Context context, long channelId)
Requests to make a channel browsable.
Once called, the system will review the request and make the channel browsable based on
its policy. The first request from a package is guaranteed to be approved. This is only
relevant to channels with Channels.TYPE_PREVIEW
type.
Parameters | |
---|---|
context |
Context : The context for accessing content provider. |
channelId |
long : The channel ID to be browsable. |
See also:
Content and code samples on this page are subject to the licenses described in the Content License. Java and OpenJDK are trademarks or registered trademarks of Oracle and/or its affiliates.
Last updated 2025-01-23 UTC.