简单的自定义圆形图片(不能与BitmapUtils一起使用)
来源:互联网 发布:自动设计软件 编辑:程序博客网 时间:2024/05/20 22:36
自定义类继承ImageView
package com.dzt.newsfast.DIYviews;import android.content.Context;import android.graphics.Bitmap;import android.graphics.Bitmap.Config;import android.graphics.Canvas;import android.graphics.Paint;import android.graphics.PorterDuff.Mode;import android.graphics.PorterDuffXfermode;import android.graphics.Rect;import android.graphics.drawable.BitmapDrawable;import android.graphics.drawable.Drawable;import android.util.AttributeSet;import android.widget.ImageView;public class RoundPicture extends ImageView{ private Paint paint ; public RoundPicture(Context context) { this(context,null); } public RoundPicture(Context context, AttributeSet attrs) { this(context, attrs,0); } public RoundPicture(Context context, AttributeSet attrs, int defStyle) { super(context, attrs, defStyle); paint = new Paint(); } /** * 绘制圆形图片 * @author caizhiming */ @Override protected void onDraw(Canvas canvas) { Drawable drawable = getDrawable(); if (null != drawable) { BitmapDrawable bd=(BitmapDrawable) drawable; Bitmap bitmap = (bd).getBitmap(); Bitmap b = getCircleBitmap(bitmap); final Rect rectSrc = new Rect(0, 0, b.getWidth(), b.getHeight()); final Rect rectDest = new Rect(0,0,getWidth(),getHeight()); paint.reset(); canvas.drawBitmap(b, rectSrc, rectDest, paint); } else { super.onDraw(canvas); } } /** * 获取圆形图片方法 * @param bitmap * @param pixels * @return Bitmap * @author caizhiming */ private Bitmap getCircleBitmap(Bitmap bitmap) { Bitmap output = Bitmap.createBitmap(bitmap.getWidth(), bitmap.getHeight(), Config.ARGB_8888); Canvas canvas = new Canvas(output); final int color = 0xff424242; final Rect rect = new Rect(0, 0, bitmap.getWidth(), bitmap.getHeight()); paint.setAntiAlias(true); canvas.drawARGB(0, 0, 0, 0); paint.setColor(color); int x = bitmap.getWidth(); canvas.drawCircle(x / 2, x / 2, x / 2, paint); paint.setXfermode(new PorterDuffXfermode(Mode.SRC_IN)); canvas.drawBitmap(bitmap, rect, rect, paint); return output; } }
xml布局中
//自己定义的包名加类名 <com.example.yue.myimageview.RoundPicture android:paddingLeft="5dp" android:paddingTop="10dp" android:layout_height="80dp" android:layout_width="80dp" android:id="@+id/image" />
注意不能与BitmapUtils一起使用冲突
0 0
- 简单的自定义圆形图片(不能与BitmapUtils一起使用)
- 178.n1-使用自定义MyBitmapUtils,不使用xUtils的BitmapUtils加载图片
- 自定义圆形图片ImageView的简单实现效果
- 如何使用Bitmaputils加载图片
- BitmapUtils 的使用
- imageview的自定义圆形图片
- 自定义圆形图片(RoundImageView)
- (转)安卓自定义圆形图片控件的使用(hdodenhof/CircleImageView)
- 自定义的圆形图片(一般用于头像显示部分)
- xutils 使用BitmapUtils进行图片本地缓存
- 自定义控件---带边框的圆形图片
- 裁剪圆形图片的自定义控件
- 圆形图片的实现自定义view
- android 自定义圆形图片与图片圆角
- 圆形自定义ImageView的简单制作
- 简单的自定义圆形进度条ProgressBar
- 自定义一个简单的圆形菜单
- Android中自定义圆形图片(一)
- hdu_1950_Bridging signals(LIS)
- 理解php-cli环境
- CentOS命令行安装VMware tools
- Spark算子:RDD基本转换操作(5)–mapPartitions、mapPartitionsWithIndex
- Cornell 感受
- 简单的自定义圆形图片(不能与BitmapUtils一起使用)
- SSL与TLS的区别以及介绍
- spark:map mapPartitions flatmap
- swiper的基础教程(十二)
- 动效,动效
- 141. Linked List Cycle
- HDU 1198
- Vitamio 花屏 透明 击穿
- 160630获取wifi ssid