ImageView倒影效果的两种方法
第一种:
写个图片的工具类,在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对象
image = (ImageView) findViewById(R.id.movie);
然后将获取到的Imageview对象转化为Bitmap类型
Bitmap imageBit = ((BitmapDrawable) image.getDrawable()).getBitmap();
接着调用图片工具类中的方法,返回一个Bitmap对象,将这个Bitmap对象放置在ImageView中
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:id="@+id/imageView3"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@+drawable/button1" />
其中
com.hello.ReflectImageView
是继承类的完整包名
分享到:
相关推荐
该项目可能包含了自定义的View类,扩展了View或ImageView,实现了倒影效果的绘制逻辑。开发者可以通过查看源码,学习如何将这些步骤集成到实际应用中。 总之,Android动态倒影效果的实现依赖于矩阵变换技术,通过对...
在Android开发中,实现图片的3D效果及倒影效果是一项常见的需求,这可以为用户带来更丰富的视觉体验。在本教程中,我们将探讨如何在Android应用中创建这些特效,特别是针对`Gallery`组件的使用。 首先,让我们了解`...
- 另外,还可以使用第三方库如`android-reflection-imageview`来简化倒影效果的实现。 2. **滑动翻转效果**: - 滑动翻转特效是指在用户滑动`Gallery`时,当前显示的图片进行3D翻转动画,以过渡到下一个或上一个...
4. **显示到界面上**:将处理好的带倒影的图片设置给自定义的ImageView或者自定义的ViewGroup,如RelativeLayout,然后在`Gallery`中添加这个ViewGroup,使得用户在切换图片时可以看到倒影效果。 5. **自定义...
6. **显示到视图**: 最后,将组合后的Bitmap设置到ImageView或其他自定义View中,以在界面上显示图片倒影效果。 在"ImageShadow"项目或类中,可能会包含一个自定义的ImageView子类,扩展了ImageView的功能,以支持...
在Android开发中,实现图片的倒影效果是一种常见的视觉增强技术,可以为用户界面增添动态感和美感。本文将深入探讨如何在Android中创建图片倒影,并提供完整的源代码示例。 首先,我们需要理解倒影效果的基本原理。...
在Android开发中,实现图片倒影效果是一种常见的视觉设计需求,可以增强用户界面的美观性和动态感。这个压缩包文件提供了实现图片倒影效果的源码示例,可以帮助开发者理解和学习如何在Android应用中创建此类效果。...
本篇将详细讲解`Gallery`实现的小demo中的倒影效果和滑动翻转功能。 首先,`Gallery`是一个基于`AbsSpinner`的视图,它提供了水平方向上的滚动行为。开发者可以通过设置`Adapter`来填充`Gallery`的内容,每个`...
图片倒影效果则可能需要结合自定义`View`或`ImageView`来实现。开发者可以通过在原始图片下方绘制一个翻转的图片,然后调整其位置和透明度,以达到倒影效果。在Android中,可以使用`Matrix`类进行图像的旋转和翻转...
在Android开发中,实现倒影效果是一种常见的视觉增强技术,特别是在设计美观的用户界面时。本文将详细探讨如何在Android Studio项目中实现图片的倒影效果。 首先,我们需要理解倒影效果的基本概念。倒影是图像的一...
在Android开发中,图片倒影效果是一种常见的视觉设计,它能为应用增添一些动态和美感。这个"Android 图片倒影效果源码.rar"压缩包很可能是包含了一个实现这一功能的示例项目或者库。接下来,我们将深入探讨如何在...
首先,Android 3D倒影效果通常通过自定义View来实现,这个自定义View需要继承自Android的`View`或者`ImageView`类。在这个过程中,我们需要覆盖`onDraw()`方法,这是Android绘制图形的核心方法。在这里,我们将进行...
- **MainActivity**:这是主活动类,通常会包含一个ImageView,用于显示带有倒影效果的图片。在`onCreate()`方法中,会调用`ReflectionUtils`来处理图片,并将结果设置给ImageView。 - **XML布局文件**:定义了界面...
在Android开发中,图片倒影效果是一种常见的视觉设计,它能为应用增添动态感和立体感。本资源“Android图片倒影效果源码.zip”提供了一种实现Android平台上图片倒影效果的方法。以下是对这个源码实现的详细解析: 1...
在Android开发中,实现3D倒影效果是一个增强用户界面视觉体验的重要技术。这个压缩包文件"Android源码——3D倒影效果源码_new_01.zip"包含了一个示例项目,展示了如何在Android应用中创建逼真的3D倒影效果。下面将...
在安卓(Android)开发中,实现图片倒影效果是一种常见的视觉设计手法,它可以为应用界面增添动态和美感。本资源包含了一个实现图片倒影效果的源码示例,旨在帮助开发者理解和掌握这一技术。下面将详细讲解这个源码...
在Android开发中,实现图片倒影效果是一种常见的需求,例如在设计美观的用户界面或创建动态特效时。本文将深入探讨如何通过源码实现这一功能,以"Android应用源码之图片倒影效果源码.zip"为例进行讲解。 首先,我们...