答案 0 :(得分:2)
您正在寻找约束布局。
1)在您的情况下,您的根布局是LinearLayout(垂直)
2)添加3个您选择的布局并设置“layout_weight”以满足您的需求 (默认权重总和为1,所以要有3个宽度相同的部分,每个部分设置为0.33如果你想让顶部和底部占据屏幕的40%,请将top_ bottom和layout_weight设置为0.4,将中间部分设置为0.2
[...]
<LinearLayout
android:layout_weight="0.33"
[...]
3)中心的布局应该是约束布局。
将中心元素对齐到屏幕中心,然后从那里到左右元素,从左右元素到屏幕边框。然后在父元素的顶部和底部绘制约束。请注意,对于不同的屏幕宽度,元素之间的间距无论如何都会有所不同。
要改变左右元素的间距,您可以尝试不同的屏幕尺寸并更改这些属性:
android:layout_marginStart="96dp"
如果您在中间部分使用按钮图标,则建议对不同的屏幕尺寸使用不同的尺寸和dpi。然后设置这些图像按钮的高度和宽度以包装内容。可以找到指南here。
示例代码如下:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:app="http://schemas.android.com/apk/res-auto"
android:orientation="vertical"
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent">
<LinearLayout
android:layout_weight="0.33"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
android:background="@color/colorPrimaryDark"></LinearLayout>
<android.support.constraint.ConstraintLayout
android:layout_weight="0.33"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<ImageView
android:id="@+id/imageView"
android:layout_width="32dp"
android:layout_height="32dp"
android:layout_marginBottom="8dp"
android:layout_marginStart="96dp"
android:layout_marginTop="8dp"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:srcCompat="@drawable/ic_home_black_24dp" />
<ImageView
android:id="@+id/imageView2"
android:layout_width="32dp"
android:layout_height="32dp"
android:layout_marginBottom="8dp"
android:layout_marginEnd="8dp"
android:layout_marginStart="8dp"
android:layout_marginTop="8dp"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toStartOf="@+id/imageView3"
app:layout_constraintStart_toEndOf="@+id/imageView"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintVertical_bias="0.495"
app:srcCompat="@drawable/ic_dashboard_black_24dp" />
<ImageView
android:id="@+id/imageView3"
android:layout_width="32dp"
android:layout_height="32dp"
android:layout_marginBottom="8dp"
android:layout_marginEnd="96dp"
android:layout_marginTop="8dp"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:srcCompat="@drawable/ic_notifications_black_24dp" />
</android.support.constraint.ConstraintLayout>
<LinearLayout
android:layout_weight="0.33"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
android:background="@color/colorPrimaryDark"></LinearLayout>
答案 1 :(得分:1)
可以使用两个嵌套的LinearLayout
来执行此操作。
在第一个LinearLayout
两个大按钮应该有layout_gravity
= top
和bottom
,layout_weight
= 1
,{{1} } = height
和0px
= width
。第一个布局也应该有match_parent
= orientation
。
三个小按钮的第二个布局应该嵌套在两个大按钮之间,固定vertical
= height
,32dp
= width
而不是{{1} }。
答案 2 :(得分:0)
您应该使用约束布局并将组件附加到布局,以便在布局大小更改时,组件的大小也会更改