这里也要简单说一下,这些小模块并不是我原创,也是当时查资料找到的,由于时间比较久,原文链接已经忘记了,所以这里就不列出引用链接了。不过这些代码我都修改、完善过,也添加了一些注释,希望对大家有帮助。
文字描边这个功能挺实用的,如果是单一背景下显示文字,文字描边也可起到装饰作用。如果是复杂背景下,尤其是在不同图片背景下显示文字,因为文字颜色很容易和图片背景相似,这样导致文字看不清楚,用户体验不佳。如果文字经过不同颜色描边后,文字轮廓部分一种颜色,文字内部另一种颜色,因为一般情况下,图片要么和文字轮廓颜色相近,要么和文字内部颜色相近,这样不管图片背景多复杂,文字都会整体显示。
我这里使用的方法是重写TextVIEw
方式。
下面是相关代码,整体比较简单,很容易懂。
继承的TextVIEw文字描边类如下:
public class strokeTextVIEw extends TextVIEw{ private TextVIEw outlineTextVIEw = null; public strokeTextVIEw(Context context) { super(context); outlineTextVIEw = new TextVIEw(context); init(); } public strokeTextVIEw(Context context,AttributeSet attrs) { super(context,attrs); outlineTextVIEw = new TextVIEw(context,attrs); init(); } public strokeTextVIEw(Context context,AttributeSet attrs,int defStyle) { super(context,attrs,defStyle); outlineTextVIEw = new TextVIEw(context,defStyle); init(); } public voID init() { TextPaint paint = outlineTextVIEw.getPaint(); paint.setstrokeWIDth(3);// 描边宽度 paint.setStyle(Style.stroke); outlineTextVIEw.setTextcolor(color.parsecolor("#45c01a"));// 描边颜色 outlineTextVIEw.setGravity(getGravity()); } @OverrIDe public voID setLayoutParams (VIEwGroup.LayoutParams params) { super.setLayoutParams(params); outlineTextVIEw.setLayoutParams(params); } @OverrIDe protected voID onMeasure(int wIDthMeasureSpec,int heightmeasureSpec) { super.onMeasure(wIDthMeasureSpec,heightmeasureSpec); // 设置轮廓文字 CharSequence outlineText = outlineTextVIEw.getText(); if (outlineText == null || !outlineText.equals(this.getText())) { outlineTextVIEw.setText(getText()); postInvalIDate(); } outlineTextVIEw.measure(wIDthMeasureSpec,heightmeasureSpec); } @OverrIDe protected voID onLayout (boolean changed,int left,int top,int right,int bottom) { super.onLayout(changed,left,top,right,bottom); outlineTextVIEw.layout(left,bottom); } @OverrIDe protected voID onDraw(Canvas canvas) { outlineTextVIEw.draw(canvas); super.onDraw(canvas); }}
布局文件如下:
<com.my.teststroketextvIEw.strokeTextVIEw androID:ID="@+ID/test_stroketextvIEw" androID:layout_wIDth="wrap_content" androID:layout_height="wrap_content" androID:layout_marginleft="10dp" androID:layout_marginRight="10dp" androID:textSize="25sp" androID:textcolor="@color/dark_gray" androID:text="@string/hello_world" />
调用代码如下:
private strokeTextVIEw test_stroketextvIEw = null; @OverrIDeprotected voID onCreate(Bundle savedInstanceState){ super.onCreate(savedInstanceState); setContentVIEw(R.layout.activity_main); test_stroketextvIEw = (strokeTextVIEw)findVIEwByID(R.ID.test_stroketextvIEw); test_stroketextvIEw.setText("Hello World!");}
如果想更改文字描边宽度,或者描边颜色,需要修改上面的strokeTextVIEw
类,当然也可以把这个类设计的更灵活些,这样就可以动态的修改描边宽度或者描边颜色。
以上就是androID中文字描边功能的实现实例,希望本文对大家学习androID开发有所帮助。请大家多多支持编程小技巧。
总结以上是内存溢出为你收集整理的android文字描边功能的实现全部内容,希望文章能够帮你解决android文字描边功能的实现所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)