Как выровнять виды в линейной компоновке?

#android #android-studio #android-linearlayout

#Android #android-studio #android-linearlayout

Вопрос:

Я хочу выровнять по горизонтали в линейной компоновке. Поэтому я использую атрибут weight для выравнивания представлений. Но после установки значения некоторые значения не устанавливаются должным образом.

Ниже приведен макет:

 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_margin="5dp"
android:background="@color/white"
android:orientation="horizontal"
android:paddingStart="5dp"
android:paddingTop="10dp"
android:gravity="center_vertical"
android:paddingEnd="5dp"
android:paddingBottom="10dp">

<androidx.appcompat.widget.AppCompatTextView
    android:id="@ id/topHoldingStockName"
    android:layout_width="0dp"
    android:layout_height="wrap_content"
    android:layout_gravity="start|center_vertical"
    android:layout_weight="1"
    android:gravity="start|center_vertical"
    android:text="Bharati Airtel Ltd."
    android:textAppearance="@style/RegularGreyText"
    android:textSize="15sp" />

<androidx.appcompat.widget.AppCompatTextView
    android:id="@ id/topHoldingSectorName"
    android:layout_width="0dp"
    android:layout_height="wrap_content"
    android:layout_marginStart="5dp"
    android:layout_weight="1"
    android:gravity="start"
    android:text="Telecommunication - service provider"
    android:textAppearance="@style/RegularGreyText"
    android:textSize="15sp" />

<androidx.appcompat.widget.AppCompatTextView
    android:id="@ id/topHoldingSchemeWeight"
    android:layout_width="0dp"
    android:layout_height="wrap_content"
    android:layout_marginStart="5dp"
    android:layout_marginEnd="5dp"
    android:layout_weight="0.7"
    android:text="15.00"
    android:gravity="center"
    android:textAppearance="@style/RegularGreyText"
    android:textSize="15sp" />
 

Вывод выглядит такизображение для справки
Я хочу, чтобы они были правильно выровнены, как заголовки.

Комментарии:

1. Если вы хотите, чтобы все имели одинаковое пространство, просто используйте android: gravity =»center» для всех AppCompatTextView

2. можете ли вы показать, что вы сделали для макета заголовка

3. @Jeeva Я также использовал тот же макет для заголовков.

4. Используйте recycler, если у вас есть больше элементов для отображения

5. @shohruhMaxmudov использует представление Recycler для отображения данных под заголовками.

Ответ №1:

вы должны добавить "weightSum = 2.7" в свой linearLayout . чтобы все ваши представления в макете были сбалансированы.

     <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_margin="5dp"
android:weightSum="2.7"
android:background="@color/white"
android:orientation="horizontal"
android:paddingStart="5dp"
android:paddingTop="10dp"
android:gravity="center_vertical"
android:paddingEnd="5dp"
android:paddingBottom="10dp">

<androidx.appcompat.widget.AppCompatTextView
    android:id="@ id/topHoldingStockName"
    android:layout_width="0dp"
    android:layout_height="wrap_content"
    android:layout_gravity="start|center_vertical"
    android:layout_weight="1"
    android:gravity="start|center_vertical"
    android:text="Bharati Airtel Ltd."
    android:textAppearance="@style/RegularGreyText"
    android:textSize="15sp" />

<androidx.appcompat.widget.AppCompatTextView
    android:id="@ id/topHoldingSectorName"
    android:layout_width="0dp"
    android:layout_height="wrap_content"
    android:layout_marginStart="5dp"
    android:layout_weight="1"
    android:gravity="start"
    android:text="Telecommunication - service provider"
    android:textAppearance="@style/RegularGreyText"
    android:textSize="15sp" />

<androidx.appcompat.widget.AppCompatTextView
    android:id="@ id/topHoldingSchemeWeight"
    android:layout_width="0dp"
    android:layout_height="wrap_content"
    android:layout_marginStart="5dp"
    android:layout_marginEnd="5dp"
    android:layout_weight="0.7"
    android:text="15.00"
    android:gravity="center"
    android:textAppearance="@style/RegularGreyText"
    android:textSize="15sp" />
 

Комментарии:

1. Я уже пробовал это. Он по-прежнему не выравнивает представления должным образом.

2. @PallaviTapkir опубликуйте свой полный макет.

3. Опубликованный файл завершен, только недостающая строка <?xml version=»1.0″ encoding=»utf-8″?>

