Android TextView實現片語高亮的示例程式碼

Android TextView實現片語高亮的示例程式碼

本文介紹了Android TextView實現片語高亮的示例程式碼,分享給大家,具體如下:

HighlightTextView

Android文字高亮控制元件,基於View實現。

特點

文字高亮
單詞自動換行
高亮片語保持在同一行顯示

效果如下:

主要邏輯:

兩個 Paint 負責繪製不同的文字
在每次繪製之前計算將要繪製的文字是否會超出螢幕寬度,如果超出則換行


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