PlayerAndroid/app/src/main/java/code/name/monkey/retromusic/fragments/player/adaptive/AdaptivePlaybackControlsFra...

280 lines
9.7 KiB
Kotlin
Raw Normal View History

2020-10-06 08:46:04 +00:00
/*
* Copyright (c) 2020 Hemanth Savarla.
*
* Licensed under the GNU General Public License v3
*
* This is free software: you can redistribute it and/or modify it
* under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
*
* This software is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
* without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
* See the GNU General Public License for more details.
*
*/
2019-04-20 05:29:45 +00:00
package code.name.monkey.retromusic.fragments.player.adaptive
2018-11-30 01:06:16 +00:00
2020-05-20 21:30:13 +00:00
import android.animation.ObjectAnimator
2018-11-30 01:06:16 +00:00
import android.graphics.PorterDuff
import android.os.Bundle
import android.view.LayoutInflater
import android.view.View
import android.view.ViewGroup
2020-05-20 21:30:13 +00:00
import android.view.animation.LinearInterpolator
import android.widget.SeekBar
2019-02-17 17:01:35 +00:00
import code.name.monkey.appthemehelper.ThemeStore
2018-11-30 01:06:16 +00:00
import code.name.monkey.appthemehelper.util.ATHUtil
import code.name.monkey.appthemehelper.util.ColorUtil
import code.name.monkey.appthemehelper.util.MaterialValueHelper
import code.name.monkey.appthemehelper.util.TintHelper
import code.name.monkey.retromusic.R
import code.name.monkey.retromusic.databinding.FragmentAdaptivePlayerPlaybackControlsBinding
import code.name.monkey.retromusic.extensions.*
2020-01-06 03:12:32 +00:00
import code.name.monkey.retromusic.fragments.base.AbsPlayerControlsFragment
2018-11-30 01:06:16 +00:00
import code.name.monkey.retromusic.helper.MusicPlayerRemote
import code.name.monkey.retromusic.helper.MusicProgressViewUpdateHelper
import code.name.monkey.retromusic.helper.PlayPauseButtonOnClickHandler
2020-05-20 21:30:13 +00:00
import code.name.monkey.retromusic.misc.SimpleOnSeekbarChangeListener
2018-11-30 01:06:16 +00:00
import code.name.monkey.retromusic.service.MusicService
import code.name.monkey.retromusic.util.MusicUtil
2020-06-06 18:57:28 +00:00
import code.name.monkey.retromusic.util.PreferenceUtil
2020-05-18 07:22:18 +00:00
import code.name.monkey.retromusic.util.color.MediaNotificationProcessor
2018-11-30 01:06:16 +00:00
class AdaptivePlaybackControlsFragment :
AbsPlayerControlsFragment(R.layout.fragment_adaptive_player_playback_controls) {
2018-11-30 01:06:16 +00:00
private var lastPlaybackControlsColor: Int = 0
private var lastDisabledPlaybackControlsColor: Int = 0
private var progressViewUpdateHelper: MusicProgressViewUpdateHelper? = null
private var _binding: FragmentAdaptivePlayerPlaybackControlsBinding? = null
private val binding get() = _binding!!
2018-11-30 01:06:16 +00:00
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
progressViewUpdateHelper = MusicProgressViewUpdateHelper(this)
}
2020-01-06 03:12:32 +00:00
override fun onCreateView(
2020-10-06 08:46:04 +00:00
inflater: LayoutInflater,
container: ViewGroup?,
2020-01-06 03:12:32 +00:00
savedInstanceState: Bundle?
): View {
_binding = FragmentAdaptivePlayerPlaybackControlsBinding.inflate(inflater, container, false)
return binding.root
2018-11-30 01:06:16 +00:00
}
override fun onViewCreated(view: View, savedInstanceState: Bundle?) {
super.onViewCreated(view, savedInstanceState)
setUpMusicControllers()
binding.playPauseButton.setOnClickListener {
2018-11-30 01:06:16 +00:00
if (MusicPlayerRemote.isPlaying) {
MusicPlayerRemote.pauseSong()
} else {
MusicPlayerRemote.resumePlaying()
}
showBounceAnimation(binding.playPauseButton)
2018-11-30 01:06:16 +00:00
}
}
2020-01-06 03:12:32 +00:00
private fun updateSong() {
2020-06-06 18:57:28 +00:00
if (PreferenceUtil.isSongInfo) {
binding.songInfo.text = getSongInfo(MusicPlayerRemote.currentSong)
binding.songInfo.show()
2020-01-06 03:12:32 +00:00
} else {
binding.songInfo.hide()
2020-01-06 03:12:32 +00:00
}
}
2018-11-30 01:06:16 +00:00
override fun onResume() {
super.onResume()
progressViewUpdateHelper!!.start()
}
override fun onPause() {
super.onPause()
progressViewUpdateHelper!!.stop()
}
2020-01-06 03:12:32 +00:00
override fun onPlayingMetaChanged() {
super.onPlayingMetaChanged()
updateSong()
}
2018-11-30 01:06:16 +00:00
override fun onServiceConnected() {
updatePlayPauseDrawableState()
updateRepeatState()
updateShuffleState()
2020-01-06 03:12:32 +00:00
updateSong()
2018-11-30 01:06:16 +00:00
}
override fun onPlayStateChanged() {
updatePlayPauseDrawableState()
}
override fun onRepeatModeChanged() {
updateRepeatState()
}
override fun onShuffleModeChanged() {
updateShuffleState()
}
2020-05-18 07:22:18 +00:00
override fun setColor(color: MediaNotificationProcessor) {
if (ColorUtil.isColorLight(
ATHUtil.resolveColor(
2020-03-01 14:37:32 +00:00
requireContext(),
android.R.attr.windowBackground
)
)
) {
2018-11-30 01:06:16 +00:00
lastPlaybackControlsColor = MaterialValueHelper.getSecondaryTextColor(activity, true)
lastDisabledPlaybackControlsColor =
MaterialValueHelper.getSecondaryDisabledTextColor(activity, true)
2018-11-30 01:06:16 +00:00
} else {
lastPlaybackControlsColor = MaterialValueHelper.getPrimaryTextColor(activity, false)
lastDisabledPlaybackControlsColor =
MaterialValueHelper.getPrimaryDisabledTextColor(activity, false)
2018-11-30 01:06:16 +00:00
}
updateRepeatState()
updateShuffleState()
updatePrevNextColor()
updatePlayPauseColor()
2020-06-06 18:57:28 +00:00
val colorFinal = if (PreferenceUtil.isAdaptiveColor) {
2020-05-18 07:22:18 +00:00
color.primaryTextColor
2019-02-17 17:01:35 +00:00
} else {
2020-03-01 13:26:12 +00:00
ThemeStore.accentColor(requireContext())
2019-08-04 10:08:34 +00:00
}.ripAlpha()
2020-01-06 03:12:32 +00:00
TintHelper.setTintAuto(
binding.playPauseButton,
2020-01-06 03:12:32 +00:00
MaterialValueHelper.getPrimaryTextColor(context, ColorUtil.isColorLight(colorFinal)),
false
)
TintHelper.setTintAuto(binding.playPauseButton, colorFinal, true)
binding.progressSlider.applyColor(colorFinal)
2019-04-04 06:07:55 +00:00
volumeFragment?.setTintable(colorFinal)
2018-11-30 01:06:16 +00:00
}
private fun updatePlayPauseColor() {
2020-10-06 08:46:04 +00:00
// playPauseButton.setColorFilter(lastPlaybackControlsColor, PorterDuff.Mode.SRC_IN);
2018-11-30 01:06:16 +00:00
}
private fun setUpPlayPauseFab() {
binding.playPauseButton.setOnClickListener(PlayPauseButtonOnClickHandler())
2018-11-30 01:06:16 +00:00
}
private fun updatePlayPauseDrawableState() {
2018-11-30 01:06:16 +00:00
if (MusicPlayerRemote.isPlaying) {
binding.playPauseButton.setImageResource(R.drawable.ic_pause)
2018-11-30 01:06:16 +00:00
} else {
binding.playPauseButton.setImageResource(R.drawable.ic_play_arrow_white_32dp)
2018-11-30 01:06:16 +00:00
}
}
private fun setUpMusicControllers() {
setUpPlayPauseFab()
setUpPrevNext()
setUpRepeatButton()
setUpShuffleButton()
setUpProgressSlider()
}
private fun setUpPrevNext() {
updatePrevNextColor()
binding.nextButton.setOnClickListener { MusicPlayerRemote.playNextSong() }
binding.previousButton.setOnClickListener { MusicPlayerRemote.back() }
2018-11-30 01:06:16 +00:00
}
private fun updatePrevNextColor() {
binding.nextButton.setColorFilter(lastPlaybackControlsColor, PorterDuff.Mode.SRC_IN)
binding.previousButton.setColorFilter(lastPlaybackControlsColor, PorterDuff.Mode.SRC_IN)
2018-11-30 01:06:16 +00:00
}
private fun setUpShuffleButton() {
binding.shuffleButton.setOnClickListener { MusicPlayerRemote.toggleShuffleMode() }
2018-11-30 01:06:16 +00:00
}
2020-05-20 21:30:13 +00:00
override fun show() {
}
override fun hide() {
}
2018-11-30 01:06:16 +00:00
override fun updateShuffleState() {
when (MusicPlayerRemote.shuffleMode) {
MusicService.SHUFFLE_MODE_SHUFFLE -> binding.shuffleButton.setColorFilter(
2020-01-06 03:12:32 +00:00
lastPlaybackControlsColor,
PorterDuff.Mode.SRC_IN
)
else -> binding.shuffleButton.setColorFilter(
lastDisabledPlaybackControlsColor,
PorterDuff.Mode.SRC_IN
)
2018-11-30 01:06:16 +00:00
}
}
private fun setUpRepeatButton() {
binding.repeatButton.setOnClickListener { MusicPlayerRemote.cycleRepeatMode() }
2018-11-30 01:06:16 +00:00
}
override fun updateRepeatState() {
when (MusicPlayerRemote.repeatMode) {
MusicService.REPEAT_MODE_NONE -> {
binding.repeatButton.setImageResource(R.drawable.ic_repeat)
binding.repeatButton.setColorFilter(
lastDisabledPlaybackControlsColor,
PorterDuff.Mode.SRC_IN
)
2018-11-30 01:06:16 +00:00
}
MusicService.REPEAT_MODE_ALL -> {
binding.repeatButton.setImageResource(R.drawable.ic_repeat)
binding.repeatButton.setColorFilter(
lastPlaybackControlsColor,
PorterDuff.Mode.SRC_IN
)
2018-11-30 01:06:16 +00:00
}
MusicService.REPEAT_MODE_THIS -> {
binding.repeatButton.setImageResource(R.drawable.ic_repeat_one)
binding.repeatButton.setColorFilter(
lastPlaybackControlsColor,
PorterDuff.Mode.SRC_IN
)
2018-11-30 01:06:16 +00:00
}
}
}
2020-05-20 21:30:13 +00:00
override fun setUpProgressSlider() {
binding.progressSlider.setOnSeekBarChangeListener(object : SimpleOnSeekbarChangeListener() {
2020-05-20 21:30:13 +00:00
override fun onProgressChanged(seekBar: SeekBar, progress: Int, fromUser: Boolean) {
if (fromUser) {
MusicPlayerRemote.seekTo(progress)
onUpdateProgressViews(
MusicPlayerRemote.songProgressMillis,
MusicPlayerRemote.songDurationMillis
)
}
}
})
}
2020-05-20 21:30:13 +00:00
override fun onUpdateProgressViews(progress: Int, total: Int) {
binding.progressSlider.max = total
2018-11-30 01:06:16 +00:00
val animator = ObjectAnimator.ofInt(binding.progressSlider, "progress", progress)
2020-05-20 21:30:13 +00:00
animator.duration = SLIDER_ANIMATION_TIME
animator.interpolator = LinearInterpolator()
animator.start()
2018-11-30 01:06:16 +00:00
binding.songTotalTime.text = MusicUtil.getReadableDurationString(total.toLong())
binding.songCurrentProgress.text = MusicUtil.getReadableDurationString(progress.toLong())
}
override fun onDestroyView() {
super.onDestroyView()
_binding = null
2018-11-30 01:06:16 +00:00
}
}