Android 对话框是否有 windowMaxWidthMajor 和 windowMaxWidthMinor?
Is there a windowMaxWidthMajor and windowMaxWidthMinor for Android dialogs?
对于自定义 Android 对话框:
属性 android:windowMinWidthMajor
定义对话框沿主轴(即横向屏幕)宽度的最小尺寸。
属性 android:windowMaxWidthMinor
定义对话框沿短轴(即屏幕为纵向)时的最小宽度。
我们还可以定义对话框宽度的最大尺寸吗?
我会将您的对话框包裹在 LinearLayout 中并在其上设置最大宽度。
<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_height="wrap_content"
android:layout_width="fill_parent"
android:maxWidth="350dp" >
<Rest of the XML for your dialog layout>
</LinearLayout>
这是一个示例,说明如何使用最小 (10%) 和最大 (90%) 的百分比排列视图。它会将 TextView 或对话框代码的左边缘设置为屏幕宽度的 10%,将右边缘设置为屏幕宽度的 90%。它使用带有指南的 ConstraintLayout。 TextView 可以替换为您的对话框代码。
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.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:id="@+id/coordinatorLayout"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity" >
<androidx.constraintlayout.widget.Guideline
android:id="@+id/guideline2"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:orientation="vertical"
app:layout_constraintGuide_percent="0.10" />
<androidx.constraintlayout.widget.Guideline
android:id="@+id/guideline3"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:orientation="vertical"
app:layout_constraintGuide_percent="0.90" />
<TextView
android:id="@+id/textView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="TextView"
app:layout_constraintEnd_toStartOf="@+id/guideline3"
app:layout_constraintStart_toStartOf="@+id/guideline2"
app:layout_constraintTop_toTopOf="parent" />
</androidx.constraintlayout.widget.ConstraintLayout>
对于自定义 Android 对话框:
属性 android:windowMinWidthMajor
定义对话框沿主轴(即横向屏幕)宽度的最小尺寸。
属性 android:windowMaxWidthMinor
定义对话框沿短轴(即屏幕为纵向)时的最小宽度。
我们还可以定义对话框宽度的最大尺寸吗?
我会将您的对话框包裹在 LinearLayout 中并在其上设置最大宽度。
<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_height="wrap_content"
android:layout_width="fill_parent"
android:maxWidth="350dp" >
<Rest of the XML for your dialog layout>
</LinearLayout>
这是一个示例,说明如何使用最小 (10%) 和最大 (90%) 的百分比排列视图。它会将 TextView 或对话框代码的左边缘设置为屏幕宽度的 10%,将右边缘设置为屏幕宽度的 90%。它使用带有指南的 ConstraintLayout。 TextView 可以替换为您的对话框代码。
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.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:id="@+id/coordinatorLayout"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity" >
<androidx.constraintlayout.widget.Guideline
android:id="@+id/guideline2"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:orientation="vertical"
app:layout_constraintGuide_percent="0.10" />
<androidx.constraintlayout.widget.Guideline
android:id="@+id/guideline3"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:orientation="vertical"
app:layout_constraintGuide_percent="0.90" />
<TextView
android:id="@+id/textView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="TextView"
app:layout_constraintEnd_toStartOf="@+id/guideline3"
app:layout_constraintStart_toStartOf="@+id/guideline2"
app:layout_constraintTop_toTopOf="parent" />
</androidx.constraintlayout.widget.ConstraintLayout>