有人会认为在字符串末尾在2019年显示三个点会很容易,但事实恰恰相反。我尝试过:
maxLines="1"
drawablePadding="10dp"
ellipsize="end"
ellipsize="marquee"
singleLine="true"
layout_width="match_parent"
layout_width="wrap_content"
我在stackoverflow上遇到了数十个问题,但这只是行不通。
我的布局文件非常简单:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:id="@+id/dialog_nearest_charger"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:minHeight="40dp"
android:orientation="horizontal"
android:weightSum="10">
<LinearLayout
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:minWidth="55dp"
android:layout_weight="1"
android:orientation="vertical">
<TextView
android:id="@+id/itemChargerDistance"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center_horizontal"
android:textColor="@color/colorCoarseDistance"
android:textStyle="bold"
android:textSize="20sp"
android:text="1.2" />
<TextView
android:id="@+id/itemChargerUnits"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center_horizontal"
android:textSize="12sp"
android:text="miles" />
</LinearLayout>
<ImageView
android:id="@+id/itemChargerOperator"
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:minWidth="40dp"
android:layout_weight="1"
app:srcCompat="@drawable/dot_cpo_cps_copy_5" />
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_marginStart="7dp"
android:layout_weight="2"
android:drawablePadding="10dp"
android:orientation="vertical">
<TextView
android:id="@+id/itemChargerTitle"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:drawablePadding="10dp"
android:ellipsize="end"
android:maxLines="1"
android:text="Kinross Park and Ride"
android:textSize="18sp"
android:textStyle="bold" />
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="horizontal">
<TextView
android:id="@+id/itemChargerAddress"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="1"
android:layout_marginStart="5dp"
android:textSize="14sp"
android:text="Junction Road" />
</LinearLayout>
</LinearLayout>
</LinearLayout>
我需要做的是在TextView itemChargerTitle
溢出时显示三个点。到目前为止,我发现的所有解决方案都无法在Android Studio预览版中正常工作。
答案 0 :(得分:0)
尝试一下
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:id="@+id/dialog_nearest_charger"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:minHeight="40dp"
android:orientation="horizontal"
android:weightSum="10">
<LinearLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:minWidth="55dp"
android:layout_weight="1"
android:orientation="vertical">
<TextView
android:id="@+id/itemChargerDistance"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center_horizontal"
android:textColor="@color/colorPrimary"
android:textStyle="bold"
android:textSize="20sp"
android:text="1.2" />
<TextView
android:id="@+id/itemChargerUnits"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center_horizontal"
android:textSize="12sp"
android:text="miles" />
</LinearLayout>
<ImageView
android:id="@+id/itemChargerOperator"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:minWidth="40dp"
android:layout_weight="1"
app:srcCompat="@drawable/ic_launcher_background" />
<LinearLayout
android:layout_width="0dp"
android:layout_height="match_parent"
android:layout_marginStart="7dp"
android:layout_weight="8"
android:orientation="vertical">
<TextView
android:id="@+id/itemChargerTitle"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:ellipsize="end"
android:singleLine="true"
android:maxLines="1"
android:text="Kinross Parkcvcxvxcgjghjhjhjvxcvcvcvcvcv and Ride"
android:textSize="18sp"
android:textStyle="bold" />
<TextView
android:id="@+id/itemChargerAddress"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginStart="5dp"
android:textSize="14sp"
android:text="Junction Road" />
</LinearLayout>
</LinearLayout>
输出
答案 1 :(得分:0)
请尝试这个。我已将宽度更新为0dp。使用android:layout_weight
时,请确保使用android:layout_width="0dp"
并且所有子项layout_weight
的总数为1或10。这意味着宽度为100%。
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/dialog_nearest_charger"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@color/colorWhite"
android:minHeight="40dp"
android:orientation="horizontal"
android:weightSum="10">
<LinearLayout
android:layout_width="0dp"
android:layout_height="match_parent"
android:layout_weight="1"
android:orientation="vertical">
<TextView
android:id="@+id/itemChargerDistance"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center_horizontal"
android:text="1.2"
android:textColor="@color/colorCoarseDistance"
android:textSize="20sp"
android:textStyle="bold" />
<TextView
android:id="@+id/itemChargerUnits"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center_horizontal"
android:text="miles"
android:textSize="12sp" />
</LinearLayout>
<ImageView
android:id="@+id/itemChargerOperator"
android:layout_width="0dp"
android:layout_height="match_parent"
app:srcCompat="@drawable/dot_cpo_cps_copy_5"
android:layout_weight="1" />
<LinearLayout
android:layout_width="0dp"
android:layout_height="match_parent"
android:layout_marginStart="7dp"
android:layout_weight="8"
android:drawablePadding="10dp"
android:orientation="vertical">
<TextView
android:id="@+id/itemChargerTitle"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:drawablePadding="10dp"
android:ellipsize="end"
android:lines="1"
android:maxLines="1"
android:padding="@dimen/ten_dp"
android:text="Kinross Park and Ride"
android:textSize="18sp"
android:textStyle="bold" />
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="horizontal">
<TextView
android:id="@+id/itemChargerAddress"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginStart="5dp"
android:layout_weight="1"
android:text="Junction Road"
android:textSize="14sp" />
</LinearLayout>
</LinearLayout>
</LinearLayout>
答案 2 :(得分:0)
您的TextView在末尾显示了三个点,但是您看不到它,因为您的布局超出了屏幕的边缘。将其父布局android:layout_weight更改为8以匹配容器android:weightSum = 10,您将看到圆点。
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:id="@+id/dialog_nearest_charger"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:minHeight="40dp"
android:orientation="horizontal"
android:weightSum="10">
<LinearLayout
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:minWidth="55dp"
android:layout_weight="1"
android:orientation="vertical">
<TextView
android:id="@+id/itemChargerDistance"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center_horizontal"
android:textColor="@color/colorCoarseDistance"
android:textStyle="bold"
android:textSize="20sp"
android:text="1.2" />
<TextView
android:id="@+id/itemChargerUnits"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center_horizontal"
android:textSize="12sp"
android:text="miles" />
</LinearLayout>
<ImageView
android:id="@+id/itemChargerOperator"
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:minWidth="40dp"
android:layout_weight="1"
app:srcCompat="@drawable/dot_cpo_cps_copy_5" />
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_marginStart="7dp"
android:layout_weight="8"
android:drawablePadding="10dp"
android:orientation="vertical">
<TextView
android:id="@+id/itemChargerTitle"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:drawablePadding="10dp"
android:ellipsize="end"
android:maxLines="1"
android:text="Kinross Park and Ride"
android:textSize="18sp"
android:textStyle="bold" />
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="horizontal">
<TextView
android:id="@+id/itemChargerAddress"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="1"
android:layout_marginStart="5dp"
android:textSize="14sp"
android:text="Junction Road" />
</LinearLayout>
</LinearLayout>
答案 3 :(得分:0)
TextView 具有 ellipsize 属性 你可以这样使用
<TextView
android:id="@+id/topicName"
android:layout_width="50dp"
android:layout_height="wrap_content"
android:layout_marginStart="10dp"
android:layout_marginTop="10dp"
android:layout_marginEnd="10dp"
android:maxLines="1"
android:ellipsize="end"
android:text="Very long long long long text"
android:textColor="@color/black"
android:textSize="16sp" />
它会像这样显示这个文本 好长好长好长...