使用透明圆创建视图

问题描述 投票:0回答:1

我想创建一个带圆角的视图和一个居中的圆形按钮。目前我正在使用带有圆形边框的矩形形状作为视图背景(绿色部分)和白色圆形形状,其中包含按钮(带有android徽标的绿色按钮)。

只要背景(此时为黄色/棕色,仅为了更好的可视化)与圆形形状具有相同的颜色,这样就可以正常工作。

但现在我想使用渐变背景:用透明圆圈实现相同外观的智能方法是什么?

我无法使用普通的android形状创建相同的外观(我有圆角的想法)。

enter image description here

android android-drawable shapes
1个回答
0
投票

用自定义视图解决了它。它将绘制一个填充给定颜色的矩形。之后,将清除椭圆形。

我将发布一个最小化的代码(没有自定义属性等),也许它有一天会帮助某人:

public class InvertedCircleView extends View {

    private Paint mPaint;
    private float mCanvasCenterX;

    private float mCenterCircleWidth, mCenterCircleHeight;


    public InvertedCircleView(Context context, AttributeSet attrs) {
        super(context, attrs);

        mPaint = new Paint(Paint.ANTI_ALIAS_FLAG);
        setLayerType(View.LAYER_TYPE_SOFTWARE, null);
    }

    @Override
    public void onDraw(Canvas canvas) {
        super.onDraw(canvas);

        mPaint.setColor(getResources().getColor(android.R.color.holo_green_dark));
        mPaint.setStyle(Paint.Style.FILL);
        canvas.drawPaint(mPaint);

        mPaint.setXfermode(new PorterDuffXfermode(PorterDuff.Mode.CLEAR));

        mCenterCircleWidth = canvas.getWidth();        
        mCenterCircleHeight = canvas.getHeight();        

        mCanvasCenterX = canvas.getWidth() / 2;

        canvas.drawOval(mCanvasCenterX - (mCenterCircleWidth / 2),
                -mCenterCircleHeight,
                mCanvasCenterX + (mCenterCircleWidth / 2),
                mCenterCircleHeight,
                mPaint);
    }
}
© www.soinside.com 2019 - 2024. All rights reserved.