圆角矩形图片在苹果的产品中很流行,相比于普通的矩形,很多人都喜欢圆角矩形的图片,因为它避开了直角的生硬,带来更好的用户体验,下面是几个设计的例子:

下面在Android中实现将普通的矩形图片绘制成圆角矩形。首先看最终效果:

代码清单:

  1. package com.example.phototest;
  2. import android.os.Bundle;
  3. import android.app.Activity;
  4. import android.graphics.Bitmap;
  5. import android.graphics.BitmapFactory;
  6. import android.graphics.Canvas;
  7. import android.graphics.Color;
  8. import android.graphics.Paint;
  9. import android.graphics.Path;
  10. import android.graphics.PorterDuffXfermode;
  11. import android.graphics.PorterDuff;
  12. import android.graphics.RectF;
  13. import android.graphics.drawable.BitmapDrawable;
  14. import android.graphics.drawable.Drawable;
  15. import android.view.Menu;
  16. import android.widget.ImageView;
  17. public class MainActivity extends Activity {
  18. private ImageView myImageView;
  19. @Override
  20. public void onCreate(Bundle savedInstanceState) {
  21. super.onCreate(savedInstanceState);
  22. setContentView(R.layout.activity_main);
  23. myImageView=(ImageView)findViewById(R.id.imageView1);
  24. Bitmap photo = BitmapFactory.decodeResource(getResources(), R.drawable.photo1);
  25. myImageView.setImageBitmap(createFramedPhoto(500,400,photo,20));
  26. //myImageView.setImageBitmap(createStarPhoto(500,400,photo));
  27. }
  28. @Override
  29. public boolean onCreateOptionsMenu(Menu menu) {
  30. getMenuInflater().inflate(R.menu.activity_main, menu);
  31. return true;
  32. }
  33. private Bitmap createFramedPhoto(int x, int y, Bitmap image, float outerRadiusRat) {
  34. //根据源文件新建一个darwable对象
  35. Drawable imageDrawable = new BitmapDrawable(image);
  36. // 新建一个新的输出图片
  37. Bitmap output = Bitmap.createBitmap(x, y, Bitmap.Config.ARGB_8888);
  38. Canvas canvas = new Canvas(output);
  39. // 新建一个矩形
  40. RectF outerRect = new RectF(0, 0, x, y);
  41. // 产生一个红色的圆角矩形
  42. Paint paint = new Paint(Paint.ANTI_ALIAS_FLAG);
  43. paint.setColor(Color.RED);
  44. canvas.drawRoundRect(outerRect, outerRadiusRat, outerRadiusRat, paint);
  45. // 将源图片绘制到这个圆角矩形上
  46. //详解见http://lipeng88213.iteye.com/blog/1189452
  47. paint.setXfermode(new PorterDuffXfermode(PorterDuff.Mode.SRC_IN));
  48. imageDrawable.setBounds(0, 0, x, y);
  49. canvas.saveLayer(outerRect, paint, Canvas.ALL_SAVE_FLAG);
  50. imageDrawable.draw(canvas);
  51. canvas.restore();
  52. return output;
  53. }
  54. }

实现原理:通过在一个Canvas中绘制一个最终的输出形状,然后通过类似于遮罩的方式将图形显示出来,最终的图片形状就是先前绘制的图形的形状。具体起作用的函数是这个:

paint.setXfermode(new PorterDuffXfermode(PorterDuff.Mode.SRC_IN));

用来设置叠加模式的。

通过这个原理,我能就能够绘制各种各样形状的图片,比如:

代码:

  1. private Bitmap createStarPhoto(int x, int y, Bitmap image)
  2. {
  3. //根据源文件新建一个darwable对象
  4. Drawable imageDrawable = new BitmapDrawable(image);
  5. // 新建一个新的输出图片
  6. Bitmap output = Bitmap.createBitmap(x, y, Bitmap.Config.ARGB_8888);
  7. Canvas canvas = new Canvas(output);
  8. // 新建一个矩形
  9. RectF outerRect = new RectF(0, 0, x, y);
  10. Paint paint = new Paint(Paint.ANTI_ALIAS_FLAG);
  11. paint.setColor(Color.RED);
  12. Path path = new Path();
  13. //绘制三角形
  14. //path.moveTo(0, 0);
  15. //path.lineTo(320, 250);
  16. //path.lineTo(400, 0);
  17. //绘制正无边形
  18. long tmpX,tmpY;
  19. path.moveTo(200, 200);// 此点为多边形的起点
  20. for(int i=0;i<=5;i++)
  21. {
  22. tmpX =(long)(200+200*Math.sin((i*72+36)*2*Math.PI/360));
  23. tmpY =(long)(200+200*Math.cos((i*72+36)*2*Math.PI/360));
  24. path.lineTo(tmpX, tmpY);
  25. }
  26. path.close(); // 使这些点构成封闭的多边形
  27. canvas.drawPath(path, paint);
  28. //canvas.drawCircle(100, 100, 100, paint);
  29. // 将源图片绘制到这个圆角矩形上
  30. // 产生一个红色的圆角矩形
  31. paint.setXfermode(new PorterDuffXfermode(PorterDuff.Mode.SRC_IN));
  32. imageDrawable.setBounds(0, 0, x, y);
  33. canvas.saveLayer(outerRect, paint, Canvas.ALL_SAVE_FLAG);
  34. imageDrawable.draw(canvas);
  35. canvas.restore();
  36. return output;
  37. }

