TextView.setTextSize和Paint.setTextSize

TextView.setTextSize和Paint.setTextSize


TextView.setTextSize是以sp为单位的


Paint.setTextSize()是以像素(px)为单位的


/**
 * 将sp值转换为px值,保证文字大小不变
 *
 * @param spValue
 * @param fontScale (DisplayMetrics类中属性scaledDensity)
 * @return
 */
public static int sp2px(Context context, float spValue) {
    final float fontScale = context.getResources().getDisplayMetrics().scaledDensity;
    return (int) (spValue * fontScale + 0.5f);
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
可以使用 `SpannableString` 实现在 `TextView` 中嵌套另一个 `TextView` 的效果。 示例代码如下: ```java TextView textView = findViewById(R.id.text_view); SpannableString spannableString = new SpannableString("这是一个TextView,里面嵌套着另一个TextView"); TextView nestedTextView = new TextView(this); nestedTextView.setText("嵌套的TextView"); nestedTextView.setTextSize(18); nestedTextView.setTextColor(Color.BLUE); spannableString.setSpan(new ForegroundColorSpan(Color.RED), 0, 8, Spannable.SPAN_EXCLUSIVE_EXCLUSIVE); spannableString.setSpan(new ForegroundColorSpan(Color.GREEN), 8, 15, Spannable.SPAN_EXCLUSIVE_EXCLUSIVE); spannableString.setSpan(new ForegroundColorSpan(Color.YELLOW), 15, spannableString.length(), Spannable.SPAN_EXCLUSIVE_EXCLUSIVE); spannableString.setSpan(new CustomSpan(nestedTextView), 15, spannableString.length(), Spannable.SPAN_EXCLUSIVE_EXCLUSIVE); textView.setText(spannableString); ``` 其中,`CustomSpan` 是自定义的 `Span`,用于将 `TextView` 嵌套进去。示例代码如下: ```java public class CustomSpan extends ReplacementSpan { private final TextView textView; public CustomSpan(TextView textView) { this.textView = textView; } @Override public int getSize(@NonNull Paint paint, CharSequence text, int start, int end, @Nullable Paint.FontMetricsInt fm) { return (int) (textView.getPaint().measureText(text, start, end) + 0.5f); } @Override public void draw(@NonNull Canvas canvas, CharSequence text, int start, int end, float x, int top, int y, int bottom, @NonNull Paint paint) { textView.layout(0, 0, textView.getWidth(), textView.getHeight()); textView.draw(canvas); } } ``` 注意,因为嵌套的 `TextView` 是动态创建的,所以需要在 `draw` 方法中先对其进行布局。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

chenhuakang

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值