4. это ваш код для одной строки, я говорю о целом коде. Потому что очевидно, что вы создали отдельные макеты для всех трех строк, поэтому они не выравниваются и не будут выравниваться. Я говорю со ссылкой на опубликованное вами изображение.

5. Я решил эту проблему. Это не связано с макетом, при раздувании макета в классе адаптера я передаю корневое значение как null, передача ViewGroup решила проблему.

Ответ №2:

Вы можете использовать свойство weight для просмотра устройства.

 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:orientation="vertical"
    android:layout_weight="3">

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:layout_weight="3">

        <TextView
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:gravity="center"
            android:text="Stock Name"
            android:textColor="@android:color/black"
            android:textSize="20sp"
            android:textStyle="bold" />

        <TextView
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:gravity="center"
            android:text="Sector"
            android:textColor="@android:color/black"
            android:textSize="20sp"
            android:textStyle="bold" />

        <TextView
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:gravity="center"
            android:text="Weight"
            android:textColor="@android:color/black"
            android:textSize="20sp"
            android:textStyle="bold" />
    </LinearLayout>

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_marginTop="20dp"
        android:layout_height="wrap_content"
        android:layout_weight="3">

        <TextView
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:gravity="center"
            android:text="Tata Chemical"
            android:textColor="@android:color/black"
            android:textSize="20sp"/>

        <TextView
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:gravity="center"
            android:text="Chemical"
            android:textColor="@android:color/black"
            android:textSize="20sp" />

        <TextView
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:gravity="center"
            android:text="15%"
            android:textColor="@android:color/black"
            android:textSize="20sp"/>
    </LinearLayout>
</LinearLayout>
 

Вывод

Ответ №3:

Вы должны добавить android:weightSum="2.7" в свой родительский макет.

 <?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_margin="5dp"
    android:orientation="horizontal"
    android:paddingStart="5dp"
    android:paddingTop="10dp"
    android:weightSum="2.7"
    android:gravity="center_vertical"
    android:paddingEnd="5dp"
    android:paddingBottom="10dp">

    <androidx.appcompat.widget.AppCompatTextView
        android:id="@ id/topHoldingStockName"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_gravity="start|center_vertical"
        android:layout_weight="1"
        android:gravity="start|center_vertical"
        android:text="Bharati Airtel Ltd."
        android:textSize="15sp" />

    <androidx.appcompat.widget.AppCompatTextView
        android:id="@ id/topHoldingSectorName"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_marginStart="5dp"
        android:layout_weight="1"
        android:gravity="start"
        android:text="Telecommunication - service provider"
        android:textSize="15sp" />

    <androidx.appcompat.widget.AppCompatTextView
        android:id="@ id/topHoldingSchemeWeight"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_marginStart="5dp"
        android:layout_marginEnd="5dp"
        android:layout_weight="0.7"
        android:text="15.00"
        android:gravity="center"
        android:textSize="15sp" />

</LinearLayout>
 

Вывод

Ответ №4:

Замените свой код следующим XML-кодом..

 <?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_margin="5dp"
    android:background="@color/white"
    android:gravity="center_vertical"
    android:orientation="horizontal"
    android:paddingStart="5dp"
    android:paddingTop="10dp"
    android:paddingEnd="5dp"
    android:paddingBottom="10dp"
    android:weightSum="3">


    <androidx.appcompat.widget.AppCompatTextView
        android:id="@ id/topHoldingStockName"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_gravity="start|center_vertical"
        android:layout_marginEnd="2dp"
        android:layout_weight="1"
        android:gravity="center"
        android:text="Bharati Airtel Ltd."
        android:textAppearance="@style/RegularGreyText"
        android:textSize="15sp" />

    <androidx.appcompat.widget.AppCompatTextView
        android:id="@ id/topHoldingSectorName"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_marginStart="2dp"
        android:layout_marginEnd="2dp"
        android:layout_weight="1"
        android:gravity="center"
        android:text="Telecommunication - service provider"
        android:textAppearance="@style/RegularGreyText"
        android:textSize="15sp" />

    <androidx.appcompat.widget.AppCompatTextView
        android:id="@ id/topHoldingSchemeWeight"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_marginStart="2dp"
        android:layout_weight="1"
        android:gravity="center"
        android:text="15.00"
        android:textAppearance="@style/RegularGreyText"
        android:textSize="15sp" />
</LinearLayout> 

введите описание изображения здесь