如何在播放器播放时将 Exo 播放器添加到 Android 通知状态栏

问题描述 投票:0回答:1

我有一个 MediaPlayerActivity.kt

package com.media.apps

import android.content.Intent
import android.os.Bundle
import android.widget.ImageButton
import android.widget.ImageView
import androidx.appcompat.app.AppCompatActivity
import tz.co.smartcodes.mpaper.R
import tz.co.smartcodes.mpaper.services.MediaPlayerService

class MediaPlayerHelper : AppCompatActivity() {
    private var isMediaPlaying = false
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.audio_player)

        val playButton = findViewById<ImageView>(R.id.btnPause)
        val pauseButton = findViewById<ImageButton>(R.id.btnVolume)

        if (!isMediaPlaying) {
            val mediaUrl = MEDIA_URL

            val intent = Intent(this@MediaPlayerHelper, MediaPlayerService::class.java)
            intent.putExtra("media_url", mediaUrl)
            startService(intent)
            isMediaPlaying = true
            playButton.setImageResource(R.drawable.baseline_pause_circle_48)
        }

        pauseButton.setOnClickListener {
            if (isMediaPlaying) {
                val intent = Intent(this@MediaPlayerHelper, MediaPlayerService::class.java)
                stopService(intent)
                isMediaPlaying = true
            }
        }
    }

    companion object {
        val MEDIA_URL =
            "https://mpaper.s3.us-west-2.amazonaws.com/stories/story_118_90207270-2aca-11ee-806a-757cf48e4d1c.mp3"
    }
}

我有一个带有以下代码的 MediaPlayerService.kt

package com.media.apps

import android.app.Service
import android.content.Intent
import android.os.IBinder
import androidx.media3.common.MediaItem
import androidx.media3.datasource.DefaultDataSource
import androidx.media3.exoplayer.ExoPlayer
import androidx.media3.exoplayer.source.ProgressiveMediaSource
import androidx.media3.exoplayer.trackselection.DefaultTrackSelector


class MediaPlayerService : Service() {

    private var player: ExoPlayer? = null

    override fun onBind(intent: Intent?): IBinder? {
        return null
    }

    override fun onStartCommand(intent: Intent?, flags: Int, startId: Int): Int {
        super.onStartCommand(intent, flags, startId)
        val mediaUrl = intent?.getStringExtra("media_url")
        if (mediaUrl != null) {
            playerMedia(mediaUrl)
        }
        return START_STICKY
    }


    private fun playerMedia(mediaUrl: String) {
        releasePlayer()
        player = ExoPlayer.Builder(this)
            .setTrackSelector(DefaultTrackSelector(this))
            .build()
        val mediaItem = MediaItem.fromUri(mediaUrl)
        val mediaSource = ProgressiveMediaSource.Factory(
            DefaultDataSource.Factory(this)
        ).createMediaSource(mediaItem)
        player?.setMediaSource(mediaSource)
        player?.prepare()
        player?.playWhenReady = true
    }

    private fun releasePlayer() {
        player?.release()
        player = null
    }

    override fun onDestroy() {
        super.onDestroy()
        releasePlayer()
    }

}

AndroidManifest.xml

 <service android:name=".services.MediaPlayerService"/>

