【问题标题】:Android: center and right alignment inside LinearLayoutAndroid:LinearLayout 内居中和右对齐
【发布时间】:2017-02-25 03:13:04
【问题描述】:

我有两个线性布局,一个在另一个里面。在第二个中,我有一个Switch 按钮、一个TextView 和一个FloatingActionButton。我想把这 3 个放在同一行,我想集中 Switch 和 TextView,我想在屏幕右侧对齐 FloatingActionButton。我尝试使用marginLeft 强迫他们去我想要的位置,但我认为这不是正确的方法。

这是我的代码(现在 3 个组件已经在同一行):

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

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="fill_parent"
        android:layout_height="80dp"
        android:orientation="horizontal"
        android:weightSum="1" >

    <Switch
        android:id="@+id/mySwitch"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentTop="true"
        android:layout_marginLeft="140dp"
        android:layout_marginTop="20dp"
        android:theme="@style/SCBSwitch"
        />

        <TextView
            android:id="@+id/OpenClose"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_marginTop="20dp"
            android:layout_marginLeft="10dp"
            android:text="Open"
            android:textSize="20dp"/>

    <android.support.design.widget.FloatingActionButton
        android:id="@+id/action_find_location"
        android:layout_width="277dp"
        android:layout_height="40dp"
        android:layout_marginTop="10dp"
        android:layout_marginLeft="75dp"
        android:layout_marginRight="10dp"
        android:src="@drawable/calendar_today"
        fab:backgroundTint="@color/theme_color"
        fab:borderWidth="0dp"
        fab:elevation="9dp"
        fab:rippleColor="@color/toolbar_title_color"
        fab:fabSize="mini"/>

    </LinearLayout>
    </LinearLayout>

【问题讨论】:

  • 你试过 android:layout_gravity = "left" ; android:layout_gravity = "中心" ; android:layout_gravity = "right" 分别为每个控件
  • 感谢您的回复!是的,我试过了,但没有用。我不知道它是否因为其他属性之一而不起作用。

标签: android android-layout right-align center-align


【解决方案1】:

LinearLayout 中删除android:weightSum="1" 并执行类似操作:

<FrameLayout
    android:layout_width="0dp"
    android:layout_height="match_parent"
    android:layout_weight="1"
    android:orientation="horizontal">

    <Switch
        android:id="@+id/mySwitch"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="center" />
</FrameLayout>

TextView 相同,并使用 FAB 删除:

    android:layout_gravity="end"
    android:gravity="center"
    android:layout_weight="1"

【讨论】:

    【解决方案2】:

    刚刚获取了您的代码并进行了一些更改。请检查它是否工作正常

    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:fab="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical">
    
    <LinearLayout
        android:layout_width="fill_parent"
        android:layout_height="80dp"
        android:orientation="horizontal"
        android:weightSum="3">
    
        <Switch
            android:id="@+id/mySwitch"
            android:layout_width="50dp"
            android:layout_height="50dp"
            android:theme="@style/SCBSwitch"
            android:layout_gravity="start"
            android:gravity="center"
            android:layout_weight="1"/>
    
        <TextView
            android:id="@+id/OpenClose"
            android:layout_width="50dp"
            android:layout_height="50dp"
            android:text="Open"
            android:textSize="20dp"
            android:layout_gravity="center_horizontal"
            android:gravity="center"
            android:layout_weight="1"/>
    
        <android.support.design.widget.FloatingActionButton
            android:id="@+id/action_find_location"
            android:layout_width="50dp"
            android:layout_height="50dp"
            android:src="@drawable/calendar_today"
            fab:backgroundTint="@color/theme_color"
            fab:borderWidth="0dp"
            fab:elevation="9dp"
            fab:rippleColor="@color/toolbar_title_color"
            fab:fabSize="mini"
            android:layout_gravity="end"
            android:gravity="center"
            android:layout_weight="1"/>
    
    </LinearLayout>
    </LinearLayout>
    

    【讨论】:

      猜你喜欢
      • 2023-03-16
      • 1970-01-01
      • 2023-03-10
      • 1970-01-01
      • 1970-01-01
      • 2015-06-26
      • 2013-09-11
      • 1970-01-01
      • 2012-03-19
      相关资源
      最近更新 更多