在Android中绘制圆角矩形图片
来源:互联网 发布:屈臣氏的分销网络 编辑:程序博客网 时间:2024/06/16 17:12
转自: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)
0 0
- 在Android中绘制圆角矩形图片
- 在Android中绘制圆角矩形图片
- 在Android中绘制圆角矩形图片
- 在Canvas中绘制圆角矩形
- Android中绘制圆角矩形图片及任意形状图片
- Android中绘制圆角矩形图片及任意形状图片
- Android中绘制圆角矩形图片及任意形状图片
- 在android 自定义listView中绘制矩形
- android绘制圆角矩形
- Android 绘制圆角图片(圆形图片,圆角矩形图片,圆角正方形图片)
- android在java代码中绘制矩形框
- Android 绘制圆角图片(圆形图片,圆角矩形图片,圆角正方形图片)【转】
- android view绘制圆角矩形(转)
- 在Microsoft Expression Blend 2 中绘制圆角矩形按钮
- 在Microsoft Expression Blend 2 中绘制圆角矩形按钮
- 如何:在矩形中绘制换行文本
- 在winform中绘制矩形的方法
- 在UIView中绘制直线、矩形、三角形
- [leetcode] Edit Distance
- cxgrid删除选中行记录
- 图
- linux mount (挂载命令)详解
- 把二元查找树转变成排序的双向链表
- 在Android中绘制圆角矩形图片
- 快速排序算法
- Android ActionBar完全解析
- 安装office 2010,提示需要安装MSXML版本6.10.1129.0组件的解决办法
- 物联无线自动窗帘:窗帘收放更自如-智能家居
- JAVA编程思想(4) - 多态(一)
- Duty Free Shop - POJ 1293 dp
- Android中绘制圆角矩形图片及任意形状图片
- Failed to stop component [StandardEngine[Catalina].StandardHost[localhost].S