Fix classic theme queue and colors
parent
e61294d281
commit
950e840083
|
@ -11,12 +11,15 @@ import androidx.appcompat.app.AppCompatActivity
|
||||||
import androidx.appcompat.widget.Toolbar
|
import androidx.appcompat.widget.Toolbar
|
||||||
import androidx.core.view.ViewCompat
|
import androidx.core.view.ViewCompat
|
||||||
import androidx.recyclerview.widget.LinearLayoutManager
|
import androidx.recyclerview.widget.LinearLayoutManager
|
||||||
|
import androidx.recyclerview.widget.RecyclerView
|
||||||
|
import code.name.monkey.appthemehelper.ThemeStore
|
||||||
import code.name.monkey.appthemehelper.util.*
|
import code.name.monkey.appthemehelper.util.*
|
||||||
import code.name.monkey.retromusic.R
|
import code.name.monkey.retromusic.R
|
||||||
import code.name.monkey.retromusic.RetroBottomSheetBehavior
|
import code.name.monkey.retromusic.RetroBottomSheetBehavior
|
||||||
import code.name.monkey.retromusic.activities.base.AbsSlidingMusicPanelActivity
|
import code.name.monkey.retromusic.activities.base.AbsSlidingMusicPanelActivity
|
||||||
import code.name.monkey.retromusic.adapter.song.PlayingQueueAdapter
|
import code.name.monkey.retromusic.adapter.song.PlayingQueueAdapter
|
||||||
import code.name.monkey.retromusic.extensions.hide
|
import code.name.monkey.retromusic.extensions.hide
|
||||||
|
import code.name.monkey.retromusic.extensions.ripAlpha
|
||||||
import code.name.monkey.retromusic.extensions.show
|
import code.name.monkey.retromusic.extensions.show
|
||||||
import code.name.monkey.retromusic.fragments.VolumeFragment
|
import code.name.monkey.retromusic.fragments.VolumeFragment
|
||||||
import code.name.monkey.retromusic.fragments.base.AbsPlayerFragment
|
import code.name.monkey.retromusic.fragments.base.AbsPlayerFragment
|
||||||
|
@ -35,6 +38,11 @@ import com.google.android.material.bottomsheet.BottomSheetBehavior
|
||||||
import com.google.android.material.card.MaterialCardView
|
import com.google.android.material.card.MaterialCardView
|
||||||
import com.google.android.material.shape.MaterialShapeDrawable
|
import com.google.android.material.shape.MaterialShapeDrawable
|
||||||
import com.google.android.material.shape.ShapeAppearanceModel
|
import com.google.android.material.shape.ShapeAppearanceModel
|
||||||
|
import com.h6ah4i.android.widget.advrecyclerview.animator.DraggableItemAnimator
|
||||||
|
import com.h6ah4i.android.widget.advrecyclerview.draggable.RecyclerViewDragDropManager
|
||||||
|
import com.h6ah4i.android.widget.advrecyclerview.swipeable.RecyclerViewSwipeManager
|
||||||
|
import com.h6ah4i.android.widget.advrecyclerview.touchguard.RecyclerViewTouchActionGuardManager
|
||||||
|
import com.h6ah4i.android.widget.advrecyclerview.utils.WrapperAdapterUtils
|
||||||
import kotlinx.android.synthetic.main.fragment_clasic_player.*
|
import kotlinx.android.synthetic.main.fragment_clasic_player.*
|
||||||
import kotlinx.android.synthetic.main.fragment_classic_controls.*
|
import kotlinx.android.synthetic.main.fragment_classic_controls.*
|
||||||
import kotlinx.android.synthetic.main.status_bar.*
|
import kotlinx.android.synthetic.main.status_bar.*
|
||||||
|
@ -50,6 +58,12 @@ class ClassicPlayerFragment : AbsPlayerFragment(), View.OnLayoutChangeListener,
|
||||||
private lateinit var queueAdapter: PlayingQueueAdapter
|
private lateinit var queueAdapter: PlayingQueueAdapter
|
||||||
private var volumeFragment: VolumeFragment? = null
|
private var volumeFragment: VolumeFragment? = null
|
||||||
private lateinit var shapeDrawable: MaterialShapeDrawable
|
private lateinit var shapeDrawable: MaterialShapeDrawable
|
||||||
|
private lateinit var wrappedAdapter: RecyclerView.Adapter<*>
|
||||||
|
private var recyclerViewDragDropManager: RecyclerViewDragDropManager? = null
|
||||||
|
private var recyclerViewSwipeManager: RecyclerViewSwipeManager? = null
|
||||||
|
private var recyclerViewTouchActionGuardManager: RecyclerViewTouchActionGuardManager? = null
|
||||||
|
private var playingQueueAdapter: PlayingQueueAdapter? = null
|
||||||
|
private lateinit var linearLayoutManager: LinearLayoutManager
|
||||||
|
|
||||||
private val bottomSheetCallbackList = object : BottomSheetBehavior.BottomSheetCallback() {
|
private val bottomSheetCallbackList = object : BottomSheetBehavior.BottomSheetCallback() {
|
||||||
override fun onSlide(bottomSheet: View, slideOffset: Float) {
|
override fun onSlide(bottomSheet: View, slideOffset: Float) {
|
||||||
|
@ -67,10 +81,17 @@ class ClassicPlayerFragment : AbsPlayerFragment(), View.OnLayoutChangeListener,
|
||||||
|
|
||||||
override fun onStateChanged(bottomSheet: View, newState: Int) {
|
override fun onStateChanged(bottomSheet: View, newState: Int) {
|
||||||
val activity = requireActivity() as AbsSlidingMusicPanelActivity
|
val activity = requireActivity() as AbsSlidingMusicPanelActivity
|
||||||
if (newState == BottomSheetBehavior.STATE_EXPANDED || newState == BottomSheetBehavior.STATE_DRAGGING) {
|
when (newState) {
|
||||||
activity.getBottomSheetBehavior().setAllowDragging(false)
|
BottomSheetBehavior.STATE_EXPANDED,
|
||||||
} else {
|
BottomSheetBehavior.STATE_DRAGGING -> {
|
||||||
activity.getBottomSheetBehavior().setAllowDragging(true)
|
activity.getBottomSheetBehavior().setAllowDragging(false)
|
||||||
|
}
|
||||||
|
BottomSheetBehavior.STATE_COLLAPSED -> {
|
||||||
|
resetToCurrentPosition()
|
||||||
|
}
|
||||||
|
else -> {
|
||||||
|
activity.getBottomSheetBehavior().setAllowDragging(true)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -94,7 +115,8 @@ class ClassicPlayerFragment : AbsPlayerFragment(), View.OnLayoutChangeListener,
|
||||||
setUpMusicControllers()
|
setUpMusicControllers()
|
||||||
setUpPlayerToolbar()
|
setUpPlayerToolbar()
|
||||||
hideVolumeIfAvailable()
|
hideVolumeIfAvailable()
|
||||||
setUpQueue()
|
setupRecyclerView()
|
||||||
|
|
||||||
val coverFragment =
|
val coverFragment =
|
||||||
childFragmentManager.findFragmentById(R.id.playerAlbumCoverFragment) as PlayerAlbumCoverFragment
|
childFragmentManager.findFragmentById(R.id.playerAlbumCoverFragment) as PlayerAlbumCoverFragment
|
||||||
coverFragment.setCallbacks(this)
|
coverFragment.setCallbacks(this)
|
||||||
|
@ -140,6 +162,17 @@ class ClassicPlayerFragment : AbsPlayerFragment(), View.OnLayoutChangeListener,
|
||||||
override fun onDestroyView() {
|
override fun onDestroyView() {
|
||||||
super.onDestroyView()
|
super.onDestroyView()
|
||||||
getQueuePanel().removeBottomSheetCallback(bottomSheetCallbackList)
|
getQueuePanel().removeBottomSheetCallback(bottomSheetCallbackList)
|
||||||
|
if (recyclerViewDragDropManager != null) {
|
||||||
|
recyclerViewDragDropManager?.release()
|
||||||
|
recyclerViewDragDropManager = null
|
||||||
|
}
|
||||||
|
|
||||||
|
if (recyclerViewSwipeManager != null) {
|
||||||
|
recyclerViewSwipeManager?.release()
|
||||||
|
recyclerViewSwipeManager = null
|
||||||
|
}
|
||||||
|
|
||||||
|
WrapperAdapterUtils.releaseAll(wrappedAdapter)
|
||||||
}
|
}
|
||||||
|
|
||||||
private fun updateSong() {
|
private fun updateSong() {
|
||||||
|
@ -161,66 +194,42 @@ class ClassicPlayerFragment : AbsPlayerFragment(), View.OnLayoutChangeListener,
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun onPause() {
|
override fun onPause() {
|
||||||
|
recyclerViewDragDropManager?.cancelDrag()
|
||||||
super.onPause()
|
super.onPause()
|
||||||
progressViewUpdateHelper.stop()
|
progressViewUpdateHelper.stop()
|
||||||
}
|
|
||||||
|
|
||||||
private fun getQueuePanel(): RetroBottomSheetBehavior<MaterialCardView> {
|
|
||||||
return RetroBottomSheetBehavior.from(playerQueueSheet) as RetroBottomSheetBehavior<MaterialCardView>
|
|
||||||
}
|
|
||||||
|
|
||||||
private fun setupPanel() {
|
|
||||||
if (!ViewCompat.isLaidOut(playerContainer) || playerContainer.isLayoutRequested) {
|
|
||||||
playerContainer.addOnLayoutChangeListener(this)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
val height = playerContainer.height
|
|
||||||
val width = playerContainer.width
|
|
||||||
val finalHeight = height - (playerControlsContainer.height + width)
|
|
||||||
val panel = getQueuePanel()
|
|
||||||
panel.peekHeight = finalHeight
|
|
||||||
}
|
|
||||||
|
|
||||||
private fun setUpPlayerToolbar() {
|
|
||||||
playerToolbar.inflateMenu(R.menu.menu_player)
|
|
||||||
playerToolbar.setNavigationOnClickListener { requireActivity().onBackPressed() }
|
|
||||||
playerToolbar.setOnMenuItemClickListener(this)
|
|
||||||
|
|
||||||
ToolbarContentTintHelper.colorizeToolbar(
|
|
||||||
playerToolbar,
|
|
||||||
ATHUtil.resolveColor(requireContext(), R.attr.colorControlNormal),
|
|
||||||
requireActivity()
|
|
||||||
)
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
private fun setUpQueue() {
|
|
||||||
queueAdapter = PlayingQueueAdapter(
|
|
||||||
requireActivity() as AppCompatActivity, mutableListOf(),
|
|
||||||
MusicPlayerRemote.position,
|
|
||||||
R.layout.item_queue
|
|
||||||
)
|
|
||||||
recyclerView.apply {
|
|
||||||
adapter = queueAdapter
|
|
||||||
layoutManager = LinearLayoutManager(requireContext())
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun onServiceConnected() {
|
override fun onServiceConnected() {
|
||||||
super.onServiceConnected()
|
super.onServiceConnected()
|
||||||
updateSong()
|
updateSong()
|
||||||
queueAdapter.swapDataSet(MusicPlayerRemote.playingQueue)
|
updatePlayPauseDrawableState()
|
||||||
|
updateQueue()
|
||||||
|
}
|
||||||
|
|
||||||
|
override fun onPlayStateChanged() {
|
||||||
|
updatePlayPauseDrawableState()
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
override fun onRepeatModeChanged() {
|
||||||
|
updateRepeatState()
|
||||||
|
}
|
||||||
|
|
||||||
|
override fun onShuffleModeChanged() {
|
||||||
|
updateShuffleState()
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun onPlayingMetaChanged() {
|
override fun onPlayingMetaChanged() {
|
||||||
super.onPlayingMetaChanged()
|
super.onPlayingMetaChanged()
|
||||||
updateSong()
|
updateSong()
|
||||||
|
updateQueuePosition()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
override fun onQueueChanged() {
|
override fun onQueueChanged() {
|
||||||
super.onQueueChanged()
|
super.onQueueChanged()
|
||||||
queueAdapter.swapDataSet(MusicPlayerRemote.playingQueue)
|
updateQueue()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -252,40 +261,45 @@ class ClassicPlayerFragment : AbsPlayerFragment(), View.OnLayoutChangeListener,
|
||||||
|
|
||||||
override fun onColorChanged(color: MediaNotificationProcessor) {
|
override fun onColorChanged(color: MediaNotificationProcessor) {
|
||||||
lastColor = color.backgroundColor
|
lastColor = color.backgroundColor
|
||||||
lastPlaybackControlsColor = color.primaryTextColor
|
if (ATHUtil.isWindowBackgroundDark(requireContext())) {
|
||||||
lastDisabledPlaybackControlsColor = ColorUtil.withAlpha(color.primaryTextColor, 0.3f)
|
lastPlaybackControlsColor =
|
||||||
|
MaterialValueHelper.getPrimaryTextColor(requireContext(), false)
|
||||||
|
lastDisabledPlaybackControlsColor =
|
||||||
|
MaterialValueHelper.getPrimaryDisabledTextColor(requireContext(), false)
|
||||||
|
} else {
|
||||||
|
lastPlaybackControlsColor =
|
||||||
|
MaterialValueHelper.getSecondaryTextColor(requireContext(), true)
|
||||||
|
lastDisabledPlaybackControlsColor =
|
||||||
|
MaterialValueHelper.getSecondaryDisabledTextColor(requireContext(), true)
|
||||||
|
}
|
||||||
|
|
||||||
|
val colorFinal = if (PreferenceUtil.getInstance(requireContext()).adaptiveColor) {
|
||||||
|
color.primaryTextColor
|
||||||
|
} else {
|
||||||
|
ThemeStore.accentColor(requireContext())
|
||||||
|
}.ripAlpha()
|
||||||
|
|
||||||
title.setTextColor(color.primaryTextColor)
|
|
||||||
songCurrentProgress.setTextColor(lastPlaybackControlsColor)
|
|
||||||
songTotalTime.setTextColor(lastPlaybackControlsColor)
|
|
||||||
|
|
||||||
ViewUtil.setProgressDrawable(progressSlider, color.primaryTextColor, true)
|
|
||||||
volumeFragment?.setTintableColor(
|
|
||||||
ATHUtil.resolveColor(
|
|
||||||
requireContext(),
|
|
||||||
android.R.attr.textColorPrimary
|
|
||||||
)
|
|
||||||
)
|
|
||||||
|
|
||||||
TintHelper.setTintAuto(playPauseButton, color.primaryTextColor, true)
|
|
||||||
TintHelper.setTintAuto(
|
TintHelper.setTintAuto(
|
||||||
playPauseButton,
|
playPauseButton,
|
||||||
MaterialValueHelper.getPrimaryTextColor(
|
MaterialValueHelper.getPrimaryTextColor(
|
||||||
requireContext(),
|
requireContext(),
|
||||||
ColorUtil.isColorLight(color.primaryTextColor)
|
ColorUtil.isColorLight(colorFinal)
|
||||||
),
|
),
|
||||||
false
|
false
|
||||||
)
|
)
|
||||||
updateRepeatState()
|
TintHelper.setTintAuto(playPauseButton, colorFinal, true)
|
||||||
updateShuffleState()
|
|
||||||
updatePrevNextColor()
|
ViewUtil.setProgressDrawable(progressSlider, colorFinal, true)
|
||||||
|
volumeFragment?.setTintable(colorFinal)
|
||||||
|
|
||||||
ToolbarContentTintHelper.colorizeToolbar(
|
ToolbarContentTintHelper.colorizeToolbar(
|
||||||
playerToolbar,
|
playerToolbar,
|
||||||
Color.WHITE,
|
Color.WHITE,
|
||||||
requireActivity()
|
requireActivity()
|
||||||
)
|
)
|
||||||
|
updateRepeatState()
|
||||||
|
updateShuffleState()
|
||||||
|
updatePrevNextColor()
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun toggleFavorite(song: Song) {
|
override fun toggleFavorite(song: Song) {
|
||||||
|
@ -306,6 +320,79 @@ class ClassicPlayerFragment : AbsPlayerFragment(), View.OnLayoutChangeListener,
|
||||||
songCurrentProgress.text = MusicUtil.getReadableDurationString(progress.toLong())
|
songCurrentProgress.text = MusicUtil.getReadableDurationString(progress.toLong())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
private fun updateQueuePosition() {
|
||||||
|
playingQueueAdapter?.setCurrent(MusicPlayerRemote.position)
|
||||||
|
resetToCurrentPosition()
|
||||||
|
}
|
||||||
|
|
||||||
|
private fun updateQueue() {
|
||||||
|
playingQueueAdapter?.swapDataSet(MusicPlayerRemote.playingQueue, MusicPlayerRemote.position)
|
||||||
|
resetToCurrentPosition()
|
||||||
|
}
|
||||||
|
|
||||||
|
private fun resetToCurrentPosition() {
|
||||||
|
recyclerView.stopScroll()
|
||||||
|
linearLayoutManager.scrollToPositionWithOffset(MusicPlayerRemote.position + 1, 0)
|
||||||
|
}
|
||||||
|
|
||||||
|
private fun getQueuePanel(): RetroBottomSheetBehavior<MaterialCardView> {
|
||||||
|
return RetroBottomSheetBehavior.from(playerQueueSheet) as RetroBottomSheetBehavior<MaterialCardView>
|
||||||
|
}
|
||||||
|
|
||||||
|
private fun setupPanel() {
|
||||||
|
if (!ViewCompat.isLaidOut(playerContainer) || playerContainer.isLayoutRequested) {
|
||||||
|
playerContainer.addOnLayoutChangeListener(this)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
val height = playerContainer.height
|
||||||
|
val width = playerContainer.width
|
||||||
|
val finalHeight = height - (playerControlsContainer.height + width)
|
||||||
|
val panel = getQueuePanel()
|
||||||
|
panel.peekHeight = finalHeight
|
||||||
|
}
|
||||||
|
|
||||||
|
private fun setUpPlayerToolbar() {
|
||||||
|
playerToolbar.inflateMenu(R.menu.menu_player)
|
||||||
|
playerToolbar.setNavigationOnClickListener { requireActivity().onBackPressed() }
|
||||||
|
playerToolbar.setOnMenuItemClickListener(this)
|
||||||
|
|
||||||
|
ToolbarContentTintHelper.colorizeToolbar(
|
||||||
|
playerToolbar,
|
||||||
|
ATHUtil.resolveColor(requireContext(), R.attr.colorControlNormal),
|
||||||
|
requireActivity()
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
private fun setupRecyclerView() {
|
||||||
|
playingQueueAdapter = PlayingQueueAdapter(
|
||||||
|
requireActivity() as AppCompatActivity,
|
||||||
|
MusicPlayerRemote.playingQueue.toMutableList(),
|
||||||
|
MusicPlayerRemote.position,
|
||||||
|
R.layout.item_queue
|
||||||
|
)
|
||||||
|
linearLayoutManager = LinearLayoutManager(requireContext())
|
||||||
|
recyclerViewTouchActionGuardManager = RecyclerViewTouchActionGuardManager()
|
||||||
|
recyclerViewDragDropManager = RecyclerViewDragDropManager()
|
||||||
|
recyclerViewSwipeManager = RecyclerViewSwipeManager()
|
||||||
|
|
||||||
|
val animator = DraggableItemAnimator()
|
||||||
|
animator.supportsChangeAnimations = false
|
||||||
|
wrappedAdapter =
|
||||||
|
recyclerViewDragDropManager?.createWrappedAdapter(playingQueueAdapter!!) as RecyclerView.Adapter<*>
|
||||||
|
wrappedAdapter =
|
||||||
|
recyclerViewSwipeManager?.createWrappedAdapter(wrappedAdapter) as RecyclerView.Adapter<*>
|
||||||
|
recyclerView.layoutManager = linearLayoutManager
|
||||||
|
recyclerView.adapter = wrappedAdapter
|
||||||
|
recyclerView.itemAnimator = animator
|
||||||
|
recyclerViewTouchActionGuardManager?.attachRecyclerView(recyclerView)
|
||||||
|
recyclerViewDragDropManager?.attachRecyclerView(recyclerView)
|
||||||
|
recyclerViewSwipeManager?.attachRecyclerView(recyclerView)
|
||||||
|
|
||||||
|
linearLayoutManager.scrollToPositionWithOffset(MusicPlayerRemote.position + 1, 0)
|
||||||
|
}
|
||||||
|
|
||||||
fun setUpProgressSlider() {
|
fun setUpProgressSlider() {
|
||||||
progressSlider.addOnChangeListener { _, value, fromUser ->
|
progressSlider.addOnChangeListener { _, value, fromUser ->
|
||||||
if (fromUser) {
|
if (fromUser) {
|
||||||
|
@ -318,18 +405,6 @@ class ClassicPlayerFragment : AbsPlayerFragment(), View.OnLayoutChangeListener,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun onPlayStateChanged() {
|
|
||||||
updatePlayPauseDrawableState()
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun onRepeatModeChanged() {
|
|
||||||
updateRepeatState()
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun onShuffleModeChanged() {
|
|
||||||
updateShuffleState()
|
|
||||||
}
|
|
||||||
|
|
||||||
private fun setUpPlayPauseFab() {
|
private fun setUpPlayPauseFab() {
|
||||||
playPauseButton.setOnClickListener(PlayPauseButtonOnClickHandler())
|
playPauseButton.setOnClickListener(PlayPauseButtonOnClickHandler())
|
||||||
}
|
}
|
||||||
|
@ -368,10 +443,11 @@ class ClassicPlayerFragment : AbsPlayerFragment(), View.OnLayoutChangeListener,
|
||||||
|
|
||||||
fun updateShuffleState() {
|
fun updateShuffleState() {
|
||||||
when (MusicPlayerRemote.shuffleMode) {
|
when (MusicPlayerRemote.shuffleMode) {
|
||||||
MusicService.SHUFFLE_MODE_SHUFFLE -> shuffleButton.setColorFilter(
|
MusicService.SHUFFLE_MODE_SHUFFLE ->
|
||||||
lastPlaybackControlsColor,
|
shuffleButton.setColorFilter(
|
||||||
PorterDuff.Mode.SRC_IN
|
lastPlaybackControlsColor,
|
||||||
)
|
PorterDuff.Mode.SRC_IN
|
||||||
|
)
|
||||||
else -> shuffleButton.setColorFilter(
|
else -> shuffleButton.setColorFilter(
|
||||||
lastDisabledPlaybackControlsColor,
|
lastDisabledPlaybackControlsColor,
|
||||||
PorterDuff.Mode.SRC_IN
|
PorterDuff.Mode.SRC_IN
|
||||||
|
@ -403,6 +479,7 @@ class ClassicPlayerFragment : AbsPlayerFragment(), View.OnLayoutChangeListener,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
override fun onLayoutChange(
|
override fun onLayoutChange(
|
||||||
v: View?,
|
v: View?,
|
||||||
left: Int,
|
left: Int,
|
||||||
|
|
|
@ -28,7 +28,7 @@
|
||||||
android:nestedScrollingEnabled="false"
|
android:nestedScrollingEnabled="false"
|
||||||
android:overScrollMode="never"
|
android:overScrollMode="never"
|
||||||
android:visibility="gone"
|
android:visibility="gone"
|
||||||
app:itemMargin="96dp"
|
app:itemMargin="28dp"
|
||||||
app:layout_constraintEnd_toEndOf="parent"
|
app:layout_constraintEnd_toEndOf="parent"
|
||||||
app:layout_constraintStart_toStartOf="parent"
|
app:layout_constraintStart_toStartOf="parent"
|
||||||
app:layout_constraintTop_toBottomOf="@+id/title"
|
app:layout_constraintTop_toBottomOf="@+id/title"
|
||||||
|
|
|
@ -20,7 +20,7 @@
|
||||||
app:layout_constraintEnd_toEndOf="parent"
|
app:layout_constraintEnd_toEndOf="parent"
|
||||||
app:layout_constraintStart_toStartOf="parent"
|
app:layout_constraintStart_toStartOf="parent"
|
||||||
app:layout_constraintTop_toTopOf="parent"
|
app:layout_constraintTop_toTopOf="parent"
|
||||||
tools:text="@tools:sample/lorem" />
|
tools:text="@tools:sample/full_names" />
|
||||||
|
|
||||||
|
|
||||||
<androidx.recyclerview.widget.RecyclerView
|
<androidx.recyclerview.widget.RecyclerView
|
||||||
|
|
Loading…
Reference in New Issue