效果图:
原理
首先说一下原理,这是一张图片A,然后通过拷贝成图片B,再把B翻转,翻转后再设置B+一个渐变色的混合,实现渐变。
代码
布局文件
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context="com.example.customview.ReflectActivity" >
<com.example.customview.ReflectView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerInParent="true" />
</RelativeLayout>
编码
package com.example.customview;
import android.content.Context;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.graphics.Canvas;
import android.graphics.LinearGradient;
import android.graphics.Matrix;
import android.graphics.Paint;
import android.graphics.Shader.TileMode;
import android.util.AttributeSet;
import android.view.View;
public class ReflectView extends View {
private Bitmap mBitmap;
private Bitmap mRefBitmap;
public ReflectView(Context context, AttributeSet attrs, int defStyleAttr) {
super(context, attrs, defStyleAttr);
}
public ReflectView(Context context) {
super(context, null);
}
public ReflectView(Context context, AttributeSet attrs) {
super(context, attrs, 0);
mBitmap = BitmapFactory.decodeResource(getResources(), R.drawable.jpg);
/**
* 这是上面的那张图片A
*/
Matrix matrix = new Matrix();
matrix.setScale(1f, -1f);
/**
* 使图片上下翻转的矩阵运算
*/
mRefBitmap = Bitmap.createBitmap(mBitmap, 0, 0, mBitmap.getWidth(), mBitmap.getHeight(), matrix, true);
/**
* 拷贝图片A并翻转
*/
Paint paint = new Paint();
LinearGradient linearGradient = new LinearGradient(0, 0, 0, mBitmap.getHeight() / 4, 0X00000000, 0XFF000000,
TileMode.CLAMP);
paint.setShader(linearGradient);
/**
* 这是使图片B渐变的渲染器 让颜色从透明-->黑色
*/
Canvas canvas = new Canvas(mRefBitmap);
canvas.drawRect(0, 0, mBitmap.getWidth(), mBitmap.getHeight() / 4, paint);
/**
* 然后开始在mRefBitmap上画出渐变效果
*/
}
@Override
protected void onDraw(Canvas canvas) {
super.onDraw(canvas);
canvas.clipRect(0, 0, mBitmap.getWidth(), mBitmap.getHeight() + mBitmap.getHeight() / 4);
/**
* 只在有效区域(宽度为图片宽度,高度为图片高度+倒影的高度)内作画,其他超出有效区域的裁剪掉
*/
/**
* 最后把两张图片拼接
*/
canvas.drawBitmap(mBitmap, 0, 0, null);
canvas.drawBitmap(mRefBitmap, 0, mBitmap.getHeight(), null);
}
}