Я пытаюсь создать приложение для музыкального проигрывателя и сталкиваюсь с проблемой, когда пытаюсь воспроизвести другую песню, когда песня уже воспроизводится.Я хочу, чтобы мое приложение остановило воспроизведение уже запущенной песни и запустило новую.Я извлекаю детали песен как связку из класса адаптера в мой songPlayingFragment.Я пытался реализовать методы pause (), stop () и release ().Но никто из них не работал.Я полагал, что я реализовал их в неправильном разделе кода.Это мой код без реализации вышеупомянутых методов.Решение этого было бы очень полезно.Спасибо.
Код фрагмента воспроизведения песни
override fun onActivityCreated(savedInstanceState: Bundle?) {
super.onActivityCreated(savedInstanceState)
audioManager = myActivity?.getSystemService(Context.AUDIO_SERVICE) as AudioManager
favouriteContent = EchoDatabase(myActivity)
currentSongHelper = CurrentSongHelper()
currentSongHelper?.isPlaying = true
currentSongHelper?.isLoop = false
currentSongHelper?.isShuffle = false
var path:String?=null
var songTitle:String?=null
var songArtist:String?=null
var songId:Long = 0
try
{
path = arguments?.getString("path")
songTitle = arguments?.getString("songTitle")
songArtist = arguments?.getString("songArtist")
songId = arguments?.getInt("songId")?.toLong() as Long
currentPosition = arguments?.getInt("songPosition") as Int
fetchSongs = arguments?.getParcelableArrayList("songData")
currentSongHelper?.songPath = path
currentSongHelper?.songTitle = songTitle
currentSongHelper?.songArtist = songArtist
currentSongHelper?.songId = songId
currentSongHelper?.currentPosition = currentPosition
updateTextViews(currentSongHelper?.songTitle as String,currentSongHelper?.songArtist as String)
}
catch (e:Exception)
{e.printStackTrace()}
mediaPlayer = MediaPlayer()
mediaPlayer?.setAudioStreamType(AudioManager.STREAM_MUSIC)
try
{
mediaPlayer?.setDataSource(myActivity, Uri.parse(path))
mediaPlayer?.prepare()
}
catch(e:Exception)
{e.printStackTrace()}
mediaPlayer?.start()
processInformation(mediaPlayer as MediaPlayer)
if(currentSongHelper?.isPlaying as Boolean)
{
playPauseButton?.setBackgroundResource(R.drawable.pause_icon)
}
else
{
playPauseButton?.setBackgroundResource(R.drawable.play_icon)
}
mediaPlayer?.setOnCompletionListener {
songOnComplete()
}
и мой класс адаптера
package com.musicplayer.echo.adapters
класс MainScreenAdapter (arrayList: ArrayList, _context: Context): RecyclerView.Adapter() {
var songDetails:ArrayList<Songs>?=null
var mContext: Context?=null
init
{
this.songDetails = arrayList
this.mContext = _context
}
override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): MyViewHolder
{
val itemView = LayoutInflater.from(parent?.context)
.inflate(R.layout.row_custom_mainscreen,parent,false)
return MyViewHolder(itemView)
}
override fun getItemCount(): Int
{
if(songDetails==null)
return 0
else
return (songDetails as ArrayList<Songs>).size
}
override fun onBindViewHolder(holder: MyViewHolder, position: Int)
{
val songObject = songDetails?.get(position)
holder.trackTitle?.text = songObject?.songTitle
holder.trackArtist?.text = songObject?.songArtist
holder.contentHolder?.setOnClickListener({
val songPlayingFragment = SongPlayingFragment()
var args = Bundle()
args.putString("songArtist",songObject?.songArtist)
args.putString("songTitle",songObject?.songTitle)
args.putString("path",songObject?.songData)
args.putInt("songId",songObject?.songId?.toInt() as Int)
args.putInt("songPosition",position)
args.putParcelableArrayList("songData",songDetails)
songPlayingFragment.arguments = args
(mContext as FragmentActivity).supportFragmentManager
.beginTransaction()
.replace(R.id.details_fragment, songPlayingFragment)
.commit()
})
}
class MyViewHolder(view: View) : RecyclerView.ViewHolder(view)
{
var trackTitle : TextView?=null
var trackArtist : TextView?=null
var contentHolder : RelativeLayout?=null
init
{
trackTitle = view.findViewById(R.id.trackTitle)
trackArtist = view.findViewById(R.id.trackArtist)
contentHolder = view.findViewById(R.id.contentRow)
}
}
}