Xamarin Native Android LinearLayout вес применяется к странной проблеме детей - PullRequest
1 голос
/ 10 марта 2020

Я хотел бы получить следующий вывод. Я даю свой код и изображение, которое показывает, как это выглядит в настоящее время. Я использую MVVMCross с пользовательским интерфейсом Xamarin Nativ для Android.

Требуемый вывод Вид сверху должен занимать 70% пространства, а нижний должен занимать 30% доступного пространства.

Текущий макет используется во фрагменте. Таким образом, этот макет добавляется как дочерний элемент к структуре кадра в упражнении, где размещается этот фрагмент.

<LinearLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:local="http://schemas.android.com/apk/res-auto"
    android:orientation="vertical"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:weightSum="1">

    <LinearLayout
        android:orientation="vertical"
        android:layout_width="match_parent"
        android:layout_height="0dp"
        android:gravity="center|bottom"
        android:layout_weight=".7">
        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_margin="20dp"
            android:text="Some Text"
            android:gravity="top"            />

        <Button
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_margin="10dp"
            android:text="Add Entry"
            local:MvxBind="Click AddCommand"            />
    </LinearLayout>


    <FrameLayout
        android:layout_width="match_parent"
        android:layout_height="0dp"
        android:layout_weight=".3">
        <ImageView
            android:src="@drawable/waves"
            android:adjustViewBounds="true"            
            android:layout_width="match_parent"
            android:layout_height="wrap_content"            />

        <LinearLayout
            android:orientation="vertical"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:id="@+id/MilliliterViewContainer"/> <!-- The ml is a custom view which is being inflated and added in this layout from the code behind -->

    </FrameLayout>

</LinearLayout>

Вот текущий вывод, он каким-то образом применил вес к дочернему элементу, то есть к изображению.

Токовый выход Я не понимаю, почему изображение не отображается во всю ширину? почему вес применяется к ширине изображения? Волны - это векторное изображение.

1 Ответ

1 голос
/ 11 марта 2020

Тип масштаба по умолчанию для ImageView в Android равен fitCenter, что, по-видимому, говорит о том, что Vector Drawable просто соответствует высоте в центре.

Если вы переключитесь на fitXY будет заполнять ширину.

Я также предлагаю вам переработать макет, чтобы использовать ConstraintLayout вместо того, чтобы избегать использования дорогих весов на LinearLayout. Это может выглядеть примерно так:

<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.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"
    tools:showIn="@layout/activity_main">

    <android.support.constraint.Guideline
        android:id="@+id/guideline"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:orientation="horizontal"
        app:layout_constraintGuide_percent="0.7" />

    <ImageView
        android:id="@+id/waves_image"
        android:layout_width="0dp"
        android:layout_height="0dp"
        android:src="@drawable/waves"
        android:scaleType="fitXY"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/guideline" />

    <Button
        android:id="@+id/add"
        android:text="Add Entry"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        app:layout_constraintHorizontal_bias="0.5"
        app:layout_constraintWidth_percent="0.6"
        app:layout_constraintBottom_toTopOf="@+id/guideline"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintEnd_toEndOf="parent" />

    <TextView
        android:id="@+id/overview"
        android:text="Overview Text"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:gravity="center"
        app:layout_constraintHorizontal_bias="0.5"
        app:layout_constraintWidth_percent="0.6"
        app:layout_constraintBottom_toTopOf="@+id/add"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintEnd_toEndOf="parent"/>

</android.support.constraint.ConstraintLayout>

Это значительно сглаживает макет, что означает меньшее перерасход и меньше вычислений, выполненных для расчета макета.

...