
Do two things to the margin and padding system: - Remove the redundant padding/margin dimens and replace it with a unified "spacing" dimen namespace - Make most margin and padding dimens follow the divisible-by-8 rule in material design
104 lines
No EOL
4.7 KiB
XML
104 lines
No EOL
4.7 KiB
XML
<?xml version="1.0" encoding="utf-8"?>
|
|
<layout xmlns:android="http://schemas.android.com/apk/res/android"
|
|
xmlns:app="http://schemas.android.com/apk/res-auto"
|
|
xmlns:tools="http://schemas.android.com/tools"
|
|
tools:context=".playback.CompactPlaybackFragment">
|
|
|
|
<data>
|
|
|
|
<variable
|
|
name="song"
|
|
type="org.oxycblt.auxio.music.Song" />
|
|
|
|
<variable
|
|
name="playbackModel"
|
|
type="org.oxycblt.auxio.playback.PlaybackViewModel" />
|
|
</data>
|
|
|
|
<androidx.constraintlayout.widget.ConstraintLayout
|
|
android:id="@+id/playback_layout"
|
|
android:layout_width="match_parent"
|
|
android:layout_height="wrap_content"
|
|
android:animateLayoutChanges="true"
|
|
android:background="@drawable/ui_background_ripple"
|
|
android:clickable="true"
|
|
android:focusable="true">
|
|
|
|
<ProgressBar
|
|
android:id="@+id/playback_progress"
|
|
style="?android:attr/progressBarStyleHorizontal"
|
|
android:layout_width="match_parent"
|
|
android:layout_height="@dimen/height_compact_progress"
|
|
android:clickable="false"
|
|
android:progress="@{playbackModel.positionAsProgress}"
|
|
android:progressBackgroundTint="?attr/colorControlNormal"
|
|
android:progressTint="?attr/colorPrimary"
|
|
app:layout_constraintStart_toStartOf="parent"
|
|
app:layout_constraintTop_toTopOf="parent"
|
|
tools:progress="70" />
|
|
|
|
<ImageView
|
|
android:id="@+id/playback_cover"
|
|
android:layout_width="@dimen/size_cover_compact"
|
|
android:layout_height="@dimen/size_cover_compact"
|
|
android:layout_margin="@dimen/spacing_small"
|
|
android:contentDescription="@{@string/description_album_cover(song.name)}"
|
|
app:albumArt="@{song}"
|
|
app:layout_constraintBottom_toBottomOf="parent"
|
|
app:layout_constraintStart_toStartOf="parent"
|
|
app:layout_constraintTop_toBottomOf="@+id/playback_progress"
|
|
tools:src="@drawable/ic_song" />
|
|
|
|
<TextView
|
|
android:id="@+id/playback_song"
|
|
android:layout_width="0dp"
|
|
android:layout_height="wrap_content"
|
|
android:layout_marginStart="@dimen/spacing_small"
|
|
android:layout_marginEnd="@dimen/spacing_small"
|
|
android:ellipsize="end"
|
|
android:fontFamily="@font/inter_semibold"
|
|
android:singleLine="true"
|
|
android:text="@{song.name}"
|
|
android:textAlignment="viewStart"
|
|
android:textAppearance="@style/TextAppearance.SmallHeader"
|
|
app:layout_constraintBottom_toTopOf="@+id/playback_info"
|
|
app:layout_constraintEnd_toStartOf="@+id/playback_play_pause"
|
|
app:layout_constraintStart_toEndOf="@+id/playback_cover"
|
|
app:layout_constraintTop_toTopOf="parent"
|
|
app:layout_constraintVertical_chainStyle="packed"
|
|
tools:text="Song Name" />
|
|
|
|
<TextView
|
|
android:id="@+id/playback_info"
|
|
android:layout_width="0dp"
|
|
android:layout_height="wrap_content"
|
|
android:layout_marginStart="@dimen/spacing_small"
|
|
android:layout_marginEnd="@dimen/spacing_small"
|
|
android:ellipsize="end"
|
|
android:singleLine="true"
|
|
android:text="@{@string/format_info(song.album.artist.name, song.album.name)}"
|
|
android:textAlignment="viewStart"
|
|
android:textAppearance="@style/TextAppearance.MaterialComponents.Caption"
|
|
app:layout_constraintBottom_toBottomOf="parent"
|
|
app:layout_constraintEnd_toStartOf="@+id/playback_play_pause"
|
|
app:layout_constraintStart_toEndOf="@+id/playback_cover"
|
|
app:layout_constraintTop_toBottomOf="@+id/playback_song"
|
|
tools:text="Artist Name / Album Name" />
|
|
|
|
<org.oxycblt.auxio.playback.PlayPauseButton
|
|
android:id="@+id/playback_play_pause"
|
|
style="@style/Widget.AppCompat.Button.Borderless"
|
|
android:layout_width="@dimen/size_play_pause_compact"
|
|
android:layout_height="@dimen/size_play_pause_compact"
|
|
android:layout_marginEnd="@dimen/spacing_small"
|
|
android:background="@drawable/ui_unbounded_ripple"
|
|
android:contentDescription="@string/description_play_pause"
|
|
android:onClick="@{() -> playbackModel.invertPlayingStatus()}"
|
|
android:tint="@color/control_color"
|
|
app:layout_constraintBottom_toBottomOf="parent"
|
|
app:layout_constraintEnd_toEndOf="parent"
|
|
app:layout_constraintTop_toTopOf="parent"
|
|
tools:src="@drawable/ic_play_large" />
|
|
|
|
</androidx.constraintlayout.widget.ConstraintLayout>
|
|
</layout> |