android 按钮 图片文字居中显示,自定义Button(drawableLeft与文本一起居中显示)

很多控件(比如TextView/Button...)可以使用drawableLeft/drawableRight等,但是使用的时候发现文本和图片总是不能一起居中显示,所以下面提供一种解决方案,这里以Button/drawable Left为例:

使用步骤:

自定义Button

import android.content.Context;

import android.graphics.Canvas;

import android.graphics.drawable.Drawable;

import android.util.AttributeSet;

/**

* Created by Administrator on 2017/4/8.

*/

/**

* drawableRight与文本一起居中显示

*

*

*/

class DrawableLeftCenterButton extends android.support.v7.widget.AppCompatButton {

public DrawableLeftCenterButton(Context context, AttributeSet attrs) {

super(context, attrs);

}

@Override

protected void onDraw(Canvas canvas) {

canvas = getTopCanvas(canvas);

super.onDraw(canvas);

}

private Canvas getTopCanvas(Canvas canvas) {

Drawable[] drawables = getCompoundDrawables();

if (drawables == null) {

return canvas;

}

Drawable drawable = drawables[0];// 左面的drawable

if (drawable == null) {

drawable = drawables[2];// 右面的drawable

}

// float textSize = getPaint().getTextSize(); // 使用这个会导致文字竖向排下来

float textSize = getPaint().measureText(getText().toString());

int drawWidth = drawable.getIntrinsicWidth();

int drawPadding = getCompoundDrawablePadding();

float contentWidth = textSize + drawWidth + drawPadding;

int leftPadding = (int) (getWidth() - contentWidth);

setPadding(0, 0, leftPadding, 0); // 直接贴到左边

float dx = (getWidth() - contentWidth) / 2;

canvas.translate(dx, 0);// 往右移动

return canvas;

}

}

在布局文件中使用:

和普通button一样使用

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值