美文网首页
MediaBrowserServiceCompat

MediaBrowserServiceCompat

作者: 济公大将 | 来源:发表于2022-04-10 13:38 被阅读0次

    public abstract class MediaBrowserServiceCompat
    extends Service

    java.lang.Object
      ↳ android.content.Context
        ↳ android.content.ContextWrapper
          ↳ android.app.Service
           ↳ |androidx.media.MediaBrowserServiceCompat


    媒体浏览服务的基类。

    媒体浏览服务使应用程序能够浏览应用程序提供的媒体内容,并要求应用程序开始播放它。它们也可以用来控制已经通过 MediaSessionCompat播放的内容。

    要扩展这个类,您必须在清单文件中使用 SERVICE_INTERFACE 动作的意图过滤器声明该服务。例如:

    <service android:name=".MyMediaBrowserServiceCompat"
              android:label="@string/service_name" >
         <intent-filter>
             <action android:name="android.media.browse.MediaBrowserService" />
         </intent-filter>
     </service>
    

    Public methods

    dump

    public void dump (FileDescriptor fd,
                  PrintWriter writer,
                  String[] args)

    getBrowserRootHints

    public final Bundle getBrowserRootHints ()

    获取从当前连接的MediaBrowserCompat发送的根提示。根提示是服务特定的参数,包含在一个可选的bundle中,在连接和检索浏览的根id时发送给媒体浏览器服务,如果没有,则为空。此包的内容可能会影响浏览时返回的信息。

    请注意,当连接到MediaBrowser并运行在API 23或更低的API时,将返回null。

    如果这个方法在onLoadChildren(String, MediaBrowserServiceCompat.Result>)onLoadItem(String, MediaBrowserServiceCompat.Result)onSearch(String, Bundle, MediaBrowserServiceCompat.Result>)之外被调用,将Throws IllegalStateException

    getCurrentBrowserInfo

    public final MediaSessionManager.RemoteUserInfo getCurrentBrowserInfo ()

    获取发送当前请求的浏览器信息。

    如果这个方法在onGetRoot(String, int, Bundle)onLoadChildren(String, MediaBrowserServiceCompat.Result>)onLoadItem(String, MediaBrowserServiceCompat.Result)之外被调用,将Throws IllegalStateException

    getSessionToken

    public MediaSessionCompat.Token getSessionToken ()

    获取会话令牌,如果尚未创建或已销毁该令牌,则为空。

    notifyChildrenChanged

    public void notifyChildrenChanged (String parentId,Bundle options)

    通知所有连接的媒体浏览器,指定的父id的子浏览器已以某种方式更改。这将导致浏览器再次获取订阅内容。

    Parameters Description
    parentId String:其子项已更改的父媒体项的id。
    options Bundle:发送到媒体浏览的特定于服务的参数包。这个bundle的内容可能包含关于更改的信息。

    onCustomAction

    public void onCustomAction (String action,
                 Bundle extras,
                 Result<Bundle> result)

    调用该函数来请求此服务的自定义操作。

    实现必须调用MediaBrowserServiceCompat.Result.sendResult(T)MediaBrowserServiceCompat.Result.sendError(Bundle)。如果请求的自定义操作将是一个开销很大的操作,则可以在从这个函数返回之前调用MediaBrowserServiceCompat . Result .detach(),然后服务可以在自定义操作完成之后发送结果。实现还可以调用MediaBrowSerserviceCompatt. Result . sendprogressupdate (Bundle)向请求者发送一个临时更新。

    如果请求的自定义操作不被该服务支持,则调用MediaBrowserServiceCompat . Result . senderror (Bundle)。默认实现将调用MediaBrowserServiceCompat . Result . senderror (Bundle)

    Parameters Description
    action String:从媒体浏览器发送的自定义操作。
    extras Bundle:从媒体浏览器发送的特定于服务的参数包。
    result Result:The MediaBrowserServiceCompat.Result 发送所请求的自定义操作的结果。

    参见:
    MediaBrowserCompat.CUSTOM_ACTION_DOWNLOAD
    MediaBrowserCompat.CUSTOM_ACTION_REMOVE_DOWNLOADED_FILE

    onGetRoot

    public abstractMediaBrowserServiceCompat.BrowserRoot onGetRoot (
                 String clientPackageName,
                 int clientUid,
                 Bundle rootHints)

    调用该函数以获得用于特定客户机浏览的根信息。

    在返回根id之前,实现应该验证客户端包有访问浏览媒体信息的权限;如果不允许客户端访问此信息,则返回null。

    Parameters Description
    clientPackageName String:请求访问浏览媒体的应用程序的包名。
    clientUid int:请求访问浏览媒体的应用程序的uid。
    rootHints Bundle:一个可选的服务特定参数包,在连接和获取浏览的根id时发送给媒体浏览服务,如果没有则为空。此包的内容可能会影响浏览时返回的信息。

    参见:
    MediaBrowserServiceCompat.BrowserRoot.EXTRA_RECENT
    MediaBrowserServiceCompat.BrowserRoot.EXTRA_OFFLINE
    MediaBrowserServiceCompat.BrowserRoot.EXTRA_SUGGESTED

    onLoadChildren

    public void onLoadChildren (
                 String parentId,
                 Result<List<MediaBrowserCompat.MediaItem>> result,
                 Bundle options)

    调用该函数以获取有关媒体项的子项的信息。

    实现必须调用result.sendResult的子列表。如果加载子函数是一个开销很大的操作,应该在另一个线程上执行,那么可以在从这个函数返回之前调用result.detach,加载完成时再调用resulut.sendResult

    如果媒体项没有任何子项,调用MediaBrowserServiceCompat.Result.sendresult (T)以一个空列表。当给定的parentId无效时,实现必须调用result.sendResult与null,这将调用MediaBrowserCompat.SubscriptionCallback.onError(String)。

    Parameters Description
    parentId String:要查询其子媒体项的父媒体项的id。
    result Result:发送查询的子集。
    options Bundle:从媒体浏览中发送的特定于服务的参数包。通过结果返回的信息应该受到这个bundle的内容的影响。

    onLoadItem

    public void onLoadItem (
                 String itemId,
                 Result<MediaBrowserCompat.MediaItem> result)

    调用该函数以获取有关特定媒体项的信息。

    实现必须调【result.sendResult。如果加载项将是一个开销很大的操作result.detach可能会在从这个函数返回之前被调用,当项目被加载时调用result.sendResult

    当给定的itemId无效时,实现必须调用result.sendResult null。

    默认实现将调用MediaBrowserCompat.ItemCallback.onError(String)

    Parameters Description
    itemId String:特定MediaBrowserCompart.MediaiIem的id。
    result Result:要将项目发送到的Result,如果id无效则为空。

    onSearch

    public void onSearch (
                 String query,
                 Bundle extras,
                 Result<List<MediaBrowserCompat.MediaItem>> result)

    调用来获取搜索结果。

    实现必须调用result.sendResult的子列表。如果加载子函数是一个开销很大的操作,应该在另一个线程上执行,那么可以在从这个函数返回之前调用result.detach,加载完成时再调用resulut.sendResult

    如果没有搜索结果,调用result.sendResult空列表的。如果有一些错误发生,调用结果。result.sendResult(null),这将调用MediaBrowserCompat.SearchCallback.onError()

    默认实现将调用MediaBrowserCompat.SearchCallback.onError()

    Parameters Description
    query String:从媒体浏览器发送的搜索查询。它包含用空格分隔的关键字。
    extras Bundle:从媒体浏览器发送的特定于服务的参数包。
    result Result:MediaBrowserServiceCompat.Result发送搜索结果。

    setSessionToken

    public void setSessionToken (MediaSessionCompat.Token token)

    设置媒体会话。

    应该在服务启动期间尽快调用。它可能只被调用一次。

    Parameters Description
    token MediaSessionCompat.Token: 服务的MediaSessionCompat的令牌。

    相关文章

      网友评论

          本文标题:MediaBrowserServiceCompat

          本文链接:https://www.haomeiwen.com/subject/rnrvsrtx.html