Android编程中图片特效处理方法小结

 更新时间:2015年10月29日 12:24:39   作者:阳光岛主  
这篇文章主要介绍了Android编程中图片特效处理方法,实例总结了Android实现图片的转换、缩放、圆角及倒影等效果的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下

本文实例总结了Android编程中图片特效处理方法。分享给大家供大家参考,具体如下:

这里介绍的Android图片处理方法包括:

转换 -  drawable To  bitmap
缩放 -  Zoom
圆角 -  Round Corner
倒影 -  Reflected

bitmapPrcess  code:

package com.learn.games; 
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 bitmapProcess { 
  // zoom 
  public static Bitmap zoomBitmap(Bitmap bitmap, int w, int h){ 
    int width = bitmap.getWidth(); 
    int height = bitmap.getHeight(); 
    Matrix matrix = new Matrix(); 
    float scaleWidth = w/(float)width; 
    float scaleHeight = h/(float)height; 
    matrix.postScale(scaleWidth, scaleHeight); 
    Bitmap bitmap2 = Bitmap.createBitmap(bitmap, 0, 0, width, height, matrix, true); 
    return bitmap2;    
  } 
  // drawable to bitmap 
  public static Bitmap drawable2Bitmap(Drawable drawable){ 
    int width = drawable.getIntrinsicHeight(); 
    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; 
  } 
  // Round Corner Bitmap 
  public static Bitmap getRoundCornerBitmap(Bitmap bitmap, float roundPX){ 
    int width = bitmap.getWidth(); 
    int height = bitmap.getHeight(); 
    Bitmap bitmap2 = Bitmap.createBitmap(width, height, Config.ARGB_8888); 
    Canvas canvas = new Canvas(bitmap2); 
    final int color = 0xff424242; 
    final Paint paint = new Paint(); 
    final Rect rect = new Rect(0, 0, width, height); 
    final RectF rectF = new RectF(rect); 
    paint.setColor(color); 
    paint.setAntiAlias(true); 
    canvas.drawARGB(0, 0, 0, 0); 
    canvas.drawRoundRect(rectF, roundPX, roundPX, paint); 
    paint.setXfermode(new PorterDuffXfermode(Mode.SRC_IN)); 
    canvas.drawBitmap(bitmap, rect, rect, paint); 
    return bitmap2; 
  } 
  // Reflect Bitmap 
  public static Bitmap createReflectedBitmap(Bitmap bitmap){ 
    final int reflectedGap = 4; 
    int width = bitmap.getWidth(); 
    int height = bitmap.getHeight(); 
    Matrix matrix = new Matrix(); 
    matrix.preScale(1, -1); 
    Bitmap reflectedImage = Bitmap.createBitmap(bitmap, 0, height/2, width, height/2, matrix, false); 
    Bitmap reflectedBitmap = Bitmap.createBitmap(width, (height + height/2), Config.ARGB_8888); 
    Canvas canvas = new Canvas(reflectedBitmap); 
    canvas.drawBitmap(bitmap, 0, 0, null); 
    Paint defaultPaint = new Paint(); 
    canvas.drawRect(0, height, width, height + reflectedGap, defaultPaint);
    canvas.drawBitmap(reflectedImage, 0, height + reflectedGap, null); 
    Paint paint = new Paint(); 
    LinearGradient shader = new LinearGradient(0, bitmap.getHeight(), 0, 
                reflectedBitmap.getHeight() + reflectedGap, 0x70ffffff, 0x00ffffff, TileMode.CLAMP); 
    paint.setShader(shader); 
    paint.setXfermode(new PorterDuffXfermode(Mode.DST_IN)); 
    canvas.drawRect(0, height, width, reflectedBitmap.getHeight() + reflectedGap, paint); 
    return reflectedBitmap; 
  } 
}

Java Code:

package com.learn.games; 
import android.app.Activity; 
import android.graphics.Bitmap; 
import android.graphics.drawable.BitmapDrawable; 
import android.graphics.drawable.Drawable; 
import android.os.Bundle; 
import android.widget.ImageView; 
public class MyBitmapProcessActivity extends Activity { 
  private ImageView imgView1; 
  private ImageView imgView2; 
  private ImageView imgView3; 
  private ImageView imgView4; 
  /** Called when the activity is first created. */ 
  @Override 
  public void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.main); 
    drawBitmap(); 
  } 
  private void drawBitmap(){ 
    imgView1 = (ImageView)findViewById(R.id.imgView1); 
    imgView2 = (ImageView)findViewById(R.id.imgView2); 
    imgView3 = (ImageView)findViewById(R.id.imgView3); 
    imgView4 = (ImageView)findViewById(R.id.imgView4); 
    Drawable drawable = this.getWallpaper(); 
    Bitmap bitmap = bitmapProcess.drawable2Bitmap(drawable);            // drawable to bitmap 
    Bitmap zoomBitmap = bitmapProcess.zoomBitmap(bitmap, 100, 100);         // zoom  
    Bitmap roundBitmap = bitmapProcess.getRoundCornerBitmap(zoomBitmap, 10.0f);   // round corner  
    Bitmap reflectedBitmap = bitmapProcess.createReflectedBitmap(zoomBitmap);    // reflect bitmap
    // drawable to bitmap 
    imgView1.setImageBitmap(bitmap); 
    imgView2.setImageBitmap(zoomBitmap); 
    imgView3.setImageBitmap(roundBitmap); 
    imgView4.setImageBitmap(reflectedBitmap); 
    // bitmap to drawable 
    Drawable roundDrawable = new BitmapDrawable(roundBitmap); 
    Drawable reflectedDrawable = new BitmapDrawable(reflectedBitmap); 
    imgView1.setBackgroundDrawable(roundDrawable); 
    imgView2.setBackgroundDrawable(reflectedDrawable); 
  } 
}

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/imgView1" 
    android:layout_width="wrap_content"  
    android:layout_height="wrap_content"/> 
  <ImageView android:id="@+id/imgView2" 
    android:layout_width="wrap_content"  
    android:layout_height="wrap_content"/> 
  <ImageView android:id="@+id/imgView3" 
    android:layout_width="wrap_content"  
    android:layout_height="wrap_content"/> 
  <ImageView android:id="@+id/imgView4" 
    android:layout_width="wrap_content"  
    android:layout_height="wrap_content"/> 
</LinearLayout>

效果图:

drawable2bitmap

zoom

round corner

reflected bitmap

希望本文所述对大家Android程序设计有所帮助。

相关文章

  • android实现滚动文本效果

    android实现滚动文本效果

    这篇文章主要为大家详细介绍了android实现滚动文本效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-05-05
  • Android使用HBuilder的缓存方法

    Android使用HBuilder的缓存方法

    这篇文章主要介绍了Android使用HBuilder的缓存方法 ,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2018-12-12
  • 实例解析Android ImageView的scaleType属性

    实例解析Android ImageView的scaleType属性

    通过本文给大家介绍ImageView这个控件的一些使用方法,以及其最重要的一个属性: scaleType,对imageview的scaletype相关知识感兴趣的朋友一起学习吧
    2016-01-01
  • Android中NavigationView的使用与相关问题解决

    Android中NavigationView的使用与相关问题解决

    大家都知道NavigationView的引入让 Android侧边栏实现起来相当方便,最近公司项目中也使用这个新的控件完成了侧边栏的改版。在使用过程中遇到一些问题所以记录一下。本文分为两个部分,一是基本使用,二是相关问题的解决,感兴趣的朋友们下面来一起看看吧。
    2016-10-10
  • Android开发悬浮窗踩坑解决

    Android开发悬浮窗踩坑解决

    这篇文章主要为大家介绍了Android悬浮窗踩坑解决示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-03-03
  • android利用ContentResolver访问者获取手机联系人信息

    android利用ContentResolver访问者获取手机联系人信息

    这篇文章主要介绍了android利用ContentResolver访问者获取手机联系人信息,非常具有实用价值,需要的朋友可以参考下。
    2017-02-02
  • 详解Android 传感器开发 完全解析

    详解Android 传感器开发 完全解析

    对于传感器的使用,不同版本的Android手机也许存在较大的硬件差异,本篇文章主要介绍了Android 传感器开发,有兴趣的可以了解一下。
    2016-12-12
  • Android开发中用Kotlin编写LiveData组件教程

    Android开发中用Kotlin编写LiveData组件教程

    LiveData是Jetpack组件的一部分,更多的时候是搭配ViewModel来使用,相对于Observable,LiveData的最大优势是其具有生命感知的,换句话说,LiveData可以保证只有在组件( Activity、Fragment、Service)处于活动生命周期状态的时候才会更新数据
    2022-12-12
  • Android入门教程之ListView的应用示例

    Android入门教程之ListView的应用示例

    这篇文章主要介绍了Android入门教程之ListView的应用,结合简单实例形式分析了Android中listview的简单创建与使用步骤,需要的朋友可以参考下
    2016-10-10
  • Android使用AlertDialog创建对话框

    Android使用AlertDialog创建对话框

    这篇文章主要为大家详细介绍了Android使用AlertDialog创建对话框的方法料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-12-12

最新评论