在Android中绘制圆角矩形图片
2014-07-26 17:53
435 查看
http://blog.chinaunix.net/uid-20771867-id-3260250.html
圆角矩形图片在苹果的产品中很流行,相比于普通的矩形,很多人都喜欢圆角矩形的图片,下面在Android中实现将普通的矩形图片绘制成圆角矩形。
先来看一下普通矩形图片的显示,代码很简单,从resource中将图片取出来直接拿来用:
点击(此处)折叠或打开
public class PhotoTestActivity
extends Activity
{
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
ImageView
image = (ImageView)findViewById(R.id.image);
Bitmap photo = BitmapFactory.decodeResource(getResources(),
R.drawable.test);
image.setImageBitmap(photo);
}
}
显示结果如下图:
![](http://blog.chinaunix.net/attachment/201207/2/20771867_1341199998aiA2.png)
四个角是直角的图片是不是看起来不那么舒服呢?下面将直角转换为圆角:
点击(此处)折叠或打开
public class PhotoTestActivity
extends Activity
{
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
ImageView
image = (ImageView)findViewById(R.id.image);
Bitmap photo = BitmapFactory.decodeResource(getResources(),
R.drawable.test);
image.setImageBitmap(createFramedPhoto(500,400,photo,50));
}
/**
*
* @param x 图像的宽度
* @param y 图像的高度
* @param image 源图片
* @param outerRadiusRat 圆角的大小
* @return 圆角图片
*/
Bitmap createFramedPhoto(int x,
int y, Bitmap
image,
float outerRadiusRat)
{
//根据源文件新建一个darwable对象
Drawable imageDrawable =
new BitmapDrawable(image);
// 新建一个新的输出图片
Bitmap output
= Bitmap.createBitmap(x, y, Bitmap.Config.ARGB_8888);
Canvas
canvas = new
Canvas(output);
// 新建一个矩形
RectF outerRect =
new RectF(0, 0, x, y);
// 产生一个红色的圆角矩形
Paint
paint = new
Paint(Paint.ANTI_ALIAS_FLAG);
paint.setColor(Color.RED);
canvas.drawRoundRect(outerRect, outerRadiusRat,
outerRadiusRat, paint);
// 将源图片绘制到这个圆角矩形上
paint.setXfermode(new PorterDuffXfermode(PorterDuff.Mode.SRC_IN));
imageDrawable.setBounds(0, 0, x, y);
canvas.saveLayer(outerRect,
paint,
Canvas.ALL_SAVE_FLAG);
imageDrawable.draw(canvas);
canvas.restore();
return
output;
}
}
方法的原理就是先创建出一个圆角矩形的图片,然后将我们原来的图片作为上面的一层覆盖在这个圆角矩形上,并且使用该圆角图片的形状。ok,看看结果吧,是不是看起来好多了?
![](http://blog.chinaunix.net/attachment/201207/2/20771867_1341200361SzNY.png)
圆角矩形图片在苹果的产品中很流行,相比于普通的矩形,很多人都喜欢圆角矩形的图片,下面在Android中实现将普通的矩形图片绘制成圆角矩形。
先来看一下普通矩形图片的显示,代码很简单,从resource中将图片取出来直接拿来用:
点击(此处)折叠或打开
public class PhotoTestActivity
extends Activity
{
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
ImageView
image = (ImageView)findViewById(R.id.image);
Bitmap photo = BitmapFactory.decodeResource(getResources(),
R.drawable.test);
image.setImageBitmap(photo);
}
}
显示结果如下图:
![](http://blog.chinaunix.net/attachment/201207/2/20771867_1341199998aiA2.png)
四个角是直角的图片是不是看起来不那么舒服呢?下面将直角转换为圆角:
点击(此处)折叠或打开
public class PhotoTestActivity
extends Activity
{
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
ImageView
image = (ImageView)findViewById(R.id.image);
Bitmap photo = BitmapFactory.decodeResource(getResources(),
R.drawable.test);
image.setImageBitmap(createFramedPhoto(500,400,photo,50));
}
/**
*
* @param x 图像的宽度
* @param y 图像的高度
* @param image 源图片
* @param outerRadiusRat 圆角的大小
* @return 圆角图片
*/
Bitmap createFramedPhoto(int x,
int y, Bitmap
image,
float outerRadiusRat)
{
//根据源文件新建一个darwable对象
Drawable imageDrawable =
new BitmapDrawable(image);
// 新建一个新的输出图片
Bitmap output
= Bitmap.createBitmap(x, y, Bitmap.Config.ARGB_8888);
Canvas
canvas = new
Canvas(output);
// 新建一个矩形
RectF outerRect =
new RectF(0, 0, x, y);
// 产生一个红色的圆角矩形
Paint
paint = new
Paint(Paint.ANTI_ALIAS_FLAG);
paint.setColor(Color.RED);
canvas.drawRoundRect(outerRect, outerRadiusRat,
outerRadiusRat, paint);
// 将源图片绘制到这个圆角矩形上
paint.setXfermode(new PorterDuffXfermode(PorterDuff.Mode.SRC_IN));
imageDrawable.setBounds(0, 0, x, y);
canvas.saveLayer(outerRect,
paint,
Canvas.ALL_SAVE_FLAG);
imageDrawable.draw(canvas);
canvas.restore();
return
output;
}
}
方法的原理就是先创建出一个圆角矩形的图片,然后将我们原来的图片作为上面的一层覆盖在这个圆角矩形上,并且使用该圆角图片的形状。ok,看看结果吧,是不是看起来好多了?
![](http://blog.chinaunix.net/attachment/201207/2/20771867_1341200361SzNY.png)
相关文章推荐
- Android中绘制圆角矩形图片及任意形状图片
- Android 绘制圆角图片(圆形图片,圆角矩形图片,圆角正方形图片)
- 在Android中绘制圆角矩形图片
- Android 绘制圆角图片(圆形图片,圆角矩形图片,圆角正方形图片)【转】
- Android中绘制圆角矩形图片及任意形状图片
- Android中绘制圆角矩形图片及任意形状图片
- 在Android中绘制圆角矩形图片
- Android中绘制圆角矩形图片及任意形状图片
- Android中绘制圆角矩形图片及任意形状图片
- android开发中圆角图片的绘制
- Android中绘制圆形和圆角图片
- Android长方形图片生成正圆形,以及矩形图片生成圆角
- Android长方形图片生成正圆形,以及矩形图片生成圆角
- android view绘制圆角矩形(转)
- Android画圆角矩形图片,并在图片上写字
- Android开发:SurfaceView上新建线程绘制旋转图片 及 刷新特定区域(脏矩形)
- Android 如何使用shape绘制只有一个圆角的矩形
- Android长方形图片生成正圆形,以及矩形图片生成圆角
- android 使用java编程实现圆角渐变矩形的绘制
- android 图片转 圆形和圆角矩形