Работа с Imageview и руководящими принципами - PullRequest
1 голос
/ 29 января 2020

Я создаю игру-викторину и пытаюсь ограничить изображение моего Imageview в соответствии с указанными мною рекомендациями.

В Android Предварительный просмотр в студии все выглядит нормально и, как и ожидалось. Ниже приведен экран этого ожидаемого результата:

Expectation

Но когда я запускаю приложение в эмуляторе (Pixel 3 XL API 29 в AVD Manager), Я получаю результат ниже:

result

Изображение не ограничено вертикальными направляющими или каким-либо образом вертикальные направляющие никогда не применяются, в то время как предварительный просмотр показывает иначе. Я пытался запустить его на разных устройствах, и результат всегда один и тот же.

Вот мой 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>

Я не могу понять asp, что здесь происходит, хотя я прочитал документацию. В крайнем случае я попытался поиграть с комбинациями следующих параметров:

  • layout_constraintDimensionRatio
  • scaleType
  • AdjustViewBounds
  • layout_width
  • layout_height

Без удачи.

Любая помощь будет принята с благодарностью!

Спасибо!

1 Ответ

0 голосов
/ 30 января 2020

Вы выполнили большую часть работы, но вот что не так с вашим макетом:

  • вы использовали фиксированные размеры для ваших представлений (android:layout_width="342dp"), и потому что разные телефоны получили другие размеры, которые могут хорошо смотреться на вашем предварительном просмотре, не будут выглядеть одинаково на другом устройстве.

  • у вас никогда не будет просмотра с идентификатором 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" />

Будет выглядеть так

enter image description here

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...