Android:Paint的setMaskFilter(MaskFilter maskfilter)

1.setMaskFilter(MaskFilter maskfilter)

setMaskFilter(MaskFilter maskfilter)是paint中的方法,它可以用来对图像进行一定的处理。这个方法需要传入一个MaskFilter对象。但MaskFilter类中没有任何实现方法,所以我们就要认识下它的两个子类BlurMaskFilter和EmbossMaskFilter,前者为模糊遮罩滤镜而后者为浮雕遮罩滤镜。

2.BlurMaskFilter

2.1 初识

我们在之前的cardView中讲解到cardview可以设置阴影效果,我先摆出之前文章的图片。
Android:Paint的setMaskFilter(MaskFilter maskfilter)_第1张图片
使用BlurMaskFilter可以轻松实现上面的阴影效果。

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

        mPaint.setColor(Color.RED);
        // 设置画笔遮罩滤镜 ,传入度数和样式
        mPaint.setMaskFilter(new BlurMaskFilter(20, BlurMaskFilter.Blur.SOLID));
        // 画一个矩形 
        canvas.drawRect(200, 200, 600, 600, mPaint);  
    }

Android:Paint的setMaskFilter(MaskFilter maskfilter)_第2张图片

2.2 构造函数

BlurMaskFilter只有一个含参的构造函数
BlurMaskFilter(float radius, BlurMaskFilter.Blur style)
第一个参数:radius很容易理解,值越大我们的阴影越扩散,用过PS的人会很容易理解,其实就是阴影范围。
第二个参数:style表示的是模糊的类型,上面我们用到的是SOLID,其效果就是在图像的Alpha边界外产生一层与Paint颜色一致的阴影效果而不影响图像本身,除了SOLID还有三种,NORMAL,OUTER和INNER。我们来逐个看看效果:

SOLID
其效果就是在图像的Alpha边界外产生一层与Paint颜色一致的阴影效果而不影响图像本身。
Android:Paint的setMaskFilter(MaskFilter maskfilter)_第3张图片

因为阴影的颜色是从色块中取出的,也是红色的,所以你感觉不是很舒服,如果阴影是黑色的就好很多了。

NORMAL
会将整个图像模糊掉。
Android:Paint的setMaskFilter(MaskFilter maskfilter)_第4张图片

OUTER
会在Alpha边界外产生一层阴影且会将原本的图像变透明。

INNER
会在图像内部产生模糊。可以看见阴影在色块的内部,有种淡淡的浮雕感。

INNER效果其实并不理想,实际应用中我们使用的也少。

2.3 给图片添加阴影

BlurMaskFilter是根据Alpha通道的边界来计算模糊的,如果用它对图片进行处理,你会发现没有任何效果。那么我们如何给图片加一个类似阴影的效果呢?其实很简单,我们可以尝试从Bitmap中获取其Alpha通道,并在绘制Bitmap前先以该Alpha通道绘制一个模糊效果就就行了。最终效果就是阴影图片叠加到原图的下方。

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

        Bitmap srcBitmap = BitmapFactory.decodeResource(mContext.getResources(), R.drawable.kale);

        // 获取位图的Alpha通道图
        Bitmap shadowBitmap = srcBitmap.extractAlpha();

        mPaint.setColor(Color.DKGRAY);
        // 设置画笔遮罩滤镜 ,传入度数和样式
        mPaint.setMaskFilter(new BlurMaskFilter(10, BlurMaskFilter.Blur.NORMAL));

        // 先绘制阴影
        canvas.drawBitmap(shadowBitmap, 200, 200, mPaint);

        // 画原图
        canvas.drawBitmap(srcBitmap, 200, 200, null);
    }


如果你好奇,底部的阴影图片是什么样子的,我们就不绘制原图,仅仅绘制后面的阴影图片看看。
Android:Paint的setMaskFilter(MaskFilter maskfilter)_第5张图片

3.EmbossMaskFilter

3.1 初识

相对于之前的BlurMaskFilter来说,EmbossMaskFilter的可用性比较低,因为它实现的效果不是很霸气。正如其名,他可以实现一种类似浮雕的效果,说白了就是让你绘制的图像感觉像是从屏幕中“凸”起来更有立体感一样(在设计软件中类似的效果称之为斜面浮雕)。

3.2 构造函数

EmbossMaskFilter(float[] direction, float ambient, float specular, float blurRadius)
这里面的各种参数理解起来比较复杂,如果想要详细的了解可以去看:http://blog.csdn.net/aigestudio/article/details/41447349

http://blog.csdn.net/aigestudio/article/details/41447349

你可能感兴趣的:(android)