android - 如何为原生应用程序进行响应式设计?
问题描述
我正在构建的应用程序有问题。我不知道我们如何才能使应用程序对设备的多个维度做出响应。我创建了一个尺寸文件,其中包含我使用 Nexus 5 (360dp x 640dp) 的尺寸创建的每个布局的所有尺寸。然后我下载了 Dimenify 插件并尝试为 Nexus 5X (411dp x 731dp) 缩放它。我创建了一个名为 dimens.xml (sw411dp) 的新文件,比 Nexus 5X 的尺寸增加了 15%。问题是宽度是我可以控制的,但是有许多设备具有相同的宽度但具有不同的高度。
下面是底部的 MenuBar 示例:
<layout 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/menu_bar_fragment"
android:orientation="vertical">
<data>
<variable
name="menuBarViewModelFragment"
type="com.app.multired.viewmodel.MenuBarViewModelFragment" />
</data>
<androidx.constraintlayout.widget.ConstraintLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".ui.Fragments.MenuBarFragment">
<ImageView
android:id="@+id/ivMenuFondo"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:background="@drawable/menufondo"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" />
<ImageView
android:id="@+id/ivMenuFondoSuperior"
android:layout_width="match_parent"
android:layout_height="@dimen/layoutHeightIvMenuFondoSuperior"
android:background="@drawable/menufondosuperior"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" />
<ImageView
android:id="@+id/ivMenuFondoInferior"
android:layout_width="match_parent"
android:layout_height="@dimen/layoutHeightIvMenuFondoInferior"
android:background="@drawable/menufondoinferior"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent" />
<ImageView
android:id="@+id/ivNotificacion"
android:layout_width="@dimen/layoutWidthNotificacion"
android:layout_height="@dimen/layoutHeightNotificacion"
android:layout_marginStart="@dimen/marginStartNotificacion"
android:layout_marginTop="@dimen/marginTopNotificacion"
android:layout_marginBottom="@dimen/marginBottomNotificacion"
app:layout_constraintBottom_toBottomOf="@+id/ivMenuFondoSuperior"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:srcCompat="@drawable/notificacionoff" />
<ImageView
android:id="@+id/ivMas"
android:layout_width="@dimen/layoutWidthAyuda"
android:layout_height="@dimen/layoutHeightAyuda"
android:layout_marginStart="@dimen/marginStartAyuda"
android:layout_marginTop="@dimen/marginTopAyuda"
android:layout_marginEnd="@dimen/marginEndAyuda"
android:layout_marginBottom="@dimen/marginBottomAyuda"
app:layout_constraintBottom_toBottomOf="@+id/ivMenuFondoSuperior"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toEndOf="@+id/ivNotificacion"
app:layout_constraintTop_toTopOf="parent"
app:srcCompat="@drawable/botonmas" />
<LinearLayout
android:layout_width="match_parent"
android:layout_height="@dimen/layoutHeightLayoutMenuFragment"
android:orientation="horizontal"
app:layout_constraintBottom_toBottomOf="@+id/ivMenuFondoInferior"
app:layout_constraintEnd_toEndOf="@+id/ivMenuFondoInferior"
app:layout_constraintStart_toStartOf="@id/ivMenuFondoInferior"
app:layout_constraintTop_toTopOf="@+id/ivMenuFondoInferior">
<LinearLayout
android:layout_width="@dimen/layoutWidthLayoutInicio"
android:layout_height="match_parent"
android:layout_marginStart="@dimen/marginStartLayoutInicio"
android:layout_marginTop="@dimen/marginTopLinearLayoutButton"
android:orientation="vertical">
<ImageView
android:id="@+id/ivInicio"
android:layout_width="match_parent"
android:layout_height="@dimen/layoutHeightIvInicio"
android:layout_gravity="center"
app:srcCompat="@drawable/botoninicio" />
<TextView
android:id="@+id/tvInicio"
android:layout_width="wrap_content"
android:layout_height="@dimen/layoutHeightTvInicio"
android:layout_gravity="center"
android:fontFamily="@font/opensans"
android:text="@string/inicio"
android:textColor="@color/blanco"
android:textSize="@dimen/textSizeTvInicio" />
</LinearLayout>
<LinearLayout
android:layout_width="@dimen/layoutWidthLayoutQR"
android:layout_height="match_parent"
android:layout_marginStart="@dimen/_35sdp"
android:orientation="vertical"
android:layout_marginTop="@dimen/marginTopLinearLayoutButton">
<ImageView
android:id="@+id/ivQR"
android:layout_width="match_parent"
android:layout_height="@dimen/layoutHeightIvQR"
android:layout_gravity="center"
app:srcCompat="@drawable/botonqr" />
<TextView
android:id="@+id/tvQR"
android:layout_width="wrap_content"
android:layout_height="@dimen/layoutHeightTvQR"
android:layout_gravity="center"
android:fontFamily="@font/opensans"
android:text="@string/retirar"
android:textColor="@color/blanco"
android:textSize="@dimen/textSizeTvQR" />
</LinearLayout>
<LinearLayout
android:layout_width="@dimen/layoutWidthLayoutHistorial"
android:layout_height="match_parent"
android:layout_marginStart="@dimen/_35sdp"
android:orientation="vertical"
android:layout_marginTop="@dimen/marginTopLinearLayoutButton">
<ImageView
android:id="@+id/ivHistorial"
android:layout_width="match_parent"
android:layout_height="@dimen/layoutHeightIvHistorial"
android:layout_gravity="center"
app:layout_constraintBottom_toBottomOf="@+id/ivMenuFondoInferior"
app:layout_constraintStart_toEndOf="@+id/ivRetirar"
app:layout_constraintTop_toTopOf="@+id/ivMenuFondoInferior"
app:srcCompat="@drawable/botonhistorial" />
<TextView
android:id="@+id/tvHistorial"
android:layout_width="wrap_content"
android:layout_height="@dimen/layoutHeightTvHistorial"
android:layout_gravity="center"
android:fontFamily="@font/opensans"
android:text="@string/historial"
android:textColor="@color/blanco"
android:textSize="@dimen/textSizeTvHistorial" />
</LinearLayout>
<LinearLayout
android:layout_width="@dimen/layoutWidthLayoutTuCuenta"
android:layout_height="match_parent"
android:layout_marginStart="@dimen/_35sdp"
android:orientation="vertical"
android:layout_marginTop="@dimen/marginTopLinearLayoutButton">
<ImageView
android:id="@+id/ivCuenta"
android:layout_width="match_parent"
android:layout_height="@dimen/layoutHeightIvTuCuenta"
android:layout_gravity="center"
app:srcCompat="@drawable/botoncuenta" />
<TextView
android:id="@+id/tvCuenta"
android:layout_width="wrap_content"
android:layout_height="@dimen/layoutHeightTvTuCuenta"
android:layout_gravity="center"
android:fontFamily="@font/opensans"
android:text="@string/cuenta"
android:textColor="@color/blanco"
android:textSize="@dimen/textSizeTvTuCuenta"
app:layout_constraintStart_toEndOf="@+id/tvHistorial"
app:layout_constraintTop_toBottomOf="@+id/ivCuenta" />
</LinearLayout>
</LinearLayout>
</androidx.constraintlayout.widget.ConstraintLayout>
</layout>
我添加了每个 LinearLayout:android:layout_marginStart="@dimen/_35sdp"
使用implementation 'com.intuit.sdp:sdp-android:1.0.6'
解决方案
您可以使用库来处理不同尺寸设备上的 UI。
尝试使用该SDP
库。有关更多信息和用法,您可以在此处查看
将此添加到您的 Gradle 以使用该SDP
库。
dependencies {
implementation 'com.intuit.sdp:sdp-android:1.0.6'
}
在您的布局中而不是dp
用作spd
代替
android:layout_width="35dp"
利用
android:layout_width="@dimen/_35sdp"
如果您有任何问题,请告诉我。