Android   发布时间:2022-04-28  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了如何利用matrix实现图片倒影效果大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

本文主要内容就是用marix加上渐变色实现图片倒影的效果,步骤如下:

 1. 获取需要倒影效果图片,这里取原图片的一半

 2. 添加颜色渐变到倒影图片

 具体的实现如下面代码所述,我们以一种自定义view的形式给出效果图,代码如下:

@H_673_9@ package com.flection.view; import com.flection.main.R; import android.Annotation.SuppressLint; import android.content.Context; import android.graphics.bitmap; import android.graphics.bitmap.Config; import android.graphics.bitmapFactory; import android.graphics.Canvas; import android.graphics.Color; import android.graphics.LinearGradient; import android.graphics.Matrix; import android.graphics.Paint; import android.graphics.PorterDuffXfermode; import android.graphics.Shader.TileMode; import android.graphics.drawable.bitmapDrawable; import android.util.AttributeSet; import android.view.View; public class FlectionView extends View { Context mContext=null; public FlectionView(Context context) { super(context); } public FlectionView(Context context,AttributeSet attrs) { super(context,attrs); this.mContext=context; } @SuppressLint("DrawAlLOCATIOn") @Override protected void onDraw(Canvas canvas) { //设置背景色 this.setBACkgroundColor(Color.parseColor("#8B8378")); Bitmap oldBitmap = BitmapFactory.decoderesource(mContext.getresources(),R.drawable.dropBox); Bitmap newBitmap = createFlectionBitmap(oldBitmap); canvas.drawBitmap(newBitmap,newBitmap.getWidth(),newBitmap.getHeight(),new Paint()); this.invalidate(); } //获取原图+倒影图的bitmap private Bitmap createFlectionBitmap(Bitmap oldBitmap) { int mWidth = oldBitmap.getWidth(); int mHeight = oldBitmap.getHeight(); //原图和倒影图之间的缝隙 int gap = 2; Matrix matrix = new Matrix(); matrix.preScale(1,-1); Bitmap flection = Bitmap.createBitmap(oldBitmap,mHeight / 2,mWidth,matrix,falsE); Bitmap BACkground = Bitmap.createBitmap(mWidth,mHeight+gap+mHeight/2,Config.ARGB_8888); Canvas canvas = new Canvas(BACkground); Paint p1 = new Paint(); //画出原图 canvas.drawBitmap(oldBitmap,p1); //画出倒影图 canvas.drawBitmap(flection,mHeight+gap,p1); Paint shaderPaint = new Paint(); LinearGradient shader = new LinearGradient(0,mHeight,flection.getHeight(),0x70ffffff,0x00ffffff,TileMode.MIRROR); shaderPaint.setShader(shader); shaderPaint.setXfermode(new PorterDuffXfermode(android.graphics.PorterDuff.Mode.DST_IN)); //画出渐变颜色 canvas.drawRect(0,BACkground.getHeight(),shaderPaint); return BACkground; } }

实现的效果如下图:

如何利用matrix实现图片倒影效果

以上就是本文的全部内容,希望能给大家一个,也希望大家多多支持编程小技巧。

大佬总结

以上是大佬教程为你收集整理的如何利用matrix实现图片倒影效果全部内容,希望文章能够帮你解决如何利用matrix实现图片倒影效果所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。