无法将项目设置为LinearLayout并排显示

3

我在布局中遇到了一个奇怪的问题,想要在同一行(并排)设置一个TextView和Spinner,但是遇到了困难。

我已经尝试过在论坛上找到的所有解决方案,但没有一个似乎有效。

我尝试了这个:如何在LinearLayout上并排布置元素并应用适当的间距和对齐

还有这个:将TextView和Spinner对齐在同一行上

还有这个:如何将Spinners从右侧对齐到左侧?

以及这个:如何将Spinner在LinearLayout中向右移动?

主要问题是,如果我设置 android:orientation="horizontal" ,我的整个布局会变得扭曲和错误。

当然,在我想对齐的两个项目上设置 android:weightSum="1" 是无效的...

以下是我的activity_main.xml布局代码:

<RelativeLayout 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"
xmlns:ads="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
android:background="#191414"
tools:context=".MainActivity">

<LinearLayout
    android:id="@+id/aboutLinearLayout"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:orientation="vertical"
    android:layout_gravity="center_horizontal">


    <ImageView
        android:id="@+id/imageView1"
        android:layout_width="match_parent"
        android:layout_height="200dp"
        android:scaleType="fitXY"
        android:layout_gravity="center_horizontal"
        android:contentDescription="Header picture"
        android:importantForAccessibility="no"
        android:src="@drawable/spoty"
        android:layout_marginBottom="15dp"/>

    <Switch
        android:id="@+id/Switchs"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:textStyle="bold"
        android:text="Smart" />
    <TextView
        android:id="@+id/switch_text"
        android:text="@string/delete_cache"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="start"
        android:gravity="start"
        android:textStyle="bold"
        android:layout_marginEnd="45dp"
        android:layout_marginBottom="10dp"/>

    <TextView
        android:id="@+id/main_text"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="start"
        android:gravity="start"
        android:textStyle="bold"
        android:layout_marginBottom="10dp"/>

    <TextView
        android:id="@+id/days_text"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="@string/soemstring"
        android:layout_weight="1"
        android:textStyle="bold" />

    <Spinner
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_weight="1"
        android:id="@+id/spinner1"
        android:entries="@array/days">
    </Spinner>

    <TextView
        android:id="@+id/size_text"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="start"
        android:text="@string/someotherstring"
        android:gravity="start"
        android:textStyle="bold"
        android:layout_marginBottom="5dp"/>
    <Spinner
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:id="@+id/spinner2"
        android:gravity="start"
        android:entries="@array/sizes"
        android:layout_marginBottom="5dp">
    </Spinner>

    <TextView
        android:id="@+id/notes"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="start"
        android:text="@string/notes"
        android:gravity="start"
        android:textStyle="bold"
        android:layout_marginEnd="15dp"
        android:layout_marginBottom="25dp"/>

    <Button
        android:layout_width="200dp"
        android:layout_height="wrap_content"
        android:text="@string/sometext"
        android:id="@+id/button1"
        android:textStyle="bold"
        android:layout_gravity="center"
        android:background="@drawable/btn_round"
        android:layout_marginBottom="5dp"/>
    </LinearLayout>
</RelativeLayout>

有什么可以解决这个问题的方法吗?非常感谢您提出任何建议!

2
你能添加一个所需输出的图片吗? - sanoJ
现在尝试使用ConstraintLayout - Richard Le Mesurier
3个回答

2
如果我理解您的示例背后的想法,您最终会使用嵌套的LinearLayout - 上面一个具有垂直方向,嵌套的一个具有水平实现 - 这是错误的,因为您应该使用ConstraintLayout。无论如何,在您的情况下,我认为它会像这样进行:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingBottom="@dimen/activity_vertical_margin"
    tools:context=".MainActivity">

    <LinearLayout
        android:id="@+id/aboutLinearLayout"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:gravity="center_horizontal"
        android:orientation="vertical">

        <LinearLayout
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:gravity="center_vertical"
            android:orientation="horizontal">

            <TextView
                android:id="@+id/days_text"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:text="something"
                android:textStyle="bold" />

            <Spinner
                android:id="@+id/spinner1"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:entries="@array/days" />
        </LinearLayout>
    </LinearLayout>
</RelativeLayout>

如果你使用水平方向,并且你的项目布局宽度为wrap_content,它们将会一个接一个地排列。如果你给它们设置权重,请不要忘记将它们的layout_width设置为0dp,但我猜你只需要前者,因为顶级LinearLayout会将你的一对视图放在屏幕中央,就像这样:

enter image description here


谢谢!我只是想知道新的LinearLayout是否应该包含所有布局内容,还是只包括Spinner和TextViews,我想要对齐? - androidexpert35
假设 TextView 和 Spinner 应该在屏幕水平居中并排放置,它们的父 LinearLayout 应该将它们包裹起来。基本上,这个新的水平 LinearLayout 就像表示您更大布局中的一行。 - ror
谢谢,伙计!它修复了所有问题! - androidexpert35

0

首先将您的LinearLayout方向更改为android:orientation="horizontal"

然后在其中的项目中添加android:layout_weight="1",并将项目的android:layout_width="wrap_content"更改为android:layout_width="0dp"

您可以在LinearLayout的子项中每次使用它。如果您希望它们共享相同的宽度,则不需要android:weightSum

注意:android:weightSum仅适用于LinearLayout,它表示所有子项权重的总和。


0
在嵌套的LinearLayout中添加一个LinearLayout,将其设置为水平方向,将您想要并排对齐的视图放入其中,为每个视图设置相应的布局参数。
android:layout_weight ="1"
android :layout_width ="0"

试试这个。

<RelativeLayout> // parent layout.
<LinearLayout >
..................... // top children in nested LinearLayout
<LinearLayout
android:orientation = "horizontal "
........... // set remaining attributes >
<Textview
.............. // set other attributes 
android: layout_width="0"
android:layout_weight="1"/>
<Spinner
......... // set remaining attributes 
android:layout_width="0"
android :layout_weight="1"/>
</LinearLayout> // end of nested layout 
</LinearLayout > // end of top nested layout
</RelativeLayout> // end of parent layout 

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接