1

我正在创建一个问答游戏,并努力在我声明的准则中限制我的 Imageview 的图像。

在 Android Studio 预览中,一切似乎都正常且符合预期。下面是这个预期结果的打印屏幕:

期待

但是当我在模拟器中运行应用程序时(AVD Manager 上的 Pixel 3 XL API 29),我得到以下结果:

结果

图像不受垂直准线的约束,或者以某种方式从不应用垂直准线,而预览显示为其他方式。我尝试在不同的设备上运行它,结果总是一样的。

这是我的 XML 代码:

<?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:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="#427e83"
    tools:context=".level1">

    <androidx.appcompat.widget.AppCompatTextView
        android:id="@+id/level1completion"
        android:layout_width="342dp"
        android:layout_height="32dp"
        android:layout_marginTop="32dp"
        android:autofillHints=""
        android:fontFamily="@font/sunrise_international"
        android:textAlignment="center"
        android:textSize="36sp"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/level1answer" />

    <EditText
        android:id="@+id/level1tail1answer"
        android:layout_width="0dp"
        android:layout_height="0dp"
        android:layout_marginTop="32dp"
        android:background="@drawable/rounded_corners_edittext"
        android:ems="10"
        android:fontFamily="@font/sunrise_international"
        android:hint="@string/type_your_answer"
        android:inputType="textPersonName"
        android:textColor="@android:color/darker_gray"
        android:textColorHint="#45484b"
        app:layout_constraintEnd_toStartOf="@+id/guideline2"
        app:layout_constraintStart_toStartOf="@+id/guideline"
        app:layout_constraintTop_toBottomOf="@+id/level1imagetoguess" />

    <ImageView
        android:id="@+id/level1tail1imagetoguess"
        android:contentDescription="@string/correct_answer"
        android:src="@drawable/my_picture"
        android:scaleType="fitStart"
        android:adjustViewBounds="true"
        app:layout_constraintDimensionRatio="1:1"
        app:layout_constraintEnd_toStartOf="@+id/guideline2"
        app:layout_constraintStart_toStartOf="@+id/guideline"
        app:layout_constraintTop_toTopOf="@+id/guideline3" />

    <androidx.constraintlayout.widget.Guideline
        android:id="@+id/guideline"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:orientation="vertical"
        app:layout_constraintGuide_percent="0.18" />

    <androidx.constraintlayout.widget.Guideline
        android:id="@+id/guideline2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:orientation="vertical"
        app:layout_constraintGuide_percent="0.9155" />

    <androidx.constraintlayout.widget.Guideline
        android:id="@+id/guideline3"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:orientation="horizontal"
        app:layout_constraintGuide_percent="0.055" />

</androidx.constraintlayout.widget.ConstraintLayout>

即使我已经阅读了文档,我也无法掌握这里出了什么问题。作为最后的手段,我尝试使用以下参数的组合:

  • layout_constraintDimensionRatio
  • 比例尺类型
  • 调整视图边界
  • 布局宽度
  • 布局高度

没有运气。

任何帮助将不胜感激!

谢谢!

4

1 回答 1

0

您完成了大部分工作,但这是您的布局出了什么问题:

  • 您在视图上使用了固定尺寸android:layout_width="342dp"

  • 您永远不会拥有 id 的视图level1answer,因此您的其他视图不能被限制为不存在的视图

固定布局:

<EditText
    android:id="@+id/level1tail1answer"
    android:layout_width="0dp"
    android:layout_height="0dp"
    app:layout_constraintHeight_percent="0.1"
    android:ems="10"
    android:hint="type_your_answer"
    android:inputType="textPersonName"
    android:textColor="@android:color/darker_gray"
    android:textColorHint="#45484b"
    app:layout_constraintEnd_toStartOf="@+id/guideline2"
    app:layout_constraintStart_toStartOf="@+id/guideline"
    app:layout_constraintTop_toTopOf="@+id/guideline4" />

<ImageView
    android:id="@+id/level1tail1imagetoguess"
    android:adjustViewBounds="true"
    android:layout_width="0dp"
    android:layout_height="0dp"
    android:contentDescription="correct_answer"
    android:scaleType="fitStart"
    app:layout_constraintBottom_toTopOf="@+id/guideline4"
    app:layout_constraintDimensionRatio="1:1"
    app:layout_constraintEnd_toStartOf="@+id/guideline2"
    app:layout_constraintStart_toStartOf="@+id/guideline"
    app:layout_constraintTop_toTopOf="@+id/guideline3" />

<androidx.constraintlayout.widget.Guideline
    android:id="@+id/guideline"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:orientation="vertical"
    app:layout_constraintGuide_percent="0.18" />

<androidx.constraintlayout.widget.Guideline
    android:id="@+id/guideline2"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:orientation="vertical"
    app:layout_constraintGuide_percent="0.9155" />

<androidx.constraintlayout.widget.Guideline
    android:id="@+id/guideline3"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:orientation="horizontal"
    app:layout_constraintGuide_percent="0.055" />

<androidx.constraintlayout.widget.Guideline
    android:id="@+id/guideline4"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:orientation="horizontal"
    app:layout_constraintGuide_percent="0.6" />

<TextView
    android:id="@+id/textView2"
    android:layout_width="0dp"
    android:layout_height="0dp"
    app:layout_constraintHeight_percent="0.1"
    android:text="some text"
    app:layout_constraintBottom_toBottomOf="parent"
    app:layout_constraintEnd_toStartOf="@+id/guideline2"
    app:layout_constraintStart_toStartOf="@+id/guideline"
    app:layout_constraintTop_toBottomOf="@+id/level1tail1answer" />

看起来像这样

在此处输入图像描述

于 2020-01-30T08:23:53.923 回答