美文网首页andnroid
一个drawableRight可以居中的TextView

一个drawableRight可以居中的TextView

作者: vachex | 来源:发表于2019-08-15 15:51 被阅读0次
    我们都知道TextView可以设置drawableLeft/Right/Top/Bottom, 然后会显示在文本的对应一侧。但是为啥没有drawableCenter呢。比如下面这种控件,即便设置了gravity为center,小箭头依然还是会在最右边,但是我希望的是文本和箭头一起均匀的居中(网上全是drawableLeft和文本居中的例子,drawableRight居中还稍有不同)。 image.png

    怎么办呢,可以用TextView和ImageView组合。而这里我们可以自定义控件,重写TextView的onDraw方法,重新绘制就可以了。
    要使得drawableRight和文本紧挨着就只能设置gravity为Gravity.RIGHT了,然后要让他们居中就在onDraw时将画布平移至合适的位置。效果如下


    image.png

    代码:

    import android.content.Context;
    import android.graphics.Canvas;
    import android.graphics.drawable.Drawable;
    import android.util.AttributeSet;
    import android.view.Gravity;
    import android.support.v7.widget.AppCompatTextView;
    
    /**
     * 文字和drawableRight一起居中的TextView
     *
     */
    public class RightDrawableCenterTextView extends AppCompatTextView {
        public RightDrawableCenterTextView(Context context) {
            this(context, null);
        }
    
        public RightDrawableCenterTextView(Context context, AttributeSet attrs) {
            this(context, attrs, 0);
        }
    
        public RightDrawableCenterTextView(Context context, AttributeSet attrs, int defStyleAttr) {
            super(context, attrs, defStyleAttr);
            init();
        }
    
        private void init() {
            setGravity(Gravity.CENTER | Gravity.RIGHT);
        }
    
        @Override
        protected void onDraw(Canvas canvas) {
            Drawable[] drawables = getCompoundDrawables();
            Drawable drawable = drawables[2];
            if (drawable != null) {
                float textWidth = getPaint().measureText(getText().toString());
                int drawablePadding = getCompoundDrawablePadding();
                int drawableWidth = drawable.getMinimumWidth();
                float bodyWidth = textWidth + drawableWidth + drawablePadding + getPaddingLeft() + getPaddingRight();
                canvas.translate((bodyWidth - getWidth()) / 2, 0);
            }
            super.onDraw(canvas);
        }
    }
    

    相关文章

      网友评论

        本文标题:一个drawableRight可以居中的TextView

        本文链接:https://www.haomeiwen.com/subject/wnpzjctx.html