Android TextView SpannableString多个字体大小不一致的情况下,设置字体垂直居中显示

1、我的TextView。

<TextView
                    android:id="@+id/tev_title"
                    android:layout_width="match_parent"
                    android:layout_height="@dimen/dp_50"
                    android:gravity="center"
                    android:text="@string/create_user"
                    android:textColor="@color/color_FFFFFFFF"
                    android:textSize="@dimen/sp_17" />

2、res下的values文件夹下的strings.xml文件的资源字符串。

<string name="created_b">创建了</string>
    <string name="users_b">个用户</string>

3、TextView Style 管理类。

package com.phone.common_library.manager;

import android.content.Context;
import android.graphics.Typeface;
import android.text.Spannable;
import android.text.SpannableString;
import android.text.style.AbsoluteSizeSpan;
import android.text.style.StyleSpan;
import android.widget.TextView;

import com.phone.common_library.spannable.VerticalAlignTextSpan;

public class TextViewStyleManager {

    private static final String TAG = TextViewStyleManager.class.getSimpleName();

    public static void setTextViewStyle(TextView textView,
                                        String data,
                                        int start) {
        Spannable spannable = new SpannableString(data);
        // 粗体
        spannable.setSpan(new StyleSpan(Typeface.BOLD), start, data.length(), Spannable.SPAN_INCLUSIVE_INCLUSIVE);
        // 显示
        textView.setText(spannable);
    }

    public static void setTextViewStyle(Context context,
                                        TextView textView,
                                        String data,
                                        int start,
                                        int end,
                                        float size) {
        Spannable spannable = new SpannableString(data);
        // 粗体
        spannable.setSpan(new StyleSpan(Typeface.BOLD), start, end, Spannable.SPAN_INCLUSIVE_INCLUSIVE);
        spannable.setSpan(new AbsoluteSizeSpan(ScreenManager.spToPx(context, size)), start, end, Spannable.SPAN_INCLUSIVE_INCLUSIVE);
        // 显示
        textView.setText(spannable);
    }

    public static void setTextViewStyleVerticalCenter(Context context,
                                        TextView textView,
                                        String data,
                                        int start,
                                        int end,
                                        float size) {
        Spannable spannable = new SpannableString(data);
        // 粗体
        spannable.setSpan(new StyleSpan(Typeface.BOLD), start, end, Spannable.SPAN_INCLUSIVE_INCLUSIVE);
        spannable.setSpan(new AbsoluteSizeSpan(ScreenManager.spToPx(context, size)), start, end, Spannable.SPAN_INCLUSIVE_INCLUSIVE);
        //SpannableString字体大小不一致垂直居中显示
        spannable.setSpan(new VerticalAlignTextSpan(context, size), start, end, SpannableString.SPAN_INCLUSIVE_EXCLUSIVE);
        // 显示
        textView.setText(spannable);
    }

}

4、在Activity中设置SpannableString多个字体大小不一致的情况下,设置字体垂直居中显示。

TextViewStyleManager.setTextViewStyleVerticalCenter(this,
                    tevTitle, getResources().getString(R.string.created_b)
                            + 3
                            + getResources().getString(R.string.users_b),
                    getResources().getString(R.string.created_b).length(),
                    getResources().getString(R.string.created_b).length() + 1,
                    28);

5、效果如下(见下图一,图中红圈处的3这个字最大,而且这个字水平居中显示了)。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
如果两个TextView文字大小一致,但是要顶部对齐,您可以使用以下方法: 1. 设置两个TextView的高度为wrap_content,并且让它们分别居中对齐。 2. 让第一个TextView的底部与第二个TextView的顶部对齐。 3. 在第一个TextView的底部添加一个空的View,并且设置这个View的高度为第二个TextView的字号大小。 具体可以参考下面的代码: ``` <RelativeLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:padding="16dp"> <TextView android:id="@+id/textView1" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="TextView 1" android:textSize="18sp" android:layout_centerVertical="true" /> <View android:layout_width="1dp" android:layout_height="0dp" android:layout_centerVertical="true" android:layout_toEndOf="@id/textView1" /> <TextView android:id="@+id/textView2" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="TextView 2" android:textSize="16sp" android:layout_toEndOf="@id/view" android:layout_alignTop="@id/textView1" android:layout_centerVertical="true" /> <View android:id="@+id/view" android:layout_width="0dp" android:layout_height="16sp" android:layout_alignBottom="@id/textView1" android:layout_toEndOf="@id/textView1" /> </RelativeLayout> ``` 其中,第一个TextView和第二个TextView都是wrap_content,但是通过设置`android:layout_centerVertical="true"`让它们垂直居中对齐。第二个TextView通过`android:layout_alignTop="@id/textView1"`和`android:layout_centerVertical="true"`实现了顶部对齐。空的View通过`android:layout_height="16sp"`设置了高度,使得它和第二个TextView的字号大小相同。同时,通过`android:layout_alignBottom="@id/textView1"`让它与第一个TextView的底部对齐,实现了上述的三个步骤。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值