简体   繁体   English

如何在线性布局中对齐视图?

[英]How to align views in linear layout?

I want align Horizontally in linear layout.我想在线性布局中水平对齐。 So I use weight attribute for align views.所以我使用 weight 属性来对齐视图。 But after setting value some values are not getting set properly.但是在设置值之后,一些值没有被正确设置。

Below is layout:下面是布局:

<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" />

Output looks like Output 看起来像图片供参考 I want them align properly like headings.我希望它们像标题一样正确对齐。

you should add "weightSum = 2.7" in your linearLayout .您应该在您的linearLayout中添加"weightSum = 2.7" so that all of your views in a layout are balanced.这样布局中的所有视图都是平衡的。

    <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" />

Replace your code with following xml code..用以下 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>
在此处输入图像描述

You can use weight property to device view.您可以使用权重属性来查看设备。

<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>

输出

You have to add android:weightSum="2.7" to your parent layout.您必须将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>

输出

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM