我有一个带有ConstraintLayout的应用程序,我在其中组织了一些textview和一个饼图。
<android.support.v7.widget.CardView
android:id="@+id/crv1"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_margin="8dp"
app:cardBackgroundColor="@color/mycolor1"
app:cardCornerRadius="16dp"
app:cardElevation="8dp">
<android.support.constraint.ConstraintLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingBottom="8dp">
<TextView
android:id="@+id/txv1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_margin="8dp"
android:text="MY VALUES"
android:textColor="@color/colorPrimary"
android:textSize="18dp"
android:textStyle="bold"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" />
<TextView
android:id="@+id/txv2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_margin="8dp"
android:text="MY VALUE 1"
android:textColor="@color/colorPrimary"
android:textSize="18dp"
android:textStyle="bold"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/txv1" />
<TextView
android:id="@+id/txv3"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_margin="8dp"
android:textAlignment="viewEnd"
android:textColor="@color/colorPrimary"
android:textSize="18dp"
android:textStyle="bold"
app:layout_constraintEnd_toStartOf="@+id/pic1"
app:layout_constraintTop_toBottomOf="@+id/txv1" />
<TextView
android:id="@+id/txv4"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_margin="8dp"
android:text="MY VALUE 2"
android:textColor="@color/colorGrey"
android:textSize="18dp"
android:textStyle="bold"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/txv2" />
<TextView
android:id="@+id/txv5"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_margin="8dp"
android:textAlignment="viewEnd"
android:textColor="@color/colorGrey"
android:textSize="18dp"
android:textStyle="bold"
app:layout_constraintEnd_toStartOf="@+id/pic1"
app:layout_constraintTop_toBottomOf="@+id/txv3" />
<com.github.mikephil.charting.charts.PieChart
android:id="@+id/pic1"
android:layout_width="@dimen/dim_pie_chart"
android:layout_height="@dimen/dim_pie_chart"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintTop_toBottomOf="@+id/txv1" />
</android.support.constraint.ConstraintLayout>
</android.support.v7.widget.CardView>
这是我的结果,如果本机设置的字体大小是“正常”,那么它的工作正常:
至:
我的文字视图重叠......
有一种方法可以强制我的代码忽略原生字体大小设置吗?或者,我可以在左边的文本视图中将我的文本视图约束到右边的文本化开头,并设置ellipsize,如下所示:
<TextView
android:id="@+id/txv2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_margin="8dp"
android:ellipsize="end"
android:maxLines="1"
android:text="MY VALUE 1"
android:textColor="@color/colorPrimary"
android:textSize="18dp"
android:textStyle="bold"
app:layout_constraintEnd_toStartOf="@+id/txv3"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/txv1" />
<TextView
android:id="@+id/txv3"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_margin="8dp"
android:textAlignment="viewEnd"
android:textColor="@color/colorPrimary"
android:textSize="18dp"
android:textStyle="bold"
app:layout_constraintEnd_toStartOf="@+id/pic1"
app:layout_constraintTop_toBottomOf="@+id/txv1" />
无论如何,如果我这样做,左侧的文本视图不会剪切到父级的左侧,结果不好。如何强制将文本视图剪切到父级左侧?谢谢
尝试更换
<TextView
android:id="@+id/txv2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_margin="8dp"
android:ellipsize="end"
android:maxLines="1"
android:text="MY VALUE 1"
android:textColor="@color/colorPrimary"
android:textSize="18dp"
android:textStyle="bold"
app:layout_constraintEnd_toStartOf="@+id/txv3"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/txv1" />
同
<TextView
android:id="@+id/txv2"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_margin="8dp"
android:ellipsize="end"
android:maxLines="1"
android:text="MY VALUE 1"
android:textColor="@color/colorPrimary"
android:textSize="18dp"
android:textStyle="bold"
app:layout_constraintEnd_toStartOf="@+id/txv3"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/txv1" />
关键在于这一行:
android:layout_width="0dp"
这将使您的左视图正确结束约束。