Android TextView实现词组高亮的示例代码

 更新时间:2017年10月30日 11:37:28   作者:Young_Ji  
本篇文章主要介绍了Android TextView实现词组高亮的示例代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

本文介绍了Android TextView实现词组高亮的示例代码,分享给大家,具体如下:

HighlightTextView

Android文本高亮控件,基于View实现。

特点

  1. 文本高亮
  2. 单词自动换行
  3. 高亮词组保持在同一行显示

效果如下:

主要逻辑:

  1. 两个 Paint 负责绘制不同的文字
  2. 在每次绘制之前计算将要绘制的文本是否会超出屏幕宽度,如果超出则换行
protected void onDraw(Canvas canvas) {
    super.onDraw(canvas);
    float x_draw = getPaddingLeft();
    float y_draw = getPaddingTop() + dfPaint.getTextSize();
    for (ExtendText t : extendTexts) {
      Paint paint = t.isHighlight ? hlPaint : dfPaint;
      float textLen = paint.measureText(t.textUnit);
      if (x_draw + textLen > width) {
        x_draw = getPaddingLeft();
        y_draw += paint.getTextSize();
      }
      canvas.drawText(t.textUnit, x_draw, y_draw, paint);
      x_draw += textLen;
    }
  }

Demo

Java:

public class MainActivity extends Activity {
  private final static String TEXT = "";
  private final static String[] HIGHLIGHT = {};

  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    HighLightTextView hlTv = (HighLightTextView) findViewById(R.id.hlTv);
    hlTv.setDisplayedText(TEXT, Arrays.asList(HIGHLIGHT));
    hlTv.setDefaultColor(Color.BLACK);
    hlTv.setHighlightColor(ContextCompat.getColor(this, R.color.colorPrimary));

  }
}

XML:

<com.jy.highlighttextview.HighLightTextView
  android:id="@+id/hlTv"
  android:layout_width="match_parent"
  android:layout_height="wrap_content"
  android:padding="5dp"
  app:textSize="16sp" />

Methods:

method 方法 description 描述
setDefaultColor(int color) 设置默认显示颜色
setHighlightColor(int color) 设置高亮颜色
setDisplayedText(String text, List<String> highlights) 设置显示的文本和高亮词组
setTextSize(float size) 设置字体大小

xml value:

app:defaultColor="@color/colorPrimary"
app:highlightColor="@color/colorAccent"
app:text="@string/app_name"
app:textSize="16sp"

完整请移步github-> jiyangg -> HighlightText

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。 

相关文章

最新评论