我是靠谱客的博主 烂漫母鸡,最近开发中收集的这篇文章主要介绍android 描边 投影 textview,TextView 文字描边,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

在不是很明显的描边 可以使用 阴影来互动如下:

android:shadowColor 阴影颜色

android:shadowDx 阴影的水平偏移量

android:shadowDy 阴影的垂直偏移量

android:shadowRadius 阴影的范围

真正的描边方法如下:

实现方法是两个TextView叠加,只有描边的TextView为底,实体TextView叠加在上面

public class MyTextView2 extends TextView {

private TextView borderText = null;///用于描边的TextView

public MyTextView2(Context context) {

super(context);

borderText = new TextView(context);

init();

}

public MyTextView2(Context context, AttributeSet attrs) {

super(context, attrs);

borderText = new TextView(context, attrs);

init();

}

public MyTextView2(Context context, AttributeSet attrs, int defStyleAttr) {

super(context, attrs, defStyleAttr);

borderText = new TextView(context, attrs, defStyleAttr);

init();

}

public void init() {

TextPaint tp1 = borderText.getPaint();

tp1.setStrokeWidth(1); //设置描边宽度

tp1.setStyle(Paint.Style.STROKE); //对文字只描边

borderText.setTextColor(Color.GREEN); //设置描边颜色

borderText.setGravity(getGravity());

}

@Override

public void setLayoutParams(ViewGroup.LayoutParams params) {

super.setLayoutParams(params);

borderText.setLayoutParams(params);

}

@Override

protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {

CharSequence tt = borderText.getText();

//两个TextView上的文字必须一致

if (tt == null || !tt.equals(this.getText())) {

borderText.setText(getText());

this.postInvalidate();

}

super.onMeasure(widthMeasureSpec, heightMeasureSpec);

borderText.measure(widthMeasureSpec, heightMeasureSpec);

}

protected void onLayout(boolean changed, int left, int top, int right, int bottom) {

super.onLayout(changed, left, top, right, bottom);

borderText.layout(left, top, right, bottom);

}

@Override

protected void onDraw(Canvas canvas) {

borderText.draw(canvas);

super.onDraw(canvas);

}

}

产考:

最后

以上就是烂漫母鸡为你收集整理的android 描边 投影 textview,TextView 文字描边的全部内容,希望文章能够帮你解决android 描边 投影 textview,TextView 文字描边所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(40)

评论列表共有 0 条评论

立即
投稿
返回
顶部