美文网首页
Android布局中一行有三个控件,中间TextView会挤压右

Android布局中一行有三个控件,中间TextView会挤压右

作者: JellyCai | 来源:发表于2019-04-18 16:19 被阅读0次

    需求是一行显示三个控件,左边显示一张图片,中间显示TextView,右边显示图片
    如果不做处理,TextView如果过长,右边的图片会被挤压出界面
    如果设置TextView的属性为

                android:layout_weight="1"
                android:ellipsize="end"
                android:singleLine="true"
    

    显示会ok,但是如果TextView不过长,右边的图片也会显示在最右边
    最后的解决方案是,在外面加一个布局,width为match_parent,里面的布局width为wrap_content

    <?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="wrap_content"
        android:background="?attr/item_bg">
    
        <LinearLayout
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:gravity="center_vertical"
            android:orientation="horizontal"
            android:padding="10dp">
    
            <ImageView
                android:id="@+id/iv_icon"
                android:layout_width="40dp"
                android:layout_height="40dp" />
    
            <TextView
                android:id="@+id/tv_name"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_marginStart="10dp"
                android:layout_weight="1"
                android:ellipsize="end"
                android:singleLine="true"
                android:textColor="?attr/text1"
                android:textSize="@dimen/text3" />
    
            <ImageView
                android:id="@+id/iv_hint"
                android:layout_width="wrap_content"
                android:layout_height="18dp"
                android:layout_marginStart="5dp" />
        </LinearLayout>
    
    
    </LinearLayout>
    

    问题解决

    相关文章

      网友评论

          本文标题:Android布局中一行有三个控件,中间TextView会挤压右

          本文链接:https://www.haomeiwen.com/subject/nnetgqtx.html