`

图片处理:圆角、倒影

阅读更多
效果图:
[img]

[/img]


这里需要的图片是手机壁纸


main.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    >
	<ImageView 
		android:id="@+id/image01" 
	    android:layout_width="wrap_content" 
	    android:layout_height="wrap_content" 
	    android:padding="10px"
	    />
	<ImageView
		android:id="@+id/image02"
		android:layout_width="wrap_content" 
	    android:layout_height="wrap_content" 
	    android:padding="10px"
	/>
</LinearLayout>



图片处理工具类:
package com.zzl.imagedemo;
import android.graphics.Bitmap;
import android.graphics.Canvas;
import android.graphics.LinearGradient;
import android.graphics.Matrix;
import android.graphics.Paint;
import android.graphics.PixelFormat;
import android.graphics.PorterDuffXfermode;
import android.graphics.Rect;
import android.graphics.RectF;
import android.graphics.Bitmap.Config;
import android.graphics.PorterDuff.Mode;
import android.graphics.Shader.TileMode;
import android.graphics.drawable.Drawable;
public class ImageUtil {
	
	//放大缩小图片
	public static Bitmap zoomBitmap(Bitmap bitmap,int w,int h){
		int width = bitmap.getWidth();
		int height = bitmap.getHeight();
		Matrix matrix = new Matrix();
		float scaleWidht = ((float)w / width);
    	float scaleHeight = ((float)h / height);
    	matrix.postScale(scaleWidht, scaleHeight);
    	Bitmap newbmp = Bitmap.createBitmap(bitmap, 0, 0, width, height, matrix, true);
		return newbmp;
	}
	//将Drawable转化为Bitmap
	 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;
	    	
	    }
	 
	 //获得圆角图片的方法
	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 int color = 0xff424242;
		final Paint paint = new Paint();
		final Rect rect = new Rect(0, 0, bitmap.getWidth(), bitmap.getHeight());
		final RectF rectF = new RectF(rect);
 
		paint.setAntiAlias(true);
		canvas.drawARGB(0, 0, 0, 0);
		paint.setColor(color);
		canvas.drawRoundRect(rectF, roundPx, roundPx, paint);
 
		paint.setXfermode(new PorterDuffXfermode(Mode.SRC_IN));
		canvas.drawBitmap(bitmap, rect, rect, paint);
 
		return output;
	}
	//获得带倒影的图片方法
	public static Bitmap createReflectionImageWithOrigin(Bitmap bitmap){
		final int reflectionGap = 4;
		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 bitmapWithReflection = Bitmap.createBitmap(width, (height + height/2), Config.ARGB_8888);
		
		Canvas canvas = new Canvas(bitmapWithReflection);
		canvas.drawBitmap(bitmap, 0, 0, null);
		Paint deafalutPaint = new Paint();
		canvas.drawRect(0, height,width,height + reflectionGap,
				deafalutPaint);
		
		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);
		// Set the Transfer mode to be porter duff and destination in
		paint.setXfermode(new PorterDuffXfermode(Mode.DST_IN));
		// Draw a rectangle using the paint with our linear gradient
		canvas.drawRect(0, height, width, bitmapWithReflection.getHeight()
				+ reflectionGap, paint);
 
		return bitmapWithReflection;
	}
	
}




Activity的调用:
package com.zzl.imagedemo;
import android.app.Activity;
import android.graphics.Bitmap;
import android.graphics.drawable.Drawable;
import android.os.Bundle;
import android.widget.ImageView;
public class Imagedemo extends Activity {
	private ImageView mImageView01,mImageView02;
	
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        setupViews();
    }
   
    private void setupViews(){
    	mImageView01 = (ImageView)findViewById(R.id.image01);
    	mImageView02 = (ImageView)findViewById(R.id.image02);
    	
    	//获取壁纸返回值是Drawable
    	Drawable drawable = getWallpaper();
    	//将Drawable转化为Bitmap
    	Bitmap bitmap = ImageUtil.drawableToBitmap(drawable);
    	//缩放图片
    	Bitmap zoomBitmap = ImageUtil.zoomBitmap(bitmap, 100, 100);
    	//获取圆角图片
    	Bitmap roundBitmap = ImageUtil.getRoundedCornerBitmap(zoomBitmap, 10.0f);
    	//获取倒影图片
    	Bitmap reflectBitmap = ImageUtil.createReflectionImageWithOrigin(zoomBitmap);
    	//这里可以让Bitmap再转化为Drawable
//    	Drawable roundDrawable = new BitmapDrawable(roundBitmap);    	
//    	Drawable reflectDrawable = new BitmapDrawable(reflectBitmap);   	
//    	mImageView01.setBackgroundDrawable(roundDrawable);
//    	mImageView02.setBackgroundDrawable(reflectDrawable);
    	    	
    	mImageView01.setImageBitmap(roundBitmap);
    	mImageView02.setImageBitmap(reflectBitmap);
    }
      
       
}
  • 大小: 16.4 KB
分享到:
评论

相关推荐

    制作圆角倒影图片比PS高手还牛!iRoundPic 傻瓜式图片处理工具

    今天给大家送上一款超实用的免费的傻瓜式图片制作工具iRoundPic,使用者不需要任何专业知识即可非常简单地做出圆角、倒影、撕边、折角、加水印、等等一系列超酷的效果!而且你还能用它制作论坛头像、PSP、手机等壁纸...

    Android图片倒影+圆角图片

    在Android开发中,图片处理是常见且重要的任务之一。这个话题涵盖了两个方面:创建图片的倒影效果和制作圆角图片。这两个特性可以用于提升应用的用户体验,使其看起来更加美观和专业。 首先,我们来讨论如何在...

    android 圆角图片+图片倒影

    在Android开发中,创建圆角图片和图片倒影是常见的需求,这主要涉及到图像处理和视图绘制的技术。本文将详细讲解如何在Android平台上实现这些功能。 首先,让我们来看看如何生成圆角图片。在Android中,我们可以...

    圆角、倒影处理及壁纸获取

    在Android应用开发中,对图像进行圆角处理和制作倒影效果是常见的需求,这能够提升界面的美观度和用户体验。本Demo就是针对这些需求提供的一种解决方案,它适用于Android 4.4.2(KitKat)及更高版本的系统。 首先,...

    图片美化工具加圆角修饰

    综上所述,这款名为“图片美化工具加圆角修饰”的软件提供了多种图片编辑功能,不仅能够实现图片的圆角处理,还支持添加水印、倒影、各种纹理效果以及光照处理。用户可以通过运行提供的程序文件进行操作,并借助帮助...

    Android图片处理效果

    为了更好地实践这些知识,你可以参考压缩包中的"实现圆角倒影"文件,它可能包含了一些示例代码或项目,供你学习和参考。通过动手实践,你会更深入地理解Android图片处理的各种技巧,并能自如地运用到自己的项目中。

    安卓系列毕设:Android图片处理合集

    今天分享一个Android的图片处理大合集:包括了 "图片缩放", "图片圆角", "图片倒影", "旋转图片", "图片反转", "图片色调饱和度、色相、亮度处理", "涂鸦,水印", "图片上写文字", "怀旧效果","模糊效果" ,"柔化效果...

    Android图片各种处理效果源码

    Android图片效果: "图片缩放", "图片圆角", "图片倒影", "旋转图片", "图片反转", "图片色调饱和度、色相、亮度处理", "涂鸦,水印", "图片上写文字", "怀旧效果", "模糊效果" ,"柔化效果(高斯模糊)", "浮雕效果...

    android Bitmap圆角与倒影的具体实现代码

    在设计用户界面时,我们可能需要对Bitmap进行各种操作,如制作圆角和倒影效果,以提升视觉体验。以下将详细介绍如何实现这两个功能。 首先,我们来看如何创建一个具有圆角的Bitmap。这个过程主要通过Canvas和Paint...

    iRoundPic圆角方角图片快速制作

    零操作多用途制作,快速自动生成圆角图片、多边形图片、为图片加水印、转换图片格式、压缩图片尺寸,全部支持批量操作。完全本地化的软件操作使用,不用上传到网络制作以避免原始图片素材的流失,保证你原始图片的...

    图片处理Demo

    这个"图片处理Demo"项目聚焦于展示如何在Android平台上对图像进行多种操作,包括放大缩小、旋转、合成、置灰、倒影、圆角、涂鸦和剪切。下面将详细介绍这些知识点: 1. **放大缩小**: Android提供了Bitmap类来...

    iRoundPic 傻瓜式图片处理工具

    1、快速制作圆角图、倒影图、阴影图、折角图、水印图 2、快速裁切图片,自动比例处理,支持手工精确选取 3、转换图片格式、优化压缩图片文件尺寸 4、为图片添加各类样式水印、及其他元素 5、快速桌面截图、应用程序...

    图片的各种效果的处理

    在Android开发中,图片处理是常见且重要的任务,特别是在用户界面设计和图像应用中。`ImageView`组件是Android系统提供用于展示图片的核心组件,而如何对其进行各种效果的处理,是开发者常常面临的问题。本篇文章将...

    bitmap图片处理工具类

    "Bitmap图片处理工具类" 提供了多种对位图(Bitmap)进行操作的功能,如颜色转换、图像分割、缩放、旋转、调整透明度、生成圆角图片以及文字与倒影效果的绘制。接下来,我们将深入探讨这些知识点。 首先,`...

    Android 图像处理(类型转换,比例缩放,倒影,圆角)的小例子

    在Android开发中,图像处理是一项常见的任务,涵盖了各种操作,如类型转换、比例缩放、创建倒影和制作圆角图像。以下是对这些知识点的详细解释: 1. **比例缩放图片**: 在Android中,可以使用`Bitmap`类提供的...

    3D 带倒影展示画廊 android

    这个Demo展示了如何在Android应用程序中创建一个具有3D视觉效果和倒影的图片展示区域,为用户带来更丰富的交互体验。 首先,核心知识点在于Android的3D渲染技术。在Android中,可以使用OpenGL ES(OpenGL for ...

    android图片处理

    在Android开发中,图片处理是一项常见的任务,涉及到各种视觉效果的实现。以下是对标题和描述中涉及的知识点的详细说明: 1. **图片缩放**:Android提供了Bitmap类的多种方法来处理图片缩放,如`createScaledBitmap...

    图片处理方法

    在IT领域,图片处理是一项非常重要的技术,广泛应用于各种应用场景,如网页设计、移动应用、图形用户界面(GUI)以及图像分析等。本篇将详细阐述标题和描述中提到的几个核心知识点,包括图片缩放、圆角处理、倒影...

    图片处理效果大全

    针对图片效果的处理整理出来的效果合集,大部分来源于网络,本人整理出来以便使用方便,包括图片缩放、图片圆角、图片倒影、图片旋转、翻转、色调饱和度、色相、亮度处理、涂鸦、水印、怀旧效果、模糊效果、弱化效果...

Global site tag (gtag.js) - Google Analytics