Android自定义View_绘制菱形图片

本文介绍了如何在Android中自定义View来实现圆角菱形图片的绘制,通过创建圆角矩形遮罩层,旋转45度,结合PorterDuffXfermode的SRC_IN模式完成图片的裁剪。详细步骤包括绘制遮罩层、恢复画布状态和最终的图片绘制。总结中强调了在处理Canvas时注意方向的恢复和改变。
摘要由CSDN通过智能技术生成

自定义菱形图片.png

一、 前言

在实际项目中,用户头像,音乐专辑都有可能用到圆形,菱形等无规则图像,需要自己自定义View实现相应的功能。

二、思路

需求:制作圆角菱形的图片
思路:
1、绘制出圆角矩形的遮罩层;
2、将矩形旋转45°;
3、使用画笔的PorterDuffXfermode的SRC_IN属性;
4、将图片绘制遮罩层上。

三、知识点PorterDuffXfermode

PorterDuffXfermode在网上有许多讲解它的文章,这里只讲解最常用的两种模式SRC_IN和DST_IN。
SRC_IN:【本文所用的模式】显示底层图像和上方图像的相交区域,且显示的是上方图像。如图所示,先绘制出黄色的底层图像,再绘制出蓝色的图像,设置的模式为SRC_IN,则显示的是两张图像相交的扇形区域,且为上层蓝色图像。
Picture.pngSRC_IN.png
DST_IN:显示底层图像和上方图像的相交区域,且显示的是底层图像。如图所示,先绘制出黄色的底层图像,再绘制出蓝色的图像,设置的模式为DST_IN,则显示的是两张图像相交的扇形区域,且为底层黄色图像。
DST_IN.png

四、实现

1、根据图片的大小绘制出圆角矩形的遮罩层;

//        创建图片
        mImageBitmap = BitmapFactory.decodeResource(getResources(), R.drawable.picture);
//        获取图片的宽高
        mWidth = mImageBitmap.getWidth();
        mHeight = mImageBitmap.getHeight();
        mMaskBitmap = Bitmap.createBitmap(mWidth, mHeight, Bitmap.Config.ARGB_8888);
        Canvas maskCanvas = new Canvas(mMaskBitmap);

        mPaint = new Paint();
        mPaint.setColor(Color.YELLOW);
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值