Android 设计一个菱形形状的Imageview组件.
巴扎黑
巴扎黑 2017-04-17 17:49:03
0
4
531

网上没有资料,特来请教下大神

巴扎黑
巴扎黑

全部回覆(4)
伊谢尔伦

大致思路:自訂view,先畫矩形(drawRect),然後cavas旋轉(rotate),再畫圖片,最後做XOR操作:

paint.setXfermode(new PorterDuffXfermode(Mode.SRC_ATOP));
黄舟

可以看看關於PorterDuffXfermode的使用 https://segmentfault.com/a/11...

Ty80

Paint.drawPath

參考:多邊形ImageView

伊谢尔伦

使用PorterDuffXfermode, 可以看看影像合成Xfermode和任意形狀ImageView

public class RectImageView extends ImageView {
    private Paint mPaint;
    private Xfermode mXfermode;
    private Bitmap mRectMask;

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

    public RectImageView(Context context, AttributeSet attrs) {
        this(context, attrs, 0);
    }

    public RectImageView(Context context, AttributeSet attrs, int defStyleAttr) {
        super(context, attrs, defStyleAttr);
        mPaint = new Paint(Paint.ANTI_ALIAS_FLAG);
        mPaint.setColor(Color.RED);
        // 关键方法
        mXfermode = new PorterDuffXfermode(PorterDuff.Mode.DST_IN);
    }

    @Override
    protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
        super.onMeasure(widthMeasureSpec, heightMeasureSpec);
        createMask();
    }

    private void createMask() {
        if (mRectMask == null) {
            int maskWidth = getMeasuredWidth();
            int maskHeight = getMeasuredHeight();
            mRectMask = Bitmap.createBitmap(maskWidth, maskHeight, Bitmap.Config.ARGB_8888);
            Canvas canvas = new Canvas(mRectMask);
            canvas.translate(maskWidth / 2, 0);
            canvas.rotate(45);
            int rectSize = (int) (maskWidth / 2 / Math.sin(Math.toRadians(45)));
            canvas.drawRect(0, 0, rectSize, rectSize, mPaint);
        }
    }


    @Override
    protected void onDraw(Canvas canvas) {
        int id = canvas.saveLayer(0, 0, canvas.getWidth(), canvas.getHeight(), null, Canvas.ALL_SAVE_FLAG);
        super.onDraw(canvas);
        // 关键方法
        mPaint.setXfermode(mXfermode);
        canvas.drawBitmap(mRectMask, 0, 0, mPaint);
        mPaint.setXfermode(null);
        canvas.restoreToCount(id);
    }
}

效果如下

熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板