xml - 如何在 Android Studio 中为部分约束布局添加背景颜色?
问题描述
我创建了一个简单的约束布局,在最右边的列上有一个按钮列表。我已将整个背景设置为透明,但有些人希望覆盖按钮后面的列以具有其他颜色背景。我可以有什么不同的选择来实现这个设计。任何帮助将不胜感激,我还添加了两个屏幕截图。第一个屏幕截图是整个约束背景透明,作为我的 xml 代码的输出。我希望在另一种颜色的按钮后面有另一个由黑框标记的背景。我怎样才能实现它。
我的带有使用约束布局的图像按钮的 xml 代码。
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout
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"
android:id="@+id/linearLayout"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="#00000000"
android:gravity="center">
<Button
android:id="@+id/buttonShowPreview"
android:layout_width="100dp"
android:layout_height="wrap_content"
android:layout_marginStart="120dp"
android:background="@null"
android:onClick="showPreview"
android:src="@drawable/decline"
android:textSize="0dp"
app:layout_constraintBottom_toTopOf="@+id/textViewPeer"
app:layout_constraintEnd_toEndOf="@+id/surfaceIncomingVideo"
app:layout_constraintHorizontal_bias="0.716"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintVertical_bias="0.547" />
<ImageButton
android:id="@+id/buttonAccept"
android:layout_width="72dp"
android:layout_height="107dp"
android:layout_marginBottom="44dp"
android:background="@null"
android:onClick="acceptCall"
android:scaleType="fitCenter"
android:src="@drawable/answer"
android:text="Accept"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHorizontal_bias="0.946"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="@+id/textViewCallState"
app:layout_constraintVertical_bias="0.794" />
<ImageView
android:id="@+id/voiceCall"
android:layout_width="300dp"
android:layout_height="300dp"
android:visibility="invisible"
app:layout_constraintBottom_toBottomOf="@+id/surfaceIncomingVideo"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHorizontal_bias="0.419"
app:layout_constraintStart_toStartOf="@+id/surfaceIncomingVideo"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintVertical_bias="0.466"
app:srcCompat="@drawable/voice" />
<ImageButton
android:id="@+id/imageButton"
android:layout_width="72dp"
android:layout_height="107dp"
android:layout_marginBottom="32dp"
android:background="@null"
android:onClick="hidevideo"
android:scaleType="fitCenter"
android:src="@drawable/videohide"
android:text="Accept"
android:visibility="visible"
app:layout_constraintBottom_toTopOf="@+id/mute"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHorizontal_bias="0.944"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintVertical_bias="1.0" />
<ImageButton
android:id="@+id/buttonHangup"
android:layout_width="80dp"
android:layout_height="100dp"
android:layout_marginBottom="60dp"
android:background="@null"
android:onClick="hangupCall"
android:scaleType="fitCenter"
android:src="@drawable/decline"
android:text="Reject"
app:layout_constraintBottom_toTopOf="@+id/buttonAccept"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHorizontal_bias="0.956"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintVertical_bias="1.0"
app:layout_constraintVertical_chainStyle="packed" />
<ImageButton
android:id="@+id/mute"
android:layout_width="70dp"
android:layout_height="70dp"
android:background="@null"
android:onClick="unmute"
android:scaleType="fitCenter"
android:src="@drawable/mute"
android:visibility="invisible"
app:layout_constraintBottom_toTopOf="@+id/buttonHangup"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHorizontal_bias="0.946"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintVertical_bias="0.777"
app:layout_constraintVertical_chainStyle="packed" />
<ImageButton
android:id="@+id/unmute"
android:layout_width="70dp"
android:layout_height="70dp"
android:background="@null"
android:onClick="mute"
android:scaleType="fitCenter"
android:src="@drawable/unmute"
android:visibility="visible"
app:layout_constraintBottom_toTopOf="@+id/buttonHangup"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHorizontal_bias="0.942"
app:layout_constraintStart_toStartOf="@+id/surfaceIncomingVideo"
app:layout_constraintTop_toBottomOf="@+id/imageButton"
app:layout_constraintVertical_bias="0.395" />
</androidx.constraintlayout.widget.ConstraintLayout>
解决方案
你可以简单地在你的按钮下放置一些视图(这个视图将是你想要用颜色绘制的屏幕部分)并给它一个颜色:
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout
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"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity">
<TextView
android:id="@+id/button5"
android:layout_width="0dp"
android:layout_height="0dp"
android:background="#57DDAADA"
app:layout_constraintWidth_percent="0.25"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" />
<Button
android:id="@+id/button7"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:text="Button"
android:elevation="6dp"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="@+id/button10"
app:layout_constraintStart_toStartOf="@+id/button10"
app:layout_constraintTop_toBottomOf="@+id/button8" />
<Button
android:id="@+id/button8"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:text="Button"
android:elevation="6dp"
app:layout_constraintBottom_toTopOf="@+id/button7"
app:layout_constraintEnd_toEndOf="@+id/button10"
app:layout_constraintStart_toStartOf="@+id/button10"
app:layout_constraintTop_toBottomOf="@+id/button9" />
<Button
android:id="@+id/button9"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:text="Button"
android:elevation="6dp"
app:layout_constraintBottom_toTopOf="@+id/button8"
app:layout_constraintEnd_toEndOf="@+id/button10"
app:layout_constraintStart_toStartOf="@+id/button10"
app:layout_constraintTop_toBottomOf="@+id/button10" />
<Button
android:id="@+id/button10"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:text="Button"
android:elevation="6dp"
app:layout_constraintBottom_toTopOf="@+id/button9"
app:layout_constraintEnd_toEndOf="@+id/button5"
app:layout_constraintStart_toStartOf="@+id/button5"
app:layout_constraintTop_toTopOf="parent" />
</androidx.constraintlayout.widget.ConstraintLayout>
推荐阅读
- python - 如何在 python slice = [:] 中使用 lentgh 变量
- laravel - laravel 播种机多语言
- winapi - Media Foundation Transform 能否实现多个应用同时访问网络摄像头?
- python - 使用“插入或忽略”语句加速 Python 执行
- spring-boot - 如何为 kibana 和 apm-server 启用执行器健康
- node.js - 无法使用带有 $eq 的 FindByIdAndUpdate 进行更新
- webpack - 在 Javascript 模块中自动导入 css
- python - How to write multiple rows in column excel python?
- java - Flutter FirebaseCloudMessagingPluginRegistrant 没找到?
- python - Python 编码需要在第 1 行修复