ImageView倒影效果的兩種方法
https://lws0402.iteye.com/blog/1397793
第一種:
寫個圖片的工具類,在Activity中用java代碼調用ImageView組件的setImageBitmap(Bitmap bitmap)方法。
下麵是圖片工具類:
import android.graphics.Bitmap; import android.graphics.Bitmap.Config; import android.graphics.BitmapFactory; import android.graphics.Canvas; import android.graphics.LinearGradient; import android.graphics.Matrix; import android.graphics.Paint; import android.graphics.PixelFormat; import android.graphics.PorterDuff.Mode; import android.graphics.PorterDuffXfermode; import android.graphics.Rect; import android.graphics.RectF; import android.graphics.Shader.TileMode; import android.graphics.drawable.Drawable; public class ImageUtils { /** * 從SDCard上讀取圖片 * @param pathName * @return */ public static Bitmap getBitmapFromSDCard(String pathName) { return BitmapFactory.decodeFile(pathName); } /** * 縮放圖片 * @param bitmap * @param width * @param height * @return */ public static Bitmap zoomBitmap(Bitmap bitmap, int width, int height) { int w = bitmap.getWidth(); int h = bitmap.getHeight(); Matrix matrix = new Matrix(); matrix.postScale((float) width / w, (float) height / h); return Bitmap.createBitmap(bitmap, 0, 0, w, h, matrix, true); } /** * 將Drawable轉化為Bitmap * @param drawable * @return */ public static Bitmap drawableToBitmap(Drawable drawable) { int width = drawable.getIntrinsicWidth(); int height = drawable.getIntrinsicHeight(); Bitmap bitmap = Bitmap.createBitmap(width, height, drawable .getOpacity() != PixelFormat.OPAQUE ? Bitmap.Config.ARGB_8888 : Bitmap.Config.RGB_565); Canvas canvas = new Canvas(bitmap); drawable.setBounds(0, 0, width, height); drawable.draw(canvas); return bitmap; } /** * 獲得圓角圖片 * @param bitmap * @param roundPx * @return */ public static Bitmap getRoundedCornerBitmap(Bitmap bitmap, float roundPx) { Bitmap output = Bitmap.createBitmap(bitmap.getWidth(), bitmap .getHeight(), Config.ARGB_8888); Canvas canvas = new Canvas(output); final Paint paint = new Paint(); final Rect rect = new Rect(0, 0, bitmap.getWidth(), bitmap.getHeight()); final RectF rectF = new RectF(rect); canvas.drawRoundRect(rectF, roundPx, roundPx, paint); paint.setXfermode(new PorterDuffXfermode(Mode.SRC_IN)); canvas.drawBitmap(bitmap, rect, rect, paint); return output; } /** * 獲得帶倒影的圖片 * @param bitmap * @return */ public static Bitmap getReflectionImageWithOrigin(Bitmap bitmap) { // 原始圖片和反射圖片中間的間距 final int reflectionGap = 0; int width = bitmap.getWidth(); int height = bitmap.getHeight(); // 反轉 Matrix matrix = new Matrix(); // 第一個參數為1表示x方向上以原比例為準保持不變,正數表示方向不變。 // 第二個參數為-1表示y方向上以原比例為準保持不變,負數表示方向取反。 matrix.preScale(1, -1); Bitmap reflectionImage = Bitmap.createBitmap(bitmap, 0, height / 2, width, height / 2, matrix, false); Bitmap bitmapWithReflection = Bitmap.createBitmap(width, (height + height / 2), Config.ARGB_8888); Canvas canvas = new Canvas(bitmapWithReflection); canvas.drawBitmap(bitmap, 0, 0, null); Paint defaultPaint = new Paint(); canvas.drawRect(0, height, width, height + reflectionGap, defaultPaint); canvas.drawBitmap(reflectionImage, 0, height + reflectionGap, null); Paint paint = new Paint(); LinearGradient shader = new LinearGradient(0, bitmap.getHeight(), 0, bitmapWithReflection.getHeight() + reflectionGap, 0x70ffffff, 0x00ffffff, TileMode.CLAMP); paint.setShader(shader); paint.setXfermode(new PorterDuffXfermode(Mode.DST_IN)); canvas.drawRect(0, height, width, bitmapWithReflection.getHeight() + reflectionGap, paint); return bitmapWithReflection; } }
在Activity中這樣調用,先獲取XML文件中定義的Imageview對象
Java代碼
- image = (ImageView) findViewById(R.id.movie);
image = (ImageView) findViewById(R.id.movie);
然後將獲取到的Imageview對象轉化為Bitmap類型
Java代碼
- Bitmap imageBit = ((BitmapDrawable) image.getDrawable()).getBitmap();
Bitmap imageBit = ((BitmapDrawable) image.getDrawable()).getBitmap();
接著調用圖片工具類中的方法,返回一個Bitmap對象,將這個Bitmap對象放置在ImageView中
Java代碼
- Bitmap m = ImageUtils.getReflectionImageWithOrigin(imageBit);
- image.setImageBitmap(m);
繼承ImageView類
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.PorterDuffXfermode; import android.graphics.Bitmap.Config; import android.graphics.PorterDuff.Mode; import android.graphics.Shader.TileMode; import android.graphics.drawable.BitmapDrawable; import android.util.AttributeSet; import android.widget.ImageView; public class ReflectImageView extends ImageView { private Bitmap originalBitmap; public ReflectImageView(Context context, AttributeSet attrs) { this(context, attrs, 0); } public ReflectImageView(Context context) { this(context, null, 0); } public ReflectImageView(Context context, AttributeSet attrs, int defStyle) { super(context, attrs, defStyle); DoReflection(((BitmapDrawable) getDrawable()).getBitmap()); } @Override public void setImageBitmap(Bitmap bm) { DoReflection(bm); } /** 顯示倒影效果的setImageBitmap函數 */ public void setImageBitmap(Bitmap bm, boolean isFlected) { if (isFlected) { super.setImageBitmap(bm); } } @Override public void setImageResource(int resId) { originalBitmap = BitmapFactory.decodeResource(getResources(), resId); DoReflection(originalBitmap); } private void DoReflection(Bitmap bitmap) { final int reflectionGap = 0; int width = bitmap.getWidth(); int height = bitmap.getHeight(); Matrix matrix = new Matrix(); matrix.preScale(1, -1); Bitmap reflectionImage = Bitmap.createBitmap(bitmap, 0, height / 2, width, height / 2, matrix, false); Bitmap bitmap4Reflection = Bitmap.createBitmap(width, (height + height / 2), Config.ARGB_8888); Canvas canvasRef = new Canvas(bitmap4Reflection); Paint deafaultPaint = new Paint(); deafaultPaint.setAntiAlias(true); canvasRef.drawBitmap(bitmap, 0, 0, null); canvasRef.drawRect(0, height, width, height + reflectionGap, deafaultPaint); canvasRef.drawBitmap(reflectionImage, 0, height + reflectionGap, null); Paint paint = new Paint(); LinearGradient shader = new LinearGradient(0, bitmap.getHeight(), 0, bitmap4Reflection.getHeight() + reflectionGap, 0x70ffffff, 0x00ffffff, TileMode.CLAMP); paint.setShader(shader); paint.setXfermode(new PorterDuffXfermode(Mode.DST_IN)); canvasRef.drawRect(0, height, width, bitmap4Reflection.getHeight() + reflectionGap, paint); this.setImageBitmap(bitmap4Reflection, true); } }
然後在xml文件裏麵配置
<com.hello.ReflectImageView
android:
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@+drawable/button1" />
最後更新:2017-04-02 17:28:39