android 自定义 TextView 点击字体镂空效果

网上好多字体镂空效果都是单行的,及没有点击效果的,所以,我没办法就自己写了一个TextView ,目的是自定义这个,点击的时候才是镂空效果,但是,平时的时候是常态,就像是selector一样,这是一个工具类,你们拿去直接用就行了

public class ShowPalettePageTextView extends View {

    public static final int BACKGROUND_COLOR = MyApp.getAppColor(R.color.color_dialog_text_content);
    private static final int DEFAULT_RADIUS = MyApp.getAppDimen(R.dimen.default_radio_size);
    private TextPaint mTextPaint;
    private Paint mBackgroundPaint;
    private RectF mBackgroundRect;
    private boolean isPressed = false;
    private String mShowPageText;

    private Xfermode xfermode = new PorterDuffXfermode(PorterDuff.Mode.CLEAR);

    public ShowPalettePageTextView(Context context) {
        this(context, null);
    }

    public ShowPalettePageTextView(Context context, AttributeSet attrs) {
        this(context, attrs, -1);
    }

    public ShowPalettePageTextView(Context context, AttributeSet attrs, int defStyleAttr) {
        super(context, attrs, defStyleAttr);
        mTextPaint = new TextPaint();
        mTextPaint.setAntiAlias(true);
        mTextPaint.setColor(BACKGROUND_COLOR);
        mTextPaint.setTextSize(MyApp.getAppDimen(R.dimen.text_size));
        mBackgroundPaint = new Paint();
        mBackgroundPaint.setColor(BACKGROUND_COLOR);
        mBackgroundPaint.setAntiAlias(true);
        mBackgroundRect = new RectF();
    }

    @Override
    protected void onSizeChanged(int width, int height, int oldw, int oldh) {
        super.onSizeChanged(width, height, oldw, oldh);
        mBackgroundRect.set(0, 0, width, height);
    }

    public void setText(String showPageText) {
        this.mShowPageText = showPageText;
        invalidate();
    }

    @Override
    protected void onDraw(Canvas canvas) {
        drawBackground(canvas);
        drawText(canvas);
    }

    private void drawBackground(Canvas canvas) {
        if (isPressed) {
            mBackgroundPaint.setStyle(Paint.Style.FILL);
        } else {
            mBackgroundPaint.setStyle(Paint.Style.STROKE);
        }
        canvas.drawRoundRect(mBackgroundRect, DEFAULT_RADIUS, DEFAULT_RADIUS, mBackgroundPaint);
    }

    private void drawText(Canvas canvas) {
        if (mShowPageText == null) {
            return;
        }
        if (isPressed) {
            mTextPaint.setXfermode(xfermode);
        } else {
            mTextPaint.setXfermode(null);
        }
        float x = mBackgroundRect.width() / 2 - mTextPaint.measureText(mShowPageText) / 2;
        float y = mBackgroundRect.top + mBackgroundRect.height() / 2 + mTextPaint.getTextSize() / 3;
        canvas.drawText(mShowPageText, x, y, mTextPaint);
    }

    @SuppressLint("ClickableViewAccessibility")
    @Override
    public boolean onTouchEvent(MotionEvent event) {
        if (event.getAction() == MotionEvent.ACTION_DOWN) {
            isPressed = true;
            invalidate();
        } else if (event.getAction() == MotionEvent.ACTION_UP) {
            isPressed = false;
            invalidate();
        }
        return super.onTouchEvent(event);
    }

}

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在Android定义TextView中显示全部内容,可以使用以下两种方法: 1. 使用setEllipsize()方法 通过设置setEllipsize()方法,可以在TextView的末尾添加省略号,从而指示文本被截断。你可以使用以下代码来实现: ``` yourTextView.setEllipsize(TextUtils.TruncateAt.END); yourTextView.setSingleLine(true); ``` 上述代码将设置TextView只显示一行并在末尾添加省略号。 2. 自定义TextView 你可以从TextView类继承一个新类,并覆盖onMeasure()方法以测量控件的高度和宽度。 你可以使用以下代码实现: ``` public class CustomTextView extends TextView { public CustomTextView(Context context) { super(context); } public CustomTextView(Context context, AttributeSet attrs) { super(context, attrs); } public CustomTextView(Context context, AttributeSet attrs, int defStyle) { super(context, attrs, defStyle); } @Override protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) { super.onMeasure(widthMeasureSpec, heightMeasureSpec); //获取TextView的内容 CharSequence text = getText(); if (text != null) { //测量TextView的高度 int width = getMeasuredWidth(); int height = getMeasuredHeight(); int lineCount = getLineCount(); int lineHeight = getLineHeight(); int totalHeight = lineCount * lineHeight; if (totalHeight > height) { setMeasuredDimension(width, totalHeight); } } } } ``` 上述代码将测量TextView的高度,如果文本的高度超出了TextView的高度,则调整TextView的高度以适应文本。然后你可以使用此自定义TextView来显示你的文本。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值