固定宽度TextView旁边的可变宽度TextView

问题描述 投票:2回答:4

我正在尝试创建一个两个TextViews彼此相邻的布局。第一个TextView长度可变,单线。第二个TextView包含固定标签,不应进行椭圆化处理。第二个标签必须紧挨着第一个标签。以下是我要完成的两个例子:

enter image description here enter image description here

这是我到目前为止所取得的成就:

enter image description here

使用此布局文件:

<?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="wrap_content"
            android:layout_height="match_parent"
            android:background="@drawable/my_bg"
            android:padding="16dp"
tools:layout_height="60dp">

<TextView
    android:layout_centerVertical="true"
    android:id="@+id/tv_street"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_toLeftOf="@+id/tv_updated"
    android:textSize="17sp"
    android:singleLine="true"
    android:ellipsize="end"
    android:layout_marginLeft="16dp"
    tools:text="This label is short"/>

<TextView
    android:id="@id/tv_updated"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_alignParentRight="true"
    android:layout_centerVertical="true"
    android:layout_marginLeft="10dp"
    android:text="@string/updated"
    android:textAllCaps="true"
    android:textColor="@color/red"
    android:textStyle="bold"/>
</RelativeLayout>

剩下的问题是容器的宽度与其父级匹配,而它应该是wrap_content

还有其他方法可以解决这个问题吗?

android android-layout textview android-relativelayout
4个回答
0
投票

你最好使用linearlayout

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
              xmlns:tools="http://schemas.android.com/tools"
              android:layout_width="wrap_content"
              android:layout_height="match_parent"
              android:padding="16dp"
              android:orientation="horizontal"
              android:gravity="center_vertical"
              tools:layout_height="60dp">
    <TextView
        android:id="@+id/tv_street"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:textSize="17sp"
        android:layout_weight="1"
        android:singleLine="true"
        android:ellipsize="end"
        android:layout_marginLeft="16dp"
        tools:text="This label is short"/>

    <TextView
        android:id="@id/tv_updated"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginLeft="10dp"
        android:text="UPDATED"
        android:textAllCaps="true"
        android:textColor="@color/red"
        android:textStyle="bold"/>
</LinearLayout>

编辑:这里证明

tested


0
投票

我希望这有帮助。可能需要一些调整,但几个隐藏的视图可能会实现您正在寻找的东西。

<?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="wrap_content"
    android:layout_height="match_parent"
    android:padding="16dp"
    tools:layout_height="60dp">

    <TextView
        android:layout_centerVertical="true"
        android:id="@+id/tv_street"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentLeft="true"
        android:textSize="17sp"
        android:singleLine="true"
        android:ellipsize="end"
        android:layout_marginLeft="16dp"
        tools:text="This label is short" />

    <TextView
        android:layout_centerVertical="true"
        android:id="@+id/hidden_street"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_toLeftOf="@+id/hidden_updated"
        android:layout_alignParentLeft="true"
        android:textSize="17sp"
        android:singleLine="true"
        android:ellipsize="end"
        android:layout_marginLeft="16dp"
        tools:text="This label is short"
        android:visibility="invisible"/>

    <TextView
        android:id="@+id/tv_updated"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_centerVertical="true"
        android:layout_marginLeft="10dp"
        android:layout_toRightOf="@+id/tv_street"
        android:text="updated"
        android:textAllCaps="true"
        android:textStyle="bold"/>

    <TextView
        android:id="@+id/hidden_updated"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentRight="true"
        android:layout_centerVertical="true"
        android:layout_marginLeft="10dp"
        android:text="updated"
        android:textAllCaps="true"
        android:textStyle="bold"
        android:visibility="invisible"/>
</RelativeLayout>

0
投票

检查下面的代码它会对你有所帮助

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


        <TextView
            android:layout_centerVertical="true"
            android:id="@+id/tv_street"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_toLeftOf="@+id/tv_updated"
            android:textSize="17sp"
            android:singleLine="true"
            android:ellipsize="end"
            android:layout_weight="1"
            android:layout_marginLeft="16dp"
            tools:text="This  is fdfdfffddfdfdfffdfdfdfdffshort"/>

        <TextView
            android:id="@id/tv_updated"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_centerVertical="true"
            android:layout_marginLeft="10dp"
            android:text="Updated"
            android:textAllCaps="true"
            android:textStyle="bold"/>
    </LinearLayout>

根据您的要求,LinearLayout是更好的选择,如果没有工作让我知道


0
投票

此处发布的解决方案是布局中没有其他元素。

我提出了一个在RelativeLayout中使用的解决方案,您可以在其中修复结束视图或其他视图。 (用例:购物清单视图中的产品项目)

主要思想是将textViews包装在LinearLayout中,并让线性布局的大小与其子元素相对应。 TextViews始终并排。将变量TextView宽度指定为0dp,将权重指定为1(一)。然后将固定的TextView宽度分配给wrap_content。

使textView width 0dp(weight = 1)使其可伸缩并占用所有可用剩余空间。

现在,由于文本可变,LinearLayout会在任一方向上增长,任何可能与其他视图重叠。

但是,如果我们尝试alignEndOf和alignStartOf LinearLayout来修复边界,框架将修复LinearLayout在端点之间拉伸的大小。这将导致变量textView覆盖所有剩余的可用空间,即使内容文本不够大。

这导致固定的textView被放置在靠近右端点的位置,在较小内容长度的可变文本和自身之间留有空白空间。

因此,提出的解决方案。引入另一个布局来修复边界,让内部线性布局在外部布局限制内自由增长或折叠。

 <LinearLayout
        android:id="@+id/layout"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_toEndOf="@id/leftView"
        android:layout_toStartOf="@id/rightView"
        android:gravity="center_vertical"
        android:orientation="horizontal">

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

            <TextView
                android:id="@+id/card_name"
                style="@style/textStyleCardName"
                android:layout_width="0dp"
                android:layout_height="wrap_content"
                android:layout_marginEnd="4dp"
                android:layout_weight="1"
                android:ellipsize="end"
                android:singleLine="true"
                android:text="Platinum Card" />

            <TextView
                android:id="@+id/card_number"
                style="@style/textStyleCardNumber"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:ellipsize="none"
                android:singleLine="true"
                android:text="**** 3308" />
        </LinearLayout>
    </LinearLayout>
© www.soinside.com 2019 - 2024. All rights reserved.