Android高手进阶教程(二十二)之Android中几种图像特效处理的集锦汇总!!

 更新时间:2016年11月19日 17:05:46   作者:Android_Tutor  
本篇文章主要介绍了Android中几种图像特效处理,比如圆角,倒影,还有就是图片缩放,Drawable转化为Bitmap,Bitmap转化为Drawable等,有需要的可以了解一下。

大家好,这一节给大家分享的是Android中几种图像特效处理的小技巧,比如圆角,倒影,还有就是图片缩放,Drawable转化为Bitmap,Bitmap转化为Drawable等等.

废话少说了,直接讲解今天的实例,本例主要是先获取壁纸(getWallpaper()),然后对当前壁纸的一些特效处理.大家按步骤一步一步来:

第一步:新建一个Android工程命名为ImageDemo,工程结构如下:

第二步:新建一个.Java文件,命名为ImageUtil.java,在里面定义一些图片处理方法,代码如下:

package com.android.tutor; 
import androidgraphicsBitmap; 
import androidgraphicsCanvas; 
import androidgraphicsLinearGradient; 
import androidgraphicsMatrix; 
import androidgraphicsPaint; 
import androidgraphicsPixelFormat; 
import androidgraphicsPorterDuffXfermode; 
import androidgraphicsRect; 
import androidgraphicsRectF; 
import androidgraphicsBitmapConfig; 
import androidgraphicsPorterDuffMode; 
import androidgraphicsShaderTileMode; 
import androidgraphicsdrawableDrawable; 
public class ImageUtil { 
   
  //放大缩小图片 
  public static Bitmap zoomBitmap(Bitmap bitmap,int w,int h){ 
    int width = bitmapgetWidth(); 
    int height = bitmapgetHeight(); 
    Matrix matrix = new Matrix(); 
    float scaleWidht = ((float)w / width); 
    float scaleHeight = ((float)h / height); 
    matrixpostScale(scaleWidht, scaleHeight); 
    Bitmap newbmp = BitmapcreateBitmap(bitmap, 0, 0, width, height, matrix, true); 
    return newbmp; 
  } 
  //将Drawable转化为Bitmap 
   public static Bitmap drawableToBitmap(Drawable drawable){ 
      int width = drawablegetIntrinsicWidth(); 
      int height = drawablegetIntrinsicHeight(); 
      Bitmap bitmap = BitmapcreateBitmap(width, height, 
          drawablegetOpacity() != PixelFormatOPAQUE ? BitmapConfigARGB_8888 
              : BitmapConfigRGB_565); 
      Canvas canvas = new Canvas(bitmap); 
      drawablesetBounds(0,0,width,height); 
      drawabledraw(canvas); 
      return bitmap; 
       
    } 
    
   //获得圆角图片的方法 
  public static Bitmap getRoundedCornerBitmap(Bitmap bitmap,float roundPx){ 
     
    Bitmap output = BitmapcreateBitmap(bitmapgetWidth(), bitmap 
        getHeight(), ConfigARGB_8888); 
    Canvas canvas = new Canvas(output); 
  
    final int color = 0xff424242; 
    final Paint paint = new Paint(); 
    final Rect rect = new Rect(0, 0, bitmapgetWidth(), bitmapgetHeight()); 
    final RectF rectF = new RectF(rect); 
  
    paintsetAntiAlias(true); 
    canvasdrawARGB(0, 0, 0, 0); 
    paintsetColor(color); 
    canvasdrawRoundRect(rectF, roundPx, roundPx, paint); 
  
    paintsetXfermode(new PorterDuffXfermode(ModeSRC_IN)); 
    canvasdrawBitmap(bitmap, rect, rect, paint); 
  
    return output; 
  } 
  //获得带倒影的图片方法 
  public static Bitmap createReflectionImageWithOrigin(Bitmap bitmap){ 
    final int reflectionGap = 4; 
    int width = bitmapgetWidth(); 
    int height = bitmapgetHeight(); 
     
    Matrix matrix = new Matrix(); 
    matrixpreScale(1, -1); 
     
    Bitmap reflectionImage = BitmapcreateBitmap(bitmap,  
        0, height/2, width, height/2, matrix, false); 
     
    Bitmap bitmapWithReflection = BitmapcreateBitmap(width, (height + height/2), ConfigARGB_8888); 
     
    Canvas canvas = new Canvas(bitmapWithReflection); 
    canvasdrawBitmap(bitmap, 0, 0, null); 
    Paint deafalutPaint = new Paint(); 
    canvasdrawRect(0, height,width,height + reflectionGap, 
        deafalutPaint); 
     
    canvasdrawBitmap(reflectionImage, 0, height + reflectionGap, null); 
     
    Paint paint = new Paint(); 
    LinearGradient shader = new LinearGradient(0, 
        bitmapgetHeight(), 0, bitmapWithReflectiongetHeight() 
        + reflectionGap, 0x70ffffff, 0x00ffffff, TileModeCLAMP); 
    paintsetShader(shader); 
    // Set the Transfer mode to be porter duff and destination in 
    paintsetXfermode(new PorterDuffXfermode(ModeDST_IN)); 
    // Draw a rectangle using the paint with our linear gradient 
    canvasdrawRect(0, height, width, bitmapWithReflectiongetHeight() 
        + reflectionGap, paint); 
  
    return bitmapWithReflection; 
  } 
   
} 

