public CircleImageView(Context context, AttributeSet attrs) {super(context, attrs); }之后重写onDraw方法
@Override protected void onDraw(Canvas canvas) {//获得图片的宽度int width=getWidth();//获得图片的高度int height=getHeight();//短的二分之一作为半径int radius=height>width?width/2:height/2;//重新定义的一个画布,这一步很关键Paint mPaint = new Paint();//抗锯齿mPaint.setAntiAlias(true);Bitmap bitmap = Bitmap.createBitmap(width,height,Bitmap.Config.ARGB_8888);Canvas bitmapCanvas = new Canvas(bitmap);super.onDraw(bitmapCanvas);//圆形的框Bitmap cB = Bitmap.createBitmap(width, height,Bitmap.Config.ARGB_8888);Canvas cCanv = new Canvas(cB);//在控件中间画一个cCanv.drawCircle(width/ 2, height/ 2, radius,mPaint);canvas.drawBitmap(bitmap, 0.0f, 0.0f, mPaint);//dst是后画的图形mPaint.setXfermode(new PorterDuffXfermode(PorterDuff.Mode.DST_IN));//一定要用之前的画布,不然会出现边角是黑色bitmapCanvas.drawBitmap(cB, 0.0f, 0.0f, mPaint);//给图形加边框Paint paint =new Paint();paint.setAntiAlias(true);paint.setStyle(Paint.Style.STROKE);paint.setStrokeWidth(5);paint.setColor(Color.BLACK);canvas.drawCircle(width/ 2, height/ 2, radius,paint); }一个简单的CircleImageView就做成了,你们还可以把边框弄成一个属性还有配置相应的方法,让使用者更加方便的使用
<com.example.jkgeekjk.roadtodevelop3.CircleImageViewandroid:layout_width="match_parent"android:src="@drawable/avastar"android:layout_height="match_parent" />效果图:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。