我尝试在两个具有ConstraintLayout
的活动中使用自己的工具栏。
在一个活动中,我在工具栏下方放置了一个按钮,看起来不错:
但是,在另一个活动中,我在工具栏下方放置了一个ListView
,突然之间,工具栏和ListView之间有很大的差距:
我应该注意,这不会出现在AndroidStudio
的预览中。
活动的布局完全相同,在Manifest
中,我将应用程序主题设置为NoActionBar
。
我对任何帮助感到高兴:)
以下是“不良”活动的一些代码:
<?xml version="1.0" encoding="utf-8"?>
<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="match_parent"
tools:context="com.example.nutritionanalyzer.RecipeOverviewActivity">
<android.support.v7.widget.Toolbar
android:id="@+id/recipe_overview_toolbar"
android:layout_width="match_parent"
android:layout_height="?attr/actionBarSize"
android:background="?attr/colorPrimary"
android:elevation="4dp"
android:theme="@style/ThemeOverlay.AppCompat.ActionBar"
android:visibility="visible"
app:popupTheme="@style/ThemeOverlay.AppCompat.Dark" />
<ListView
android:id="@+id/recipeOverviewListView"
android:layout_width="368dp"
android:layout_height="495dp"
android:layout_marginBottom="8dp"
android:layout_marginEnd="8dp"
android:layout_marginStart="8dp"
android:layout_marginTop="8dp"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHorizontal_bias="1.0"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/recipe_overview_toolbar" />
</android.support.constraint.ConstraintLayout>
也许是线
android:theme="@style/ThemeOverlay.AppCompat.ActionBar"
有罪吗?但是我在“好”活动中有完全一样的话……
答案 0 :(得分:1)
只需在ListView中设置android:layout_height="0dp"
,因为当您将约束布局中的子项的宽度和高度设置为零以外的其他值并且该子项的锚点边缘时,由于已设置了这些属性,因此视图将居中于锚点之间(您拥有锚视图的顶部和底部边缘):
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintTop_toBottomOf="@+id/recipe_overview_toolbar" />
我想如果您只想设置android:layout_width="0dp"
,也想让listView匹配父级宽度,因为您在listView中具有这些属性(您将listView水平锚定到父级):
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
并删除:
app:layout_constraintHorizontal_bias="1.0"