纯XML实现:在一个行布局中,有2个TextView,后面的tv2紧跟前面的tv1,前面的tv1过长的话,后面为省略号,后面的tv2不会被挤出屏幕



如果要实现这种布局,怎么实现呢?用代码实现的话,后来人修改这块代码很可能一不小心会跳进坑里,所以本文旨在用纯XML实现该布局。

这个布局最大的难处是,前面的控件会把后面的控件顶出屏幕,不信的话各位可以去试试,各位会发现这里面有很多坑,到后面甚至会直接用代码去写。

下面便是主要的XML实现方案,主要的一个注意点是第二个LinearLayout的layout_width要为wrap_content,如果为march_parent的话,会发现会变成这样


<?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="match_parent"
    android:padding="5dp"
    android:orientation="vertical">

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

        <TextView
            android:id="@+id/name"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:ellipsize="end"
            android:layout_weight="1"
            android:singleLine="true"
            android:text="31233" />

        <TextView
            android:id="@+id/number"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_marginLeft="5dp"
            android:singleLine="true"
            android:text="321" />

    </LinearLayout>

    <TextView
        android:id="@+id/time"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="2016.3.3" />

</LinearLayout>

具体代码在这: https://github.com/SilasGao/OmitLayout

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值