文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

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

2022-06-06 05:45

关注

大家好,这一节给大家分享的是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编程中图片特效处理方法小结Android 图片特效处理的方法实例


阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-移动开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