Как можно использовать макет несколько раз, когда некоторые вложенные представления имеют разные значения высоты и ширины? - PullRequest
0 голосов
/ 01 мая 2019

Я работаю над чьим-то кодом, который использует Heterogenous RecyclerView, а ViewHolder использует либо маленькую, либо среднюю, либо большую компоновку.

Кажется, что все 3 компоновки имеют абсолютно одинаковый набор представленийОднако единственное, что меняется, - это конкретная высота и ширина, которые всякий раз, когда я пытался изменить их программно и надувать только одну разметку в ViewHolder, на некоторых устройствах изображения на некоторых устройствах выглядят и портятся.

Чтобы он выглядел так, как должен, я сохранил 3 макета xmls, где каждый макет содержит разные значения.

Мне сильно не нравится этот шаблон, и я стараюсь не дублировать этот код в 3 xmls,Есть ли эффективный способ уменьшить шаблон?Я думал о многих других решениях: либо объявить некоторые виды в качестве макетов, и использовать их с <include />, либо создать несколько составных видов (но мне придется снова программно изменять высоту и ширину, что не очень хорошо работает).

Макеты выглядят следующим образом (я удалил Views, ViewGroups и свойства, чтобы они могли выглядеть более связно, X и Y - это значения, которые меняются среди 3 xmls, и я заинтересован в них):

<?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:id="@+id/rv_layout"
    android:layout_width="X"
    android:layout_height="wrap_content"
    android:layout_marginStart="@dimen/def_dim"
    android:layout_marginEnd="@dimen/def_dim">

    <LinearLayout
        android:id="@+id/iv_home_featured"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:orientation="vertical"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent">

        <FrameLayout
            android:layout_width="match_parent"
            android:layout_height="Y">

            <android.support.v7.widget.CardView
                android:layout_width="match_parent"
                android:paddingBottom="@dimen/dp_8"
                android:layout_height="match_parent"
                android:background="@drawable/curved_corners_rect"
                app:cardCornerRadius="8dp"
                app:cardElevation="0dp">

                <ImageView
                    android:id="@+id/iv_home_featured_img"
                    android:layout_width="match_parent"
                    android:layout_height="match_parent"
                    android:background="@android:color/transparent"
                    android:scaleType="fitXY"
                    tools:src="@drawable/community" />

                <FrameLayout
                    android:id="@+id/fav_wrapper_fl"
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:layout_gravity="top|end"
                    android:padding="7dp"
                    android:clickable="true"
                    android:focusable="true"
                    >

                    <ImageView
                        android:id="@+id/iv_fav"
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        …/>

                </FrameLayout>


            </android.support.v7.widget.CardView>

        </FrameLayout>

    </LinearLayout>

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_marginTop="8dp"
        android:orientation="vertical"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@id/iv_home_featured">

        <TextView
            android:id="@+id/tv_featured_text"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            …/>

        <TextView
            android:id="@+id/sub_category"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            …/>

    </LinearLayout>

</android.support.constraint.ConstraintLayout>

Я также рассмотрел создание составных представлений, но снова мне придется программно передавать значения и изменять размер CardView / ImageView, но это вызовет те же проблемы, которые были у меня на некоторых устройствах со сжатыми изображениями.

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