Android中绘制圆角矩形图片及任意形状图片的更多相关文章

  1. 在Microsoft Expression Blend 2 中绘制圆角矩形按钮

    原文:在Microsoft Expression Blend 2 中绘制圆角矩形按钮 /* 声明:转载请保留此信息:http://www.BrawDraw.com, http://www.ZPXP.c ...

  2. [BOT] 一种android中实现“圆角矩形”的方法

    内容简介 文章介绍ImageView(方法也可以应用到其它View)圆角矩形(包括圆形)的一种实现方式,四个角可以分别指定为圆角.思路是利用"Xfermode + Path"来进行 ...

  3. Android中实现圆角矩形及半透明效果。

    注:本文由Colin撰写,版权所有!转载请注明原文地址,谢谢合作! 在做Android开发时,我们为了美观,有时候需要使用圆角矩形,或半透明之类的效果,在网页设计中很容易实现.但在Android开发中 ...

  4. Delphi中绘制圆角矩形的窗体

    制作圆角矩形的窗体: 01.procedure TPortForm.FormCreate(Sender: Tobject); 02.var hr :thandle; 03.begin 04.hr:=c ...

  5. Android 自定义的圆角矩形ImageView 工具类

    上图看效果 自定义圆角矩形ImageView工具类 package com.wechaotou.utils; import android.content.Context; import androi ...

  6. 如何在html中做圆角矩形和 只有右边的"分隔线"

    这个网站满好的,可以常看看 css-matic中有几个很好的写css可视化的工具 其实做css 版式布局等都可以有工具的 推荐40个优秀的免费CSS工具 debugger正则表达式在线 其实是对(理论 ...

  7. CODESOFT中的圆角矩形的弧度该怎样设置?

      CODESOFT标签设计软件提供多种图形制作按钮,方便用户更为快捷的制作标签.其中就包括矩形,圆角矩形的快捷创建按钮.本文将介绍如何设置CODESOFT圆角矩形的弧度. 若有疑问可直接访问:htt ...

  8. canva绘制圆角矩形

    在做组态的时候,需要支持矩形圆角格式,但是因为canvas本身不带有圆角矩形,需要自行算出坐标进行绘制 方案一.统一圆角 <!DOCTYPE html> <html> < ...

  9. 解读Unity中的CG编写Shader系列四(unity中的圆角矩形shader)

    转自 http://www.itnose.net/detail/6097625.html 上篇文章中我们掌握了表面剔除和剪裁模式 这篇文章将利用这些知识实现一个简单的,但是又很常用的例子:把一张图片做 ...

随机推荐

  1. Mac 下纯lua(一)

    Lua 介绍 什么是lua - lua是一种跨平台开发脚本语言. Lua 历史 学校 University of Rio de Janeiro 国家 巴西 作者 Roberto Ierusalimsc ...

  2. A Simple Problem with Integers(100棵树状数组)

    A Simple Problem with Integers Time Limit: 5000/1500 MS (Java/Others)    Memory Limit: 32768/32768 K ...

  3. Sublime Text 添加到右键菜单 带菜单图标

    1.打开 regedit 2.找到节点 HKEY_CLASSSES_ROOT -> * -> Shell 3.右键选择新建“ 项 ” 这个项的名字将作为右键菜单的菜单名称,我用的“ Sub ...

  4. Java中使用webservice,简化开发(xfire的webservice)

    首先,使用到的jar先导入项目中, xbean-spring-2.8.jar, wsdl4j-1.6.1.jar, commons-httpclient-3.0.jar, commons-codec- ...

  5. 将整数数组按就分成2个部分,数组坐标为奇数,右边为偶数(java实现)

    方法1: 若不考虑性能: 使用一个新的数组target 遍历原数组 发现奇数则复制到target中 然后偶数 最后显示 import java.util.Arrays; public class Sp ...

  6. iOS框架介绍

    iOS框架介绍      Cocoa Touch   GameKit  实现对游戏中心的支持,让用户能够在线共享他们的游戏相关的信息  iOS设备之间蓝牙数据传输   从iOS7开始过期   局域网游 ...

  7. Java内存模型(转载)

    1. 概述 多任务和高并发是衡量一台计算机处理器的能力重要指标之一.一般衡量一个服务器性能的高低好坏,使用每秒事务处理数(Transactions Per Second,TPS)这个指标比较能说明问题 ...

  8. HNOI2004 宠物收养所 解题报告

    首先读完这题第一印象,是个裸题,很高兴.其次在打完代码之后,第二印象,很恶心,Treap的代码太长了,我今天下午敲了三遍,手都麻了. 废话不多说,正题.其实这个题不难,有几个点是很好的,首先,他的a值 ...

  9. Mysql JOIN优化。

    join性能自行百度,google 数据60w+,这里我只测试了一个limit , ) ,) AS C LEFT JOIN table2 AS B ON C.e_id=B.id; ) ,;

  10. 用户登录之cookie信息安全一二事

    大家都知道用户登陆后,用户信息一般会选择保存在cookie里面,因为cookie是保存客户端, 并且cookie可以在客户端用浏览器自由更改,这样将会造成用户cookie存在伪造的危险,从而可能使伪造 ...