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 左右)和父级的边距并使用匹配约束。
我正在制作我的应用程序的主屏幕。在我完成后,它在设计屏幕上是完美的。但它在 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 左右)和父级的边距并使用匹配约束。