在包裹在 ScrollView 中的 ConstraintLayout 中添加约束会切断底部
Adding constraint in ConstraintLayout wrapped in ScrollView cuts off bottom
我将 ConstraintLayout 包裹在 ScrollView 中。但是,如果我添加约束并且没有约束,某些东西会切断最后一个小部件,它会向下滚动而不切断。
下图是有约束的。所有小部件都以相同的方式连接到顶部。距离有多大并不重要。
这是没有约束的图片。
我试过边距和边距。添加填充后,它只是在底部工具栏上方创建了白色 space。我还尝试重新启动 AndroidStudio 和 Invalidate Caches/Restart。到目前为止没有成功。
这是代码
<?xml version="1.0" encoding="utf-8"?>
<ScrollView 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"
android:fillViewport="true"
tools:context="com.example.boss.abeacon.DataAcquisitionActivity">
<android.support.constraint.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="wrap_content"
tools:context="com.example.boss.abeacon.DataAcquisitionActivity">
<EditText
android:id="@+id/yCoordinate_editor"
android:layout_width="80dp"
android:layout_height="wrap_content"
android:layout_marginTop="8dp"
android:digits="0123456789"
android:ems="10"
android:imeOptions="actionDone"
android:inputType="numberSigned"
android:textSize="12sp"
app:layout_constraintStart_toStartOf="@+id/position_id_editor"
app:layout_constraintTop_toBottomOf="@+id/xCoordinate_editor" />
<EditText
android:id="@+id/xCoordinate_editor"
android:layout_width="80dp"
android:layout_height="wrap_content"
android:layout_marginTop="8dp"
android:digits="0123456789"
android:ems="10"
android:imeOptions="actionDone"
android:inputType="numberSigned"
android:textSize="12sp"
app:layout_constraintStart_toStartOf="@+id/position_id_editor"
app:layout_constraintTop_toBottomOf="@+id/position_id_editor" />
<TextView
android:id="@+id/label_number_of_data_editor"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginEnd="8dp"
android:text="Number of data \nin a position"
app:layout_constraintBottom_toBottomOf="@+id/number_of_data_editor"
app:layout_constraintEnd_toStartOf="@+id/number_of_data_editor" />
<EditText
android:id="@+id/inliers_window_editor"
android:layout_width="150dp"
android:layout_height="wrap_content"
android:layout_marginTop="16dp"
android:digits="1234567890"
android:ems="10"
android:hint="#"
android:imeOptions="actionDone"
android:inputType="number"
android:textSize="12sp"
app:layout_constraintStart_toStartOf="@+id/room_name_editor"
app:layout_constraintTop_toBottomOf="@+id/number_of_data_editor" />
<TextView
android:id="@+id/label_inliers_window_editor"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginBottom="8dp"
android:layout_marginEnd="8dp"
android:text="Inliers' window size"
app:layout_constraintBottom_toBottomOf="@+id/inliers_window_editor"
app:layout_constraintEnd_toStartOf="@+id/inliers_window_editor" />
<TextView
android:id="@+id/label_minor_bracon_editor"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginEnd="8dp"
android:text="Minor values \nof beacons"
app:layout_constraintBottom_toBottomOf="@+id/minor_beacon_editor"
app:layout_constraintEnd_toStartOf="@+id/minor_beacon_editor" />
<EditText
android:id="@+id/number_of_data_editor"
android:layout_width="150dp"
android:layout_height="wrap_content"
android:layout_marginTop="16dp"
android:digits="1234567890"
android:ems="10"
android:hint="#"
android:imeOptions="actionNext"
android:inputType="number"
android:textSize="12sp"
app:layout_constraintStart_toStartOf="@+id/room_name_editor"
app:layout_constraintTop_toBottomOf="@+id/minor_beacon_editor" />
<EditText
android:id="@+id/minor_beacon_editor"
android:layout_width="150dp"
android:layout_height="0dp"
android:layout_marginTop="16dp"
android:digits="1234567890 "
android:ems="10"
android:hint="1 2 3 10 21"
android:imeOptions="actionNext"
android:inputType="number"
android:textSize="12sp"
app:layout_constraintStart_toStartOf="@+id/room_name_editor"
app:layout_constraintTop_toBottomOf="@+id/room_name_editor" />
<TextView
android:id="@+id/label_position_id_editor"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginBottom="8dp"
android:layout_marginEnd="8dp"
android:text="Position ID"
app:layout_constraintBottom_toBottomOf="@+id/position_id_editor"
app:layout_constraintEnd_toStartOf="@+id/position_id_editor" />
<EditText
android:id="@+id/position_id_editor"
android:layout_width="80dp"
android:layout_height="wrap_content"
android:layout_marginTop="8dp"
android:digits="0123456789"
android:ems="10"
android:imeOptions="actionDone"
android:inputType="number"
android:textSize="12sp"
app:layout_constraintStart_toStartOf="@+id/room_name_editor"
app:layout_constraintTop_toBottomOf="@+id/auto_position_id_checkBox" />
<TextView
android:id="@+id/label_room_name_editor"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginBottom="8dp"
android:layout_marginEnd="8dp"
android:text="Room name"
app:layout_constraintBottom_toBottomOf="@+id/room_name_editor"
app:layout_constraintEnd_toStartOf="@+id/room_name_editor" />
<EditText
android:id="@+id/room_name_editor"
android:layout_width="150dp"
android:layout_height="wrap_content"
android:layout_marginStart="150dp"
android:layout_marginTop="32dp"
android:ems="10"
android:hint="Enter file name"
android:inputType="textPersonName"
android:textSize="12sp"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" />
<Button
android:id="@+id/scan_btn"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_marginEnd="32dp"
android:layout_marginStart="32dp"
android:text="Start"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
tools:layout_editor_absoluteY="515dp" />
<TextView
android:id="@+id/kazoeru"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginBottom="20dp"
android:layout_marginStart="32dp"
android:text="#"
app:layout_constraintBottom_toTopOf="@+id/scan_btn"
app:layout_constraintStart_toStartOf="parent" />
<CheckBox
android:id="@+id/auto_position_id_checkBox"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="32dp"
android:text="Auto position ID"
android:textSize="12sp"
app:layout_constraintStart_toStartOf="@+id/position_id_editor"
app:layout_constraintTop_toBottomOf="@+id/setParameters_btn" />
<TextView
android:id="@+id/last_position_id"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginBottom="8dp"
android:layout_marginStart="8dp"
android:textSize="12sp"
app:layout_constraintBottom_toBottomOf="@+id/position_id_editor"
app:layout_constraintStart_toEndOf="@+id/position_id_editor" />
<TextView
android:id="@+id/label_xCoordinate_editor"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginBottom="8dp"
android:layout_marginEnd="8dp"
android:text="X"
app:layout_constraintBottom_toBottomOf="@+id/xCoordinate_editor"
app:layout_constraintEnd_toStartOf="@+id/xCoordinate_editor" />
<TextView
android:id="@+id/label_yCoordinate_editor"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginBottom="8dp"
android:layout_marginEnd="8dp"
android:text="Y"
app:layout_constraintBottom_toBottomOf="@+id/yCoordinate_editor"
app:layout_constraintEnd_toStartOf="@+id/yCoordinate_editor" />
<TextView
android:id="@+id/last_xCoordinate"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginBottom="8dp"
android:layout_marginStart="8dp"
app:layout_constraintBottom_toBottomOf="@+id/xCoordinate_editor"
app:layout_constraintStart_toEndOf="@+id/xCoordinate_editor" />
<TextView
android:id="@+id/last_yCoordinate"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginBottom="8dp"
android:layout_marginStart="8dp"
app:layout_constraintBottom_toBottomOf="@+id/yCoordinate_editor"
app:layout_constraintStart_toEndOf="@+id/yCoordinate_editor" />
<Button
android:id="@+id/setParameters_btn"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_marginEnd="32dp"
android:layout_marginStart="32dp"
android:layout_marginTop="8dp"
android:onClick="setParametersButtonOnClick"
android:text="Set parameters"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/inliers_window_editor" />
</android.support.constraint.ConstraintLayout>
</ScrollView>
我是运行Ubuntu16.04.LTS和最新版本的AndroidStudio.
更新
该布局适用于最新的测试版。升级到 1.1.0-beta3 将解决问题。
关于设计器布局的差异,请查看 scan_btn
的 XML。如果没有顶部约束,设计者会在其上施加一个距顶部 515dp
的位置。这只是为了在设置所有约束之前保持原样。
tools:layout_editor_absoluteY="515dp"
当您使用 32dp
约束顶部时,不会使用上面的设计器位置,而是使用上方小部件的 32dp
。这将解释有和没有顶部约束的位置差异。您必须限制顶部,否则小部件将浮动到顶部,因为设计器约束只在设计器中不起作用,因此请选择适合您的顶部约束和顶部边距。
我将 ConstraintLayout 包裹在 ScrollView 中。但是,如果我添加约束并且没有约束,某些东西会切断最后一个小部件,它会向下滚动而不切断。
下图是有约束的。所有小部件都以相同的方式连接到顶部。距离有多大并不重要。
这是没有约束的图片。
我试过边距和边距。添加填充后,它只是在底部工具栏上方创建了白色 space。我还尝试重新启动 AndroidStudio 和 Invalidate Caches/Restart。到目前为止没有成功。
这是代码
<?xml version="1.0" encoding="utf-8"?>
<ScrollView 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"
android:fillViewport="true"
tools:context="com.example.boss.abeacon.DataAcquisitionActivity">
<android.support.constraint.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="wrap_content"
tools:context="com.example.boss.abeacon.DataAcquisitionActivity">
<EditText
android:id="@+id/yCoordinate_editor"
android:layout_width="80dp"
android:layout_height="wrap_content"
android:layout_marginTop="8dp"
android:digits="0123456789"
android:ems="10"
android:imeOptions="actionDone"
android:inputType="numberSigned"
android:textSize="12sp"
app:layout_constraintStart_toStartOf="@+id/position_id_editor"
app:layout_constraintTop_toBottomOf="@+id/xCoordinate_editor" />
<EditText
android:id="@+id/xCoordinate_editor"
android:layout_width="80dp"
android:layout_height="wrap_content"
android:layout_marginTop="8dp"
android:digits="0123456789"
android:ems="10"
android:imeOptions="actionDone"
android:inputType="numberSigned"
android:textSize="12sp"
app:layout_constraintStart_toStartOf="@+id/position_id_editor"
app:layout_constraintTop_toBottomOf="@+id/position_id_editor" />
<TextView
android:id="@+id/label_number_of_data_editor"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginEnd="8dp"
android:text="Number of data \nin a position"
app:layout_constraintBottom_toBottomOf="@+id/number_of_data_editor"
app:layout_constraintEnd_toStartOf="@+id/number_of_data_editor" />
<EditText
android:id="@+id/inliers_window_editor"
android:layout_width="150dp"
android:layout_height="wrap_content"
android:layout_marginTop="16dp"
android:digits="1234567890"
android:ems="10"
android:hint="#"
android:imeOptions="actionDone"
android:inputType="number"
android:textSize="12sp"
app:layout_constraintStart_toStartOf="@+id/room_name_editor"
app:layout_constraintTop_toBottomOf="@+id/number_of_data_editor" />
<TextView
android:id="@+id/label_inliers_window_editor"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginBottom="8dp"
android:layout_marginEnd="8dp"
android:text="Inliers' window size"
app:layout_constraintBottom_toBottomOf="@+id/inliers_window_editor"
app:layout_constraintEnd_toStartOf="@+id/inliers_window_editor" />
<TextView
android:id="@+id/label_minor_bracon_editor"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginEnd="8dp"
android:text="Minor values \nof beacons"
app:layout_constraintBottom_toBottomOf="@+id/minor_beacon_editor"
app:layout_constraintEnd_toStartOf="@+id/minor_beacon_editor" />
<EditText
android:id="@+id/number_of_data_editor"
android:layout_width="150dp"
android:layout_height="wrap_content"
android:layout_marginTop="16dp"
android:digits="1234567890"
android:ems="10"
android:hint="#"
android:imeOptions="actionNext"
android:inputType="number"
android:textSize="12sp"
app:layout_constraintStart_toStartOf="@+id/room_name_editor"
app:layout_constraintTop_toBottomOf="@+id/minor_beacon_editor" />
<EditText
android:id="@+id/minor_beacon_editor"
android:layout_width="150dp"
android:layout_height="0dp"
android:layout_marginTop="16dp"
android:digits="1234567890 "
android:ems="10"
android:hint="1 2 3 10 21"
android:imeOptions="actionNext"
android:inputType="number"
android:textSize="12sp"
app:layout_constraintStart_toStartOf="@+id/room_name_editor"
app:layout_constraintTop_toBottomOf="@+id/room_name_editor" />
<TextView
android:id="@+id/label_position_id_editor"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginBottom="8dp"
android:layout_marginEnd="8dp"
android:text="Position ID"
app:layout_constraintBottom_toBottomOf="@+id/position_id_editor"
app:layout_constraintEnd_toStartOf="@+id/position_id_editor" />
<EditText
android:id="@+id/position_id_editor"
android:layout_width="80dp"
android:layout_height="wrap_content"
android:layout_marginTop="8dp"
android:digits="0123456789"
android:ems="10"
android:imeOptions="actionDone"
android:inputType="number"
android:textSize="12sp"
app:layout_constraintStart_toStartOf="@+id/room_name_editor"
app:layout_constraintTop_toBottomOf="@+id/auto_position_id_checkBox" />
<TextView
android:id="@+id/label_room_name_editor"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginBottom="8dp"
android:layout_marginEnd="8dp"
android:text="Room name"
app:layout_constraintBottom_toBottomOf="@+id/room_name_editor"
app:layout_constraintEnd_toStartOf="@+id/room_name_editor" />
<EditText
android:id="@+id/room_name_editor"
android:layout_width="150dp"
android:layout_height="wrap_content"
android:layout_marginStart="150dp"
android:layout_marginTop="32dp"
android:ems="10"
android:hint="Enter file name"
android:inputType="textPersonName"
android:textSize="12sp"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" />
<Button
android:id="@+id/scan_btn"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_marginEnd="32dp"
android:layout_marginStart="32dp"
android:text="Start"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
tools:layout_editor_absoluteY="515dp" />
<TextView
android:id="@+id/kazoeru"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginBottom="20dp"
android:layout_marginStart="32dp"
android:text="#"
app:layout_constraintBottom_toTopOf="@+id/scan_btn"
app:layout_constraintStart_toStartOf="parent" />
<CheckBox
android:id="@+id/auto_position_id_checkBox"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="32dp"
android:text="Auto position ID"
android:textSize="12sp"
app:layout_constraintStart_toStartOf="@+id/position_id_editor"
app:layout_constraintTop_toBottomOf="@+id/setParameters_btn" />
<TextView
android:id="@+id/last_position_id"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginBottom="8dp"
android:layout_marginStart="8dp"
android:textSize="12sp"
app:layout_constraintBottom_toBottomOf="@+id/position_id_editor"
app:layout_constraintStart_toEndOf="@+id/position_id_editor" />
<TextView
android:id="@+id/label_xCoordinate_editor"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginBottom="8dp"
android:layout_marginEnd="8dp"
android:text="X"
app:layout_constraintBottom_toBottomOf="@+id/xCoordinate_editor"
app:layout_constraintEnd_toStartOf="@+id/xCoordinate_editor" />
<TextView
android:id="@+id/label_yCoordinate_editor"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginBottom="8dp"
android:layout_marginEnd="8dp"
android:text="Y"
app:layout_constraintBottom_toBottomOf="@+id/yCoordinate_editor"
app:layout_constraintEnd_toStartOf="@+id/yCoordinate_editor" />
<TextView
android:id="@+id/last_xCoordinate"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginBottom="8dp"
android:layout_marginStart="8dp"
app:layout_constraintBottom_toBottomOf="@+id/xCoordinate_editor"
app:layout_constraintStart_toEndOf="@+id/xCoordinate_editor" />
<TextView
android:id="@+id/last_yCoordinate"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginBottom="8dp"
android:layout_marginStart="8dp"
app:layout_constraintBottom_toBottomOf="@+id/yCoordinate_editor"
app:layout_constraintStart_toEndOf="@+id/yCoordinate_editor" />
<Button
android:id="@+id/setParameters_btn"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_marginEnd="32dp"
android:layout_marginStart="32dp"
android:layout_marginTop="8dp"
android:onClick="setParametersButtonOnClick"
android:text="Set parameters"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/inliers_window_editor" />
</android.support.constraint.ConstraintLayout>
</ScrollView>
我是运行Ubuntu16.04.LTS和最新版本的AndroidStudio.
更新 该布局适用于最新的测试版。升级到 1.1.0-beta3 将解决问题。
关于设计器布局的差异,请查看 scan_btn
的 XML。如果没有顶部约束,设计者会在其上施加一个距顶部 515dp
的位置。这只是为了在设置所有约束之前保持原样。
tools:layout_editor_absoluteY="515dp"
当您使用 32dp
约束顶部时,不会使用上面的设计器位置,而是使用上方小部件的 32dp
。这将解释有和没有顶部约束的位置差异。您必须限制顶部,否则小部件将浮动到顶部,因为设计器约束只在设计器中不起作用,因此请选择适合您的顶部约束和顶部边距。