Space 在小屏幕上不可见的按钮之间

Space between buttons not visible on small screen

我正在制作我的应用程序的主屏幕。在我完成后,它在设计屏幕上是完美的。但它在 Pixel 3a 模拟器中看起来一点也不像,在我的小米红米 4x 上更糟。如何让它在模拟器和我的 phone.

上看起来像设计屏幕变体

我尝试将 ConstraintLayout 与 View 一起使用,但它没有用。还有其他解决方案吗?

这是截图

我已经上传了屏幕截图,但它似乎不起作用

<androidx.drawerlayout.widget.DrawerLayout 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/drawer_layout"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="@drawable/main_screen_image"
    android:fitsSystemWindows="true"
    tools:context=".HomeScreen">
    <!--    tools:openDrawer="start"-->

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="vertical">

        <androidx.appcompat.widget.Toolbar
            android:id="@+id/toolbar"
            android:layout_width="match_parent"
            android:layout_height="?attr/actionBarSize"
            android:background="@color/purple_200"
            android:elevation="4dp"
            android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"
            app:popupTheme="@style/ThemeOverlay.AppCompat.Light" />
    </LinearLayout>

    <androidx.constraintlayout.widget.ConstraintLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="vertical"
        android:padding="20dp">

        <ImageView
            android:id="@+id/homeScreenLogo"
            android:layout_width="160dp"
            android:layout_height="160dp"
            android:layout_gravity="center"
            android:layout_marginTop="70dp"
            android:src="@drawable/kaznau_logo"
            app:layout_constraintEnd_toEndOf="parent"
            app:layout_constraintStart_toStartOf="parent"
            app:layout_constraintTop_toTopOf="parent" />

        <com.google.android.material.button.MaterialButton
            android:id="@+id/btnAboutUniversity"
            android:layout_width="160dp"
            android:layout_height="50dp"
            android:layout_marginStart="16dp"
            android:layout_marginLeft="16dp"
            android:layout_marginTop="70dp"
            android:drawableLeft="@drawable/ic_university"
            android:text="@string/s_about_kaznau"
            android:textSize="14sp"
            app:cornerRadius="5dp"
            app:layout_constraintStart_toStartOf="parent"
            app:layout_constraintTop_toBottomOf="@+id/homeScreenLogo" />

        <com.google.android.material.button.MaterialButton
            android:id="@+id/btnFaculties"
            android:layout_width="160dp"
            android:layout_height="50dp"
            android:layout_marginEnd="16dp"
            android:layout_marginRight="16dp"
            android:drawableLeft="@drawable/ic_faculty"
            android:text="Факультет"
            android:textSize="14sp"
            app:cornerRadius="5dp"
            app:layout_constraintBottom_toBottomOf="@+id/btnAboutUniversity"
            app:layout_constraintEnd_toEndOf="parent"
            app:layout_constraintTop_toTopOf="@+id/btnAboutUniversity" />

        <com.google.android.material.button.MaterialButton
            android:id="@+id/btnNews"
            android:layout_width="160dp"
            android:layout_height="50dp"
            android:layout_marginStart="16dp"
            android:layout_marginLeft="16dp"
            android:layout_marginTop="8dp"
            android:drawableLeft="@drawable/ic_baseline_article_24"
            android:text="@string/s_news"
            android:textSize="14sp"
            app:cornerRadius="5dp"
            app:layout_constraintStart_toStartOf="parent"
            app:layout_constraintTop_toBottomOf="@+id/btnAboutUniversity" />

        <com.google.android.material.button.MaterialButton
            android:id="@+id/btnEvents"
            android:layout_width="160dp"
            android:layout_height="50dp"
            android:layout_marginEnd="16dp"
            android:layout_marginRight="16dp"
            android:drawableLeft="@drawable/ic_baseline_event_24"
            android:text="@string/events_name"
            android:textSize="14sp"
            app:cornerRadius="5dp"
            app:layout_constraintBottom_toBottomOf="@+id/btnNews"
            app:layout_constraintEnd_toEndOf="parent"
            app:layout_constraintTop_toTopOf="@+id/btnNews" />

        <com.google.android.material.button.MaterialButton
            android:id="@+id/btnLocations"
            android:layout_width="160dp"
            android:layout_height="50dp"
            android:layout_marginStart="16dp"
            android:layout_marginLeft="16dp"
            android:layout_marginTop="8dp"
            android:drawableLeft="@drawable/ic_location"
            android:text="@string/s_locations"
            android:textSize="14sp"
            app:cornerRadius="5dp"
            app:layout_constraintStart_toStartOf="parent"
            app:layout_constraintTop_toBottomOf="@+id/btnNews" />

        <com.google.android.material.button.MaterialButton
            android:id="@+id/btnCampus"
            android:layout_width="160dp"
            android:layout_height="50dp"
            android:layout_marginEnd="16dp"
            android:layout_marginRight="16dp"
            android:drawableLeft="@drawable/ic_campus"
            android:text="@string/s_campus"
            android:textSize="14sp"
            app:cornerRadius="5dp"
            app:layout_constraintBottom_toBottomOf="@+id/btnLocations"
            app:layout_constraintEnd_toEndOf="parent"
            app:layout_constraintTop_toTopOf="@+id/btnLocations" />

        <com.google.android.material.button.MaterialButton
            android:id="@+id/btnLinks"
            android:layout_width="160dp"
            android:layout_height="50dp"
            android:layout_marginStart="16dp"
            android:layout_marginLeft="16dp"
            android:layout_marginTop="8dp"
            android:drawableLeft="@drawable/ic_links"
            android:text="@string/s_links"
            android:textSize="14sp"
            app:cornerRadius="5dp"
            app:layout_constraintStart_toStartOf="parent"
            app:layout_constraintTop_toBottomOf="@+id/btnLocations" />

        <com.google.android.material.button.MaterialButton
            android:id="@+id/btnContacts"
            android:layout_width="160dp"
            android:layout_height="50dp"
            android:layout_marginEnd="16dp"
            android:layout_marginRight="16dp"
            android:drawableLeft="@drawable/ic_contacts"
            android:text="@string/s_contacs"
            android:textSize="14sp"
            app:cornerRadius="5dp"
            app:layout_constraintBottom_toBottomOf="@+id/btnLinks"
            app:layout_constraintEnd_toEndOf="parent"
            app:layout_constraintTop_toTopOf="@+id/btnLinks" />

        <com.google.android.material.button.MaterialButton
            android:id="@+id/btnAgrodamu"
            android:layout_width="wrap_content"
            android:layout_height="50dp"
            android:layout_gravity="center"
            android:layout_marginTop="8dp"
            android:text="@string/s_agrodamu"
            android:textSize="14sp"
            app:cornerRadius="5dp"
            app:layout_constraintEnd_toEndOf="parent"
            app:layout_constraintStart_toStartOf="parent"
            app:layout_constraintTop_toBottomOf="@+id/btnLinks" />

    </androidx.constraintlayout.widget.ConstraintLayout>
