首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Android Notification.MediaStyle不响应MediaSession更新

Android Notification.MediaStyle不响应MediaSession更新
EN

Stack Overflow用户
提问于 2015-01-24 10:54:09
回答 1查看 3.4K关注 0票数 2

根据Notification.MediaStyle文档,将MediaSession.Token附加到给定的MediaStyle应该将其连接到关联的MediaSession对象。

引述如下:

最后,如果使用MediaSession.Token (setMediaSession,MediaSession.Token)附加一个MediaSession.Token,系统UI可以将其标识为表示活动媒体会话的通知,并相应地作出响应(例如,在锁屏中显示相册艺术品)。

然后,文档将在通知中给出使用MediaStyle的代码片段,如下所示:

代码语言:javascript
复制
Notification noti = new Notification.Builder()
    .setSmallIcon(R.drawable.ic_stat_player)
    .setContentTitle("Track title")     // these three lines are optional
    .setContentText("Artist - Album")   // if you use
    .setLargeIcon(albumArtBitmap))      // setMediaSession(token)
    .setStyle(new Notification.MediaStyle()
        .setMediaSession(mySession))
    .build();

显然(从单词可选的)声明,当与令牌对象(可能由MediaStyle实例自动填充)一起使用时,不必使用ContentTitle/ContentText参数。

在尝试将此MediaStyle实现到我目前正在构建的音乐播放器时,我注意到使用MediaStyle样式的通知根本没有被更新,尽管音乐播放器在整个过程中反复更新元数据和播放状态。唯一存在的是一个空白通知,其中包含通知的“小图标”,当视图被展开时,该通知将超出大图标的比例。

为了说明这个问题,我在下面创建了一个小型测试应用程序,其中包含两个按钮。一个按钮更新通知(用MediaStyle创建一个新的通知并发送给notification )。另一个按钮生成元数据和假播放状态来模拟播放。我注意到,无论我按了什么顺序的按钮组合,通知都不会按照我想要更新的样式进行更新。

下面表示表示我的测试用例的活动类。大多数是样板活动代码,最后两种方法updateNotification()updateState()都链接到两个按钮的onClick属性,并以OnClickListeners的形式提供方便。

代码语言:javascript
复制
public class MediaStyleTestActivity extends Activity {

    private MediaSession mSession;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_media_style_test);

        mSession = new MediaSession(this, "TestSession");
        mSession.setActive(true);
    }

    @Override
    protected void onDestroy() {
        super.onDestroy();

        mSession.release();
    }

    @Override
    public boolean onCreateOptionsMenu(Menu menu){
        // Inflate the menu; this adds items to the action bar if it is present.
        getMenuInflater().inflate(R.menu.menu_media_style_test, menu);
        return true;
    }

    @Override
    public boolean onOptionsItemSelected(MenuItem item) {
        // Handle action bar item clicks here. The action bar will
        // automatically handle clicks on the Home/Up button, so long
        // as you specify a parent activity in AndroidManifest.xml.
        int id = item.getItemId();

        //noinspection SimplifiableIfStatement
        if (id == R.id.action_settings) {
            return true;
        }

        return super.onOptionsItemSelected(item);
    }

    public void updateState(View v){
        MediaMetadata.Builder mMetaBuilder = new MediaMetadata.Builder();

        mMetaBuilder.putText(MediaMetadata.METADATA_KEY_TITLE, "Blue Jeans");
        mMetaBuilder.putText(MediaMetadata.METADATA_KEY_ALBUM, "Born to Die");
        mMetaBuilder.putText(MediaMetadata.METADATA_KEY_ARTIST, "Lana Del Rey");
        mMetaBuilder.putText(MediaMetadata.METADATA_KEY_ALBUM_ARTIST, "Lana Del Rey");
        mMetaBuilder.putLong(MediaMetadata.METADATA_KEY_TRACK_NUMBER, 3);
        mMetaBuilder.putLong(MediaMetadata.METADATA_KEY_NUM_TRACKS, 15);
        mMetaBuilder.putLong(MediaMetadata.METADATA_KEY_DISC_NUMBER, 1);

        Bitmap albumArt = BitmapFactory.decodeResource(getResources(), R.drawable.album_art);

        mMetaBuilder.putBitmap(MediaMetadata.METADATA_KEY_ALBUM_ART, albumArt);

        PlaybackState.Builder stateBuilder = new PlaybackState.Builder();

        stateBuilder.setActiveQueueItemId(MediaSession.QueueItem.UNKNOWN_ID);

        long actions = PlaybackState.ACTION_PLAY_PAUSE | PlaybackState.ACTION_STOP | PlaybackState.ACTION_SKIP_TO_NEXT | PlaybackState.ACTION_SKIP_TO_PREVIOUS;

        stateBuilder.setActions(actions);
        stateBuilder.setState(PlaybackState.STATE_PLAYING, 0, 1.0f);

        mSession.setMetadata(mMetaBuilder.build());
        mSession.setPlaybackState(stateBuilder.build());
    }

    public void updateNotification(View v){
        Notification.Builder nBuilder = new Notification.Builder(this);

        nBuilder.setOngoing(true);
        nBuilder.setShowWhen(false);
        nBuilder.setVisibility(Notification.VISIBILITY_PUBLIC);

        nBuilder.setSmallIcon(android.R.drawable.ic_media_play);
        nBuilder.setStyle(new Notification.MediaStyle().setMediaSession(mSession.getSessionToken()));

        NotificationManager notificationManager = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);

        notificationManager.notify(100, nBuilder.build());
    }
}

请忽略MediaSession的不当使用在这里,这只是为了演示目的。

我的设备上的应用程序:

我确实注意到,随着专辑艺术的发展,锁屏正在更新,但仅此而已:

如前所述,无论我尝试如何组合MediaSession/MediaStyle/Notification更新,似乎都不会导致通知的内容视图填充所提供的元数据(包括设置示例中未显示的有效MediaSession.QueueItem )。Logcat根本不显示任何东西,即使在冗长的情况下,通知也不会进行得很好或失败。

除非我错过了一些很明显的东西,否则我做错了什么?

作为附加信息,我是而不是,它使用任何用于通知和MediaSession的兼容性库。我的应用程序的这个组件仅用于API 21+,因此不需要向后兼容支持。

在我的生产代码中,实际的MediaSession保存在前台服务中,我尝试从各种线程(UI/ android使用的任何媒体线程/我自己的自定义线程)进行更新,但都没有效果。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-01-27 00:47:15

你说得对。从今天起,需要setContentTitlesetContextTextsetLargeIcon来显示通知标题、文本和图像。(正在处理的文件问题)

旁白:还请注意,您应该调用mediaSession.setActive(true)

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/28124708

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档