android设置自定义颜色阴影效果,Android自定义图片圆角,增加渐变阴影

自定义图片,切圆角、圆形,增加渐变颜色阴影

一、先上效果图

50b42337ff8d

效果图

二、GitHub

三、思路

1、图片切成圆角(圆形)

2、绘制一个带有渐变阴影的图形

3、融合圆角图片和阴影图形

四、实现(以下是以圆角为例,圆形的类似)

1)图片切成圆角

BitmapShader bitmapShader = new BitmapShader(bitmap, Shader.TileMode.CLAMP, Shader.TileMode.CLAMP);

Bitmap targetBitmap = Bitmap.createBitmap(imageWidth, imageHeight, Bitmap.Config.ARGB_8888);

Canvas targetCanvas = new Canvas(targetBitmap);

mPaint.setShader(bitmapShader);

RectF rect = new RectF(0, 0, imageWidth, imageHeight);

targetCanvas.drawRoundRect(rect, mRadius, mRadius, mPaint);

形成的效果图

50b42337ff8d

圆角

2)绘制一个带有渐变阴影的图形

设置渐变阴影 mPaint.setShadowLayer(mShadowRadius, 1, 1, mShadowColor);

第一个参数:阴影大小;

第二个参数:X轴偏移量;

第三个参数:Y轴偏移量;

第四个参数:阴影颜色;

X、Y轴偏移量都为1时是四周都有阴影

设置paint的颜色和阴影颜色一致,不然会出现黑边 mPaint.setColor(mShadowColor);

mPaint.setColor(mShadowColor);

mPaint.setShadowLayer(mShadowRadius, 1, 1, mShadowColor);

Bitmap target = Bitmap.createBitmap(width, height, Bitmap.Config.ARGB_8888);

Canvas canvas = new Canvas(target);

RectF rectF = new RectF(mShadowRadius, mShadowRadius, width - mShadowRadius, height - mShadowRadius);

canvas.drawRoundRect(rectF, mRadius, mRadius, mPaint);

50b42337ff8d

阴影效果图

3)融合圆角图片和阴影图形

上代码之前先上一个图像合成效果示意图

50b42337ff8d

图像合成效果示意图

好了,上面就是图像融合的一些方式,我用的是SRC_OVER。记得把paint设置的shadowLayer去掉

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

mPaint.setShadowLayer

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值