</androidx.drawerlayout.widget.DrawerLayout>

最方便的做法是在 Constraint Layout 的中心添加 指南 并将您的观点与guideline 从左边或右边。这样无论屏幕尺寸是多少,您的布局都不会受到干扰。

让我们这样试试:

<androidx.drawerlayout.widget.DrawerLayout 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/drawer_layout"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@drawable/main_screen_image"
android:fitsSystemWindows="true"
tools:context=".HomeScreen">
<!--    tools:openDrawer="start"-->

<LinearLayout
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical">

    <androidx.appcompat.widget.Toolbar
        android:id="@+id/toolbar"
        android:layout_width="match_parent"
        android:layout_height="?attr/actionBarSize"
        android:background="@color/purple_200"
        android:elevation="4dp"
        android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"
        app:popupTheme="@style/ThemeOverlay.AppCompat.Light" />
</LinearLayout>

<androidx.constraintlayout.widget.ConstraintLayout
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    android:padding="20dp">

 <android.support.constraint.Guideline
        android:id="@+id/guideline39"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:orientation="vertical"
        app:layout_constraintGuide_percent="0.50" />

    <ImageView
        android:id="@+id/homeScreenLogo"
        android:layout_width="160dp"
        android:layout_height="160dp"
        android:layout_gravity="center"
        android:layout_marginTop="70dp"
        android:src="@drawable/kaznau_logo"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />

    <com.google.android.material.button.MaterialButton
        android:id="@+id/btnAboutUniversity"
        android:layout_width="160dp"
        android:layout_height="50dp"
        android:layout_marginStart="16dp"
        android:layout_marginLeft="16dp"
        android:layout_marginTop="70dp"
        android:layout_marginEnd="5dp"
        android:drawableLeft="@drawable/ic_university"
        android:text="@string/s_about_kaznau"
        android:textSize="14sp"
        app:cornerRadius="5dp"
        app:layout_constraintEnd_toStartOf="@+id/guideline39"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/homeScreenLogo" />

    <com.google.android.material.button.MaterialButton
        android:id="@+id/btnFaculties"
        android:layout_width="160dp"
        android:layout_height="50dp"
        android:layout_marginEnd="16dp"
        android:layout_marginRight="16dp"
        android:layout_marginStart="5dp"
        android:drawableLeft="@drawable/ic_faculty"
        android:text="Факультет"
        android:textSize="14sp"
        app:cornerRadius="5dp"
        app:layout_constraintStart_toStartOf="@+id/guideline39"
        app:layout_constraintBottom_toBottomOf="@+id/btnAboutUniversity"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintTop_toTopOf="@+id/btnAboutUniversity" />

    <com.google.android.material.button.MaterialButton
        android:id="@+id/btnNews"
        android:layout_width="160dp"
        android:layout_height="50dp"
        android:layout_marginStart="16dp"
        android:layout_marginLeft="16dp"
        android:layout_marginTop="8dp"
        android:layout_marginEnd="5dp"
        android:drawableLeft="@drawable/ic_baseline_article_24"
        android:text="@string/s_news"
        android:textSize="14sp"
        app:cornerRadius="5dp"
        app:layout_constraintEnd_toStartOf="@+id/guideline39"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/btnAboutUniversity" />

    <com.google.android.material.button.MaterialButton
        android:id="@+id/btnEvents"
        android:layout_width="160dp"
        android:layout_height="50dp"
        android:layout_marginEnd="16dp"
        android:layout_marginRight="16dp"
        android:layout_marginStart="5dp"
        android:drawableLeft="@drawable/ic_baseline_event_24"
        android:text="@string/events_name"
        android:textSize="14sp"
        app:cornerRadius="5dp"
        app:layout_constraintStart_toStartOf="@+id/guideline39"
        app:layout_constraintBottom_toBottomOf="@+id/btnNews"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintTop_toTopOf="@+id/btnNews" />

    <com.google.android.material.button.MaterialButton
        android:id="@+id/btnLocations"
        android:layout_width="160dp"
        android:layout_height="50dp"
        android:layout_marginStart="16dp"
        android:layout_marginLeft="16dp"
        android:layout_marginTop="8dp"
        android:layout_marginEnd="5dp"
        android:drawableLeft="@drawable/ic_location"
        android:text="@string/s_locations"
        android:textSize="14sp"
        app:cornerRadius="5dp"
        app:layout_constraintEnd_toStartOf="@+id/guideline39"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/btnNews" />

    <com.google.android.material.button.MaterialButton
        android:id="@+id/btnCampus"
        android:layout_width="160dp"
        android:layout_height="50dp"
        android:layout_marginEnd="16dp"
        android:layout_marginRight="16dp"
        android:layout_marginStart="5dp"
        android:drawableLeft="@drawable/ic_campus"
        android:text="@string/s_campus"
        android:textSize="14sp"
        app:cornerRadius="5dp"
        app:layout_constraintStart_toStartOf="@+id/guideline39"
        app:layout_constraintBottom_toBottomOf="@+id/btnLocations"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintTop_toTopOf="@+id/btnLocations" />

    <com.google.android.material.button.MaterialButton
        android:id="@+id/btnLinks"
        android:layout_width="160dp"
        android:layout_height="50dp"
        android:layout_marginStart="16dp"
        android:layout_marginLeft="16dp"
        android:layout_marginTop="8dp"
        android:layout_marginEnd="5dp"
        android:drawableLeft="@drawable/ic_links"
        android:text="@string/s_links"
        android:textSize="14sp"
        app:cornerRadius="5dp"
        app:layout_constraintEnd_toStartOf="@+id/guideline39"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/btnLocations" />

    <com.google.android.material.button.MaterialButton
        android:id="@+id/btnContacts"
        android:layout_width="160dp"
        android:layout_height="50dp"
        android:layout_marginEnd="16dp"
        android:layout_marginRight="16dp"
        android:layout_marginStart="5dp"
        android:drawableLeft="@drawable/ic_contacts"
        android:text="@string/s_contacs"
        android:textSize="14sp"
        app:cornerRadius="5dp"
        app:layout_constraintStart_toStartOf="@+id/guideline39"
        app:layout_constraintBottom_toBottomOf="@+id/btnLinks"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintTop_toTopOf="@+id/btnLinks" />

    <com.google.android.material.button.MaterialButton
        android:id="@+id/btnAgrodamu"
        android:layout_width="wrap_content"
        android:layout_height="50dp"
        android:layout_gravity="center"
        android:layout_marginTop="8dp"
        android:text="@string/s_agrodamu"
        android:textSize="14sp"
        app:cornerRadius="5dp"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/btnLinks" />

</androidx.constraintlayout.widget.ConstraintLayout>
</androidx.drawerlayout.widget.DrawerLayout>

将所有 material 按钮的 android:layout_width="160dp" 更改为 android:layout_width="wrap_content"

我不建议在布局中提供固定值,这就是为什么它在具有不同密度的屏幕尺寸上变得扭曲的原因,而是使用百分比。 也不需要为您的按钮提供外边缘边距,因为您已经为父级(ConstraintLayout)提供了填充。只需为右列按钮提供左边距。 这是我会采用的非常相似的方法。这是其中一个按钮,您可以将其应用于休息。另请具体参考 width 和 bias 属性,并根据您的设计进行调整。

<com.google.android.material.button.MaterialButton
            android:id="@+id/btnFaculties"
            android:layout_width="0dp"
            android:layout_height="50dp"
            android:layout_marginLeft="16dp"
            android:drawableLeft="@drawable/ic_faculty"
            android:text="Факультет"
            android:textSize="14sp"
            app:cornerRadius="5dp"
            app:layout_constraintBottom_toBottomOf="@+id/btnAboutUniversity"
            app:layout_constraintEnd_toEndOf="parent"
            app:layout_constraintStart_toEndOf="@+id/btnAboutUniversity" 
            app:layout_constraintWidth_percent="0.2" 
            app:layout_constraintHorizontal_bias="0.5"/>

使用匹配约束 (0dp) 而不是固定值,并像这样在中心使用指南

<androidx.constraintlayout.widget.Guideline
        android:id="@+id/guideline3"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:orientation="vertical"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintGuide_percent="0.5" //this is important
        app:layout_constraintHorizontal_bias="0.5"
        app:layout_constraintStart_toStartOf="parent" />

现在给你的按钮从指南(8dp 左右)和父级的边距并使用匹配约束。