Bitamp生成倒影

简介: main.activity如下: package c.c; import android.os.Bundle; import android.

main.activity如下:

package c.c;
import android.os.Bundle;
import android.widget.ImageView;
import android.app.Activity;
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.PorterDuff.Mode;
import android.graphics.PorterDuffXfermode;
import android.graphics.Shader.TileMode;
/**
 * Demo:生成Bitmap的倒影
 */
public class MainActivity extends Activity {
	private ImageView mImageView;
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.main);
		mImageView=(ImageView) findViewById(R.id.imageView);
		Bitmap rawBitmap=BitmapFactory.decodeResource(getResources(), R.drawable.a);
		Bitmap newBitmap=getBitmapReflection(rawBitmap);
		mImageView.setImageBitmap(newBitmap);
	}

	private Bitmap getBitmapReflection(Bitmap rawBitmap) {
		final int gap = 4;
		int width = rawBitmap.getWidth();
		int height = rawBitmap.getHeight();
		Matrix matrix = new Matrix();
		//逆置
		matrix.preScale(1, -1);
		//倒影
		Bitmap reflectionBitmap =
		Bitmap.createBitmap(rawBitmap, 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(rawBitmap, 0, 0, null);
		Paint paint=new Paint();
		//画分界线
		canvas.drawRect(0, height, width, height + gap, paint);
		//画倒影
		canvas.drawBitmap(reflectionBitmap, 0, height + gap, null);
		//沿Y轴渐变效果
		LinearGradient shader = 
		new LinearGradient(0, rawBitmap.getHeight(), 0,
		bitmapWithReflection.getHeight() + gap, 0x70ffffff,0x00ffffff, TileMode.CLAMP);
		paint.setShader(shader);
		//因为有两层(倒影层和渐变),所以设置过渡模式
		paint.setXfermode(new PorterDuffXfermode(Mode.DST_IN));
		//画一个具有渐变效果的矩形
		canvas.drawRect(0, height, width, bitmapWithReflection.getHeight()+ gap, paint);
		return bitmapWithReflection;
	}	

}


main.xml如下:

<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=".MainActivity" >

    <ImageView
        android:id="@+id/imageView"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_centerHorizontal="true"
        android:layout_centerVertical="true"
      />

</RelativeLayout>


 

相关文章
|
8月前
|
移动开发 前端开发 HTML5
彩色大风车泡泡Canvas特效
彩色大风车泡泡Canvas特效
65 7
彩色大风车泡泡Canvas特效
|
2月前
CSS3制作的聚光灯下倒影文字选装动画特效源码
CSS3聚光灯下倒影文字特效是一段基于CSS3实现的聚光灯下带倒影的文字旋转动画效果代码,具有真实的视觉感,同时文字还会在旋转过程中显示出灯光的反射效果,很有意思,欢迎对此段代码感兴趣的朋友前来下载使用。
33 6
|
7月前
|
前端开发
css动画效果(边框流光闪烁阴影效果)
css动画效果(边框流光闪烁阴影效果)
|
XML Web App开发 编解码
Android动画之帧动画
在Android开发时,为了实现一些动态的炫酷的效果,我们常用到帧动画,View动画(补间动画)和属性动画,今天就来总结下我在使用帧动画的实现方式。
|
Web App开发 存储 移动开发
用 Canvas 实现一个太阳系动画效果
用 Canvas 实现一个太阳系动画效果
用 Canvas 实现一个太阳系动画效果
|
Android开发 内存技术
Android动画(帧动画、补间动画、属性动画)讲解
帧动画:是一种常见的动画形式(Frame By Frame),其原理是在“连续的关键帧”中分解动画动作,也就是在时间轴的每帧上逐帧绘制不同的内容,使其连续播放而成动画。 补间动画:指的是做FLASH动画时,在两个关键帧中间需要做“补间动画”,才能实现图画的运动; 属性动画:帧动画与补间动画实现了对View进行移动、缩放、旋转和淡入淡出的效果。但对于android开发师来说是不够的,同时移动、缩放、旋转和淡入淡出的效果也不再只是一种视觉上的动画效果了。所以从Android 3.0版本开始,系统给我们提供了一种全新的动画模式,属性动画(property animation)。
358 0
|
Web App开发 前端开发
文字底能玩出多少花样(五)实现渐变文字和文字倒影
文字底能玩出多少花样(五)实现渐变文字和文字倒影
154 0
文字底能玩出多少花样(五)实现渐变文字和文字倒影
|
Android开发
autojs圆形波纹和方形波纹
牙叔教程 简单易懂
147 0
百叶窗图片切换
在线演示 本地下载
983 0
3d旋转动画焦点图
在线演示 本地下载
688 0