第三步:修改main.xml布局文件,主要放了两个ImageView控件,代码如下:

<?xml version="0" encoding="utf-8"?> 
<LinearLayout xmlns:android="http://schemasandroidcom/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> 


第四步:修改主核心程序,ImageDemo.java,代码如下:

package comandroidtutor; 
import androidappActivity; 
import androidgraphicsBitmap; 
import androidgraphicsdrawableDrawable; 
import androidosBundle; 
import androidwidgetImageView; 
public class Imagedemo extends Activity { 
  private ImageView mImageView01,mImageView02; 
   
  public void onCreate(Bundle savedInstanceState) { 
    superonCreate(savedInstanceState); 
    setContentView(Rlayoutmain); 
    setupViews(); 
  } 
   
  private void setupViews(){ 
    mImageView01 = (ImageView)findViewById(Ridimage01); 
    mImageView02 = (ImageView)findViewById(Ridimage02); 
     
    //获取壁纸返回值是Drawable 
    Drawable drawable = getWallpaper(); 
    //将Drawable转化为Bitmap 
    Bitmap bitmap = ImageUtildrawableToBitmap(drawable); 
    //缩放图片 
    Bitmap zoomBitmap = ImageUtilzoomBitmap(bitmap, 100, 100); 
    //获取圆角图片 
    Bitmap roundBitmap = ImageUtilgetRoundedCornerBitmap(zoomBitmap, 0f); 
    //获取倒影图片 
    Bitmap reflectBitmap = ImageUtilcreateReflectionImageWithOrigin(zoomBitmap); 
    //这里可以让Bitmap再转化为Drawable 
//   Drawable roundDrawable = new BitmapDrawable(roundBitmap);     
//   Drawable reflectDrawable = new BitmapDrawable(reflectBitmap);     
//   mImageViewsetBackgroundDrawable(roundDrawable); 
//   mImageViewsetBackgroundDrawable(reflectDrawable); 
         
    mImageViewsetImageBitmap(roundBitmap); 
    mImageViewsetImageBitmap(reflectBitmap); 
  } 
    
     
} 

第五步:运行上述工程,查看效果如下:

OK大功告成了!!

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • Android Studio实现简易计算器(表格布局TableLayout)

    Android Studio实现简易计算器(表格布局TableLayout)

    这篇文章主要为大家详细介绍了Android Studio实现简易计算器,表格布局TableLayout,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-03-03
  • Android Scroller的使用方法

    Android Scroller的使用方法

    这篇文章主要为大家详细介绍了Android Scroller的使用方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-05-05
  • Android实现广告图片轮播效果

    Android实现广告图片轮播效果

    这篇文章主要为大家详细介绍了Android实现广告图片轮播效果的相关资料,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-02-02
  • Android studio 三大模拟器比较(图文详解)

    Android studio 三大模拟器比较(图文详解)

    这篇文章主要介绍了Android studio 三大模拟器比较,本文图文并茂给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-03-03
  • Android巧用ActionBar实现tab导航效果

    Android巧用ActionBar实现tab导航效果

    这篇文章主要为大家详细介绍了Android巧用ActionBar实现tab导航效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-05-05
  • Android实现悬浮图片

    Android实现悬浮图片

    这篇文章主要为大家详细介绍了Android实现悬浮图片,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-09-09
  • Android Flutter绘制扇形图详解

    Android Flutter绘制扇形图详解

    在开发过程中通常会遇到一些不规则的UI,比如不规则的线条,多边形,统计图表等等,用那些通用组件通过组合的方式无法进行实现,这就需要我们自己进行绘制。本文将利用Flutter绘制扇形图,感兴趣的可以学习一下
    2022-05-05
  • Android Studio中通过CMake使用NDK并编译自定义库和添加预编译库

    Android Studio中通过CMake使用NDK并编译自定义库和添加预编译库

    这篇文章是基于Android Studio 3.01版本的,NDK是R16。本文重点给大家介绍Android Studio中通过CMake使用NDK并编译自定义库和添加预编译库的相关知识,感兴趣的朋友一起看看吧
    2018-01-01
  • Android截屏方案实现原理解析

    Android截屏方案实现原理解析

    这篇文章给大家介绍了Android截屏方案实现原理解析,包括普通截屏,Scrollview截屏,Scrollview截屏,RecyclerView截屏等,具体截屏实现原理,大家参考下本文
    2017-12-12
  • Android自定义ListView实现仿QQ可拖拽列表功能

    Android自定义ListView实现仿QQ可拖拽列表功能

    这篇文章主要介绍了Android自定义ListView实现仿QQ可拖拽列表功能,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2016-08-08

最新评论