xml布局

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:id="@+id/bottomSheet"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:background="@color/white_black"
    android:gravity="top"
    android:orientation="vertical"
    android:paddingHorizontal="16dp"
    app:behavior_hideable="true"
    app:behavior_peekHeight="0dp"
    app:layout_behavior="com.google.android.material.bottomsheet.BottomSheetBehavior">

    <TextView
        android:id="@+id/storyName"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_marginHorizontal="@dimen/size_20"
        android:layout_marginTop="@dimen/size_4"
        android:ellipsize="marquee"
        android:focusable="true"
        android:focusableInTouchMode="true"
        android:gravity="center"
        android:scrollbars="horizontal"
        android:scrollHorizontally="true"
        android:singleLine="true"
        android:text=""
        android:textColor="@color/black_white"
        android:textSize="14sp"
        android:textStyle="bold" />

    <TextView
        android:id="@+id/channelName"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_marginHorizontal="@dimen/size_20"
        android:layout_marginTop="@dimen/size_4"
        android:layout_marginBottom="@dimen/size_12"
        android:gravity="center"
        android:maxLines="1"
        android:text=""
        android:textColor="@color/rifary_input"
        android:textSize="12sp"
        android:textStyle="normal" />

    <SeekBar
        android:id="@+id/seekBar"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_above="@+id/btnBackward"
        android:layout_marginTop="@dimen/size_4"
        android:layout_toStartOf="@+id/txtSongTime"
        android:layout_toEndOf="@+id/txtStartTime"
        android:paddingVertical="@dimen/size_4"
        android:theme="@style/Progress_color" />

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_marginHorizontal="@dimen/size_20"
        android:layout_marginBottom="@dimen/size_4"
        android:orientation="horizontal"
        android:weightSum="2">

        <TextView
            android:id="@+id/txtStartTime"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_alignTop="@+id/seekBar"
            android:layout_weight="1"
            android:text="0 : 0 " />

        <TextView
            android:id="@+id/txtSongTime"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_alignTop="@+id/seekBar"
            android:layout_toEndOf="@+id/btnForward"
            android:layout_weight="1"
            android:gravity="right"
            android:text="0 : 0  " />
    </LinearLayout>

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:paddingVertical="@dimen/size_12"
        android:orientation="horizontal"
        android:weightSum="5">

        <ImageButton
            android:id="@+id/btnVolume"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_gravity="center_vertical"
            android:layout_weight="1"
            android:background="@android:color/transparent"
            app:srcCompat="@drawable/ic_volume_up" />

        <ImageButton
            android:id="@+id/btnBackward"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_gravity="center"
            android:layout_weight="1"
            android:background="@android:color/transparent"
            app:srcCompat="@drawable/ic_arrow___left_circle"
            android:layout_marginHorizontal="@dimen/size_8" />

        <LinearLayout
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_gravity="center_vertical"
            android:layout_weight="1"
            android:gravity="center"
            android:orientation="vertical"
            android:layout_marginHorizontal="@dimen/size_16">

            <LinearLayout
                android:id="@+id/btnPlay"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_gravity="center"
                android:background="@android:color/transparent"
                android:gravity="center"
                android:visibility="visible">

                <ImageView
                    android:id="@+id/btnPause"
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    app:layout_constraintBottom_toBottomOf="parent"
                    app:layout_constraintLeft_toLeftOf="parent"
                    app:layout_constraintRight_toRightOf="parent"
                    app:layout_constraintTop_toTopOf="parent"
                    android:src="@drawable/baseline_play_circle_48"
                    android:contentDescription="@string/play_now" />
            </LinearLayout>

            <LinearLayout
                android:id="@+id/spinner_loader"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_gravity="center">

                <ProgressBar
                    style="?android:attr/progressBarStyle"
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:layout_gravity="center"
                    android:indeterminateTint="@color/rifaly_green"
                    app:layout_constraintBottom_toBottomOf="parent"
                    app:layout_constraintLeft_toLeftOf="parent"
                    app:layout_constraintRight_toRightOf="parent"
                    app:layout_constraintTop_toTopOf="parent" />
            </LinearLayout>
        </LinearLayout>

        <ImageButton
            android:id="@+id/btnForward"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_gravity="center"
            android:layout_weight="1"
            android:background="@android:color/transparent"
            android:contentDescription="@+id/imageButton3"
            app:srcCompat="@drawable/ic_arrow___right_circle"
            android:layout_marginHorizontal="@dimen/size_8"/>

        <ImageButton
            android:id="@+id/btnShare"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_gravity="center"
            android:layout_weight="1"
            android:background="@android:color/transparent"
            android:contentDescription="@+id/imageButton3"
            app:srcCompat="@drawable/ic_share" />
    </LinearLayout>

</LinearLayout>

到目前为止我尝试的是添加一个前台函数,该函数创建一个通知管理器,在 onStartCommand 中调用播放、暂停和关闭,我已将其删除,因为它不起作用

播放器工作正常,可以打开音频。我找不到实现这个东西的方法,任何帮助将不胜感激

android kotlin exoplayer
1个回答
0
投票

通知

MediaSessionService 会自动为您创建一个在大多数情况下都适用的 MediaNotification。默认情况下,发布的通知是 MediaStyle 通知,它会使用媒体会话中的最新信息进行更新并显示播放控件。 MediaNotificationThe 知道您的会话,并可用于控制连接到同一会话的任何其他应用程序的播放。

例如,使用 MediaSessionService 的音乐流应用程序将创建一个 MediaNotification,根据 MediaSession 配置显示当前正在播放的歌曲的标题、艺术家和专辑封面以及播放控件。

要提供自定义通知,请使用 DefaultMediaNotificationProvider.Builder 创建 MediaNotification.Provider 或创建提供程序接口的自定义实现。使用 setMediaNotificationProvider 将您的提供商添加到您的 MediaSession。

https://developer.android.com/guide/topics/media/session/mediasessionservice

© www.soinside.com 2019 - 2024. All rights reserved.