如何在相同的空间中对齐标题,描述和URL

时间:2016-03-15 05:05:29

标签: java android

以下是我目前在屏幕上显示的布局屏幕截图:

enter image description here

以下是布局的xml代码段:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <ImageView
        android:id="@+id/icon"
        android:layout_width="110dp"
        android:layout_height="110dp"
        android:layout_alignParentRight="true"
        android:layout_marginRight="-10dp" />

    <TextView
        android:id="@+id/title"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:height="20dp"
        android:fontFamily="Cabin-Regular"
        android:paddingLeft="10dp"
        android:textColor="#E35B5B"
        android:textSize="14dp" />

    <TextView
        android:id="@+id/desc"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_below="@+id/title"
        android:height="44dp"
        android:fontFamily="Cabin-Regular"
        android:paddingLeft="10dp"
        android:paddingRight="100dp"
        android:textColor="#2D2D2D"
        android:textSize="16dp" />

    <TextView
        android:id="@+id/url_view"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_below="@+id/title"
        android:layout_marginTop="50dp"
        android:height="15dp"
        android:paddingLeft="10dp"
        android:paddingRight="80dp"
        android:textColor="#BDBDBD"
        android:textSize="10dp" />

</RelativeLayout>

只是希望三个文本视图正确对齐并且彼此之间具有相等的空间。

8 个答案:

答案 0 :(得分:1)

这是你的布局,

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent">


    <ImageView
        android:id="@+id/icon"
        android:layout_width="110dp"
        android:layout_height="110dp"
        android:layout_alignParentRight="true"
        android:layout_marginRight="-10dp" />

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="110dp"
        android:layout_toLeftOf="@+id/icon"
        android:orientation="vertical"
        android:weightSum="3">

        <TextView
            android:id="@+id/title"
            android:layout_width="match_parent"
            android:layout_height="0dp"
            android:layout_weight="1"
            android:fontFamily="Cabin-Regular"
            android:gravity="center_vertical"
            android:paddingLeft="10dp"
            android:text="Title"
            android:textColor="#E35B5B"
            android:textSize="14dp" />

        <TextView
            android:id="@+id/desc"
            android:layout_width="match_parent"
            android:layout_height="0dp"
            android:layout_below="@+id/title"
            android:layout_weight="1"
            android:fontFamily="Cabin-Regular"
            android:gravity="center_vertical"
            android:paddingLeft="10dp"
            android:text="Description"
            android:textColor="#2D2D2D"
            android:textSize="16dp" />

        <TextView
            android:id="@+id/url_view"
            android:layout_width="match_parent"
            android:layout_height="0dp"
            android:layout_below="@+id/title"
            android:layout_weight="1"
            android:gravity="center_vertical"
            android:paddingLeft="10dp"
            android:text="URL"
            android:textColor="#BDBDBD"
            android:textSize="10dp" />
    </LinearLayout>

</RelativeLayout>

答案 1 :(得分:1)

Pawan Thakur对所有测试和layoutBelow使用相同的paddingLeft,如下所示

<TextView
    android:id="@+id/url_view"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_below="@+id/desc"
    android:height="15dp"
    android:paddingRight="80dp"
    android:paddingLeft="10dp"
    android:text="url"
    android:textColor="#BDBDBD"
    android:textSize="10dp" />

答案 2 :(得分:1)

这是代码。尽量使用LinearLayout而不是Relative。在2个或更多个元素必须彼此重叠的情况下使用相对布局。不要在一个布局中包含每个元素。将您的设计划分为不同的部分,并为每个部分使用LinearLayout,并在每个部分中包含属于该部分的元素。

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
    android:layout_height="wrap_content"
    android:layout_width="match_parent"
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="horizontal"
    >
    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:layout_weight=".25"
        android:orientation="vertical"
        >
        <TextView
            android:id="@+id/title"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:textColor="#E35B5B"
            android:fontFamily="Cabin-Regular"
            android:textSize="14dp"
            android:layout_weight="0.33"
            android:singleLine="true"
            android:ellipsize="end"
            android:gravity="center|left"
            android:paddingLeft="10dp"
            android:text="Google"
            />

        <TextView
            android:id="@+id/desc"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:textColor="#2D2D2D"
            android:fontFamily="Cabin-Regular"
            android:textSize="16dp"
            android:layout_weight="0.33"
            android:singleLine="true"
            android:ellipsize="end"
            android:gravity="center|left"
            android:paddingLeft="10dp"
            android:text="Google is a Search engine"
            />
        <TextView
            android:id="@+id/url_view"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:layout_below="@+id/title"
            android:textColor="#BDBDBD"
            android:textSize="10dp"
            android:layout_weight="0.33"
            android:singleLine="true"
            android:ellipsize="end"
            android:gravity="center|left"
            android:paddingLeft="10dp"
            android:text="http://www.google.com"
            />
    </LinearLayout>
    <LinearLayout
        android:layout_width="110dp"
        android:layout_height="110dp"

        >
        <ImageView
            android:id="@+id/icon"
            android:layout_width="match_parent"
            android:layout_height="match_parent"

            />
    </LinearLayout>

</LinearLayout>

答案 3 :(得分:0)

你可以对相对布局的孩子使用android:weight =“”

答案 4 :(得分:0)

为布局中的垂直方向和weightsum = 3的标题,描述和网址创建LinearLayout,并且每个都使用width = wrap_content,height = 0dp,weight = 1。

答案 5 :(得分:0)

Okey ..首先从每个android:height中删除TextView,然后在最后TextView中设置android:layout_marginTop="50将其删除。

提示:如果您想要垂直或水平显示所有视图,请使用LinearLayout。如果您想使用RelativeLayout,请确保正确提供边距和填充,以使它们看起来很好。

答案 6 :(得分:0)

使用线性布局作为父级和权重,并在子布局之间平均分配权重。例如:如果父级为android:weightsum =“3”,那么每个子布局的android:layout_weight =“1”(如果你想为3个孩子中的每一个提供相等的空间)。

ps:别忘了提及Linearlayout的方向。

答案 7 :(得分:0)

请检查一下,

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="horizontal">

    <LinearLayout
        android:layout_width="0dp"
        android:layout_height="match_parent"
        android:layout_weight="1
        android:padding="10dp"
        android:orientation="vertical">

        <TextView
            android:id="@+id/title"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:textColor="#E35B5B"
            android:fontFamily="Cabin-Regular"
            android:textSize="14dp"
            android:text="Google"/>


        <TextView
            android:id="@+id/desc"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:textColor="#2D2D2D"
            android:fontFamily="Cabin-Regular"
            android:textSize="16dp"
            android:margin_top="5dp"
            android:text="Google is a Search engine"/>

        <TextView
            android:id="@+id/url_view"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:textColor="#BDBDBD"
            android:textSize="10dp"
            android:margin_top="5dp"
            android:text="http://www.google.com"/>

    </LinearLayout>
    <LinearLayout
        android:layout_width="wrap_content"
        android:layout_height="wrap_content">
        <ImageView
            android:id="@+id/icon"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:padding="10dp"/>

    </LinearLayout>

</LinearLayout>