PlayerAndroid/app/src/main/java/code/name/monkey/retromusic/fragments/player/color/ColorFragment.kt

175 lines
6.3 KiB
Kotlin
Raw Normal View History

2019-04-20 05:29:45 +00:00
package code.name.monkey.retromusic.fragments.player.color
2018-12-05 15:34:26 +00:00
import android.animation.ValueAnimator
import android.graphics.drawable.Drawable
import android.os.Bundle
2019-12-08 14:41:00 +00:00
import android.view.LayoutInflater
import android.view.View
import android.view.ViewGroup
2018-12-05 15:34:26 +00:00
import androidx.appcompat.widget.Toolbar
2019-12-08 14:41:00 +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.ToolbarContentTintHelper
2018-12-05 15:34:26 +00:00
import code.name.monkey.retromusic.R
2019-06-17 02:46:50 +00:00
import code.name.monkey.retromusic.fragments.base.AbsPlayerFragment
2019-12-08 14:41:00 +00:00
import code.name.monkey.retromusic.glide.RetroMusicColoredTarget
2019-12-15 05:34:47 +00:00
import code.name.monkey.retromusic.glide.SongGlideRequest.Builder
2018-12-05 15:34:26 +00:00
import code.name.monkey.retromusic.glide.palette.BitmapPaletteWrapper
import code.name.monkey.retromusic.helper.MusicPlayerRemote
import code.name.monkey.retromusic.model.Song
2019-12-08 14:41:00 +00:00
import code.name.monkey.retromusic.util.NavigationUtil
2018-12-05 15:34:26 +00:00
import code.name.monkey.retromusic.util.RetroColorUtil
import com.bumptech.glide.Glide
import com.bumptech.glide.request.animation.GlideAnimation
2020-01-07 12:33:59 +00:00
import kotlinx.android.synthetic.main.fragment_color_player.colorGradientBackground
import kotlinx.android.synthetic.main.fragment_color_player.playerImage
import kotlinx.android.synthetic.main.fragment_color_player.playerToolbar
2018-12-05 15:34:26 +00:00
class ColorFragment : AbsPlayerFragment() {
2019-11-15 16:30:10 +00:00
2019-12-08 14:41:00 +00:00
private var lastColor: Int = 0
private var backgroundColor: Int = 0
private lateinit var playbackControlsFragment: ColorPlaybackControlsFragment
private var valueAnimator: ValueAnimator? = null
override fun playerToolbar(): Toolbar {
return playerToolbar
}
override val paletteColor: Int
get() = backgroundColor
override fun onColorChanged(color: Int) {
}
override fun onFavoriteToggled() {
2020-01-07 12:33:59 +00:00
//toggleFavorite(MusicPlayerRemote.currentSong)
2019-12-08 14:41:00 +00:00
}
override fun onShow() {
playbackControlsFragment.show()
}
override fun onHide() {
playbackControlsFragment.hide()
onBackPressed()
}
override fun onBackPressed(): Boolean {
return false
}
override fun toolbarIconColor(): Int {
return lastColor
}
override fun toggleFavorite(song: Song) {
super.toggleFavorite(song)
if (song.id == MusicPlayerRemote.currentSong.id) {
updateIsFavorite()
}
}
override fun onDestroyView() {
super.onDestroyView()
if (valueAnimator != null) {
valueAnimator!!.cancel()
valueAnimator = null
}
}
2019-12-15 05:34:47 +00:00
override fun onCreateView(inflater: LayoutInflater, container: ViewGroup?, savedInstanceState: Bundle?): View? {
2019-12-08 14:41:00 +00:00
return inflater.inflate(R.layout.fragment_color_player, container, false)
}
override fun onViewCreated(view: View, savedInstanceState: Bundle?) {
super.onViewCreated(view, savedInstanceState)
setUpSubFragments()
setUpPlayerToolbar()
playerImage.setOnClickListener {
NavigationUtil.goToLyrics(requireActivity())
}
}
private fun setUpSubFragments() {
playbackControlsFragment = childFragmentManager.findFragmentById(R.id.playbackControlsFragment) as ColorPlaybackControlsFragment
}
private fun setUpPlayerToolbar() {
playerToolbar.apply {
inflateMenu(R.menu.menu_player)
setNavigationOnClickListener { requireActivity().onBackPressed() }
setOnMenuItemClickListener(this@ColorFragment)
ToolbarContentTintHelper.colorizeToolbar(this, ATHUtil.resolveColor(requireContext(), R.attr.colorControlNormal), requireActivity())
}
}
override fun onPlayingMetaChanged() {
super.onPlayingMetaChanged()
updateSong()
}
override fun onServiceConnected() {
super.onServiceConnected()
updateSong()
}
private fun updateSong() {
2019-12-15 05:34:47 +00:00
Builder.from(Glide.with(requireActivity()), MusicPlayerRemote.currentSong)
.checkIgnoreMediaStore(requireContext())
.generatePalette(requireContext())
.build()
2019-12-08 14:41:00 +00:00
.into(object : RetroMusicColoredTarget(playerImage) {
override fun onColorReady(color: Int) {
}
override fun onResourceReady(
resource: BitmapPaletteWrapper?,
glideAnimation: GlideAnimation<in BitmapPaletteWrapper>?
) {
super.onResourceReady(resource, glideAnimation)
resource?.let {
val palette = resource.palette
val swatch = RetroColorUtil.getSwatch(palette)
val textColor = RetroColorUtil.getTextColor(palette)
val backgroundColor = swatch.rgb
setColors(backgroundColor, textColor)
}
}
override fun onLoadFailed(e: Exception?, errorDrawable: Drawable?) {
super.onLoadFailed(e, errorDrawable)
val backgroundColor = defaultFooterColor
2019-12-15 05:34:47 +00:00
val textColor = if (ColorUtil.isColorLight(defaultFooterColor)) MaterialValueHelper.getPrimaryTextColor(requireContext(), true)
else MaterialValueHelper.getPrimaryTextColor(requireContext(), false)
2019-12-08 14:41:00 +00:00
setColors(backgroundColor, textColor)
}
})
}
2019-12-15 05:34:47 +00:00
private fun setColors(backgroundColor: Int, componentsColor: Int) {
this.lastColor = componentsColor
2019-12-08 14:41:00 +00:00
this.backgroundColor = backgroundColor
2019-12-15 05:34:47 +00:00
playbackControlsFragment.setDark(componentsColor, backgroundColor)
colorGradientBackground?.setBackgroundColor(backgroundColor)
2019-12-08 14:41:00 +00:00
playerActivity?.setLightNavigationBar(ColorUtil.isColorLight(backgroundColor))
callbacks?.onPaletteColorChanged()
2019-12-15 05:34:47 +00:00
ToolbarContentTintHelper.colorizeToolbar(playerToolbar, componentsColor, requireActivity())
2019-12-08 14:41:00 +00:00
}
companion object {
fun newInstance(): ColorFragment {
val args = Bundle()
val fragment = ColorFragment()
fragment.arguments = args
return fragment
}
}
2018-12-05 15:34:26 +00:00
}