我目前面临着尺寸变化的麻烦。
我已经使用 dp 对 xml 文件进行了编码,但是当我更改设备屏幕尺寸时,布局会发生变化。
例如,当我进入“设置”-“显示”-“屏幕缩放和字体”并将屏幕缩放从中到大时,布局中的某些元素(例如图像视图或按钮)会增大并超出屏幕。
由于我使用的是包含 LinearLayouts 和 FrameLayouts 的复杂布局,因此我不清楚如何使该布局在任何其他设备或屏幕尺寸中看起来都不错。似乎当我更改屏幕缩放设置时,dp 的值会发生变化。
有没有办法避免这个问题,或者可以以编程方式将屏幕缩放设置设置为中等?
这是我的代码:
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical"
android:gravity="center"
android:layout_gravity="center"
android:layout_marginTop="65dp">
<android.support.constraint.ConstraintLayout
android:id="@+id/frameLayout"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginBottom="95dp"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintVertical_bias="0.3">
<ImageView
android:id="@+id/imageView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/home_map" />
<Button
android:id="@+id/pick1"
android:layout_width="34dp"
android:layout_height="56dp"
android:background="@drawable/top_deselected"
app:layout_constraintBottom_toBottomOf="@+id/imageView"
app:layout_constraintEnd_toEndOf="@+id/imageView"
app:layout_constraintHorizontal_bias="0.17"
app:layout_constraintStart_toStartOf="@+id/imageView"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintVertical_bias="0.18" />
<Button
android:id="@+id/pick2"
android:layout_width="34dp"
android:layout_height="56dp"
android:background="@drawable/jungle_deselected"
app:layout_constraintBottom_toBottomOf="@+id/imageView"
app:layout_constraintEnd_toEndOf="@+id/imageView"
app:layout_constraintHorizontal_bias="0.28"
app:layout_constraintStart_toStartOf="@+id/imageView"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintVertical_bias="0.367" />
<Button
android:id="@+id/pick3"
android:layout_width="34dp"
android:layout_height="56dp"
android:background="@drawable/mid_deselected"
app:layout_constraintBottom_toBottomOf="@+id/imageView"
app:layout_constraintEnd_toEndOf="@+id/imageView"
app:layout_constraintHorizontal_bias="0.424"
app:layout_constraintStart_toStartOf="@+id/imageView"
app:layout_constraintTop_toTopOf="@+id/imageView"
app:layout_constraintVertical_bias="0.43" />
<Button
android:id="@+id/pick4"
android:layout_width="34dp"
android:layout_height="56dp"
android:background="@drawable/support_deselected"
app:layout_constraintBottom_toBottomOf="@+id/imageView"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHorizontal_bias="0.615"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="@+id/imageView"
app:layout_constraintVertical_bias="0.71" />
<Button
android:id="@+id/pick5"
android:layout_width="34dp"
android:layout_height="56dp"
android:background="@drawable/adc_deselected"
app:layout_constraintBottom_toBottomOf="@+id/imageView"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHorizontal_bias="0.733"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="@+id/imageView"
app:layout_constraintVertical_bias="0.71" />
</android.support.constraint.ConstraintLayout>
<Button
android:layout_width="335dp"
android:layout_height="42.5dp"
android:layout_marginBottom="5.5dp"
android:background="@drawable/home_mode"
android:id="@+id/home_mode"/>
<Button
android:layout_width="335dp"
android:layout_height="42.5dp"
android:background="@drawable/home_match"
android:id="@+id/home_match"/>
</LinearLayout>
约束布局曾经是框架布局,但我现在刚刚尝试约束布局。
您还可以使用这个库,它适用于所有设备,无需制作任何 dimen 文件等。但仅将其用于小部件的大小,对于文本大小仅使用“sp”。
https://github.com/intuit/sdp
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)