让我的头像圆起来--Android之圆头像 .

在很多应用中,我们看到,个人主页里面的头像一般都是圆的,设计成圆的会使整个界面布局变的优雅漂亮。那么,怎么使头像变圆呢?有的人说可以在上面加一个中间为透明圆形的png图,用它来遮盖住头像不就行了嘛,但是png四周始终始终是不透明的,怎么做也达不到如下的效果图的。

下面我们讲讲怎么做成的吧。

首先创建一个继承ImageView的抽象类MaskedImage。让他重写onDraw方法。代码如下

  1. public abstract class MaskedImage extends ImageView {  
        private static final Xfermode MASK_XFERMODE;  
        private Bitmap mask;  
        private Paint paint;  
      
        static {  
            PorterDuff.Mode localMode = PorterDuff.Mode.DST_IN;  
            MASK_XFERMODE = new PorterDuffXfermode(localMode);  
        }  
      
        public MaskedImage(Context paramContext) {  
            super(paramContext);  
        }  
      
        public MaskedImage(Context paramContext, AttributeSet paramAttributeSet) {  
            super(paramContext, paramAttributeSet);  
        }  
      
        public MaskedImage(Context paramContext, AttributeSet paramAttributeSet, int paramInt) {  
            super(paramContext, paramAttributeSet, paramInt);  
        }  
      
        public abstract Bitmap createMask();  
      
        protected void onDraw(Canvas paramCanvas) {  
            Drawable localDrawable = getDrawable();  
            if (localDrawable == null)  
                return;  
            try {  
                if (this.paint == null) {  
                    Paint localPaint1 = new Paint();  
                    this.paint = localPaint1;  
                    this.paint.setFilterBitmap(false);  
                    Paint localPaint2 = this.paint;  
                    Xfermode localXfermode1 = MASK_XFERMODE;  
                    @SuppressWarnings("unused")  
                    Xfermode localXfermode2 = localPaint2.setXfermode(localXfermode1);  
                }  
                float f1 = getWidth();  
                float f2 = getHeight();  
                int i = paramCanvas.saveLayer(0.0F, 0.0F, f1, f2, null, 31);  
                int j = getWidth();  
                int k = getHeight();  
                localDrawable.setBounds(0, 0, j, k);  
                localDrawable.draw(paramCanvas);  
                if ((this.mask == null) || (this.mask.isRecycled())) {  
                    Bitmap localBitmap1 = createMask();  
                    this.mask = localBitmap1;  
                }  
                Bitmap localBitmap2 = this.mask;  
                Paint localPaint3 = this.paint;  
                paramCanvas.drawBitmap(localBitmap2, 0.0F, 0.0F, localPaint3);  
                paramCanvas.restoreToCount(i);  
                return;  
            } catch (Exception localException) {  
                StringBuilder localStringBuilder = new StringBuilder()  
                        .append("Attempting to draw with recycled bitmap. View ID = ");  
                System.out.println("localStringBuilder=="+localStringBuilder);  
            }  
        }  
    }
  1. public abstract class MaskedImage extends ImageView {  
        private static final Xfermode MASK_XFERMODE;  
        private Bitmap mask;  
        private Paint paint;  
      
        static {  
            PorterDuff.Mode localMode = PorterDuff.Mode.DST_IN;  
            MASK_XFERMODE = new PorterDuffXfermode(localMode);  
        }  
      
        public MaskedImage(Context paramContext) {  
            super(paramContext);  
        }  
      
        public MaskedImage(Context paramContext, AttributeSet paramAttributeSet) {  
            super(paramContext, paramAttributeSet);  
        }  
      
        public MaskedImage(Context paramContext, AttributeSet paramAttributeSet, int paramInt) {  
            super(paramContext, paramAttributeSet, paramInt);  
        }  
      
        public abstract Bitmap createMask();  
      
        protected void onDraw(Canvas paramCanvas) {  
            Drawable localDrawable = getDrawable();  
            if (localDrawable == null)  
                return;  
            try {  
                if (this.paint == null) {  
                    Paint localPaint1 = new Paint();  
                    this.paint = localPaint1;  
                    this.paint.setFilterBitmap(false);  
                    Paint localPaint2 = this.paint;  
                    Xfermode localXfermode1 = MASK_XFERMODE;  
                    @SuppressWarnings("unused")  
                    Xfermode localXfermode2 = localPaint2.setXfermode(localXfermode1);  
                }  
                float f1 = getWidth();  
                float f2 = getHeight();  
                int i = paramCanvas.saveLayer(0.0F, 0.0F, f1, f2, null, 31);  
                int j = getWidth();  
                int k = getHeight();  
                localDrawable.setBounds(0, 0, j, k);  
                localDrawable.draw(paramCanvas);  
                if ((this.mask == null) || (this.mask.isRecycled())) {  
                    Bitmap localBitmap1 = createMask();  
                    this.mask = localBitmap1;  
                }  
                Bitmap localBitmap2 = this.mask;  
                Paint localPaint3 = this.paint;  
                paramCanvas.drawBitmap(localBitmap2, 0.0F, 0.0F, localPaint3);  
                paramCanvas.restoreToCount(i);  
                return;  
            } catch (Exception localException) {  
                StringBuilder localStringBuilder = new StringBuilder()  
                        .append("Attempting to draw with recycled bitmap. View ID = ");  
                System.out.println("localStringBuilder=="+localStringBuilder);  
            }  
        }  
    }

然后新建一个类CircularImage继承MaskedImage。代码如下:

  1. <SPAN style="FONT-SIZE: 14px">public class CircularImage extends MaskedImage {  
        public CircularImage(Context paramContext) {  
            super(paramContext);  
        }  
      
        public CircularImage(Context paramContext, AttributeSet paramAttributeSet) {  
            super(paramContext, paramAttributeSet);  
        }  
      
        public CircularImage(Context paramContext, AttributeSet paramAttributeSet, int paramInt) {  
            super(paramContext, paramAttributeSet, paramInt);  
        }  
      
        public Bitmap createMask() {  
            int i = getWidth();  
            int j = getHeight();  
            Bitmap.Config localConfig = Bitmap.Config.ARGB_8888;  
            Bitmap localBitmap = Bitmap.createBitmap(i, j, localConfig);  
            Canvas localCanvas = new Canvas(localBitmap);  
            Paint localPaint = new Paint(1);  
            localPaint.setColor(-16777216);  
            float f1 = getWidth();  
            float f2 = getHeight();  
            RectF localRectF = new RectF(0.0F, 0.0F, f1, f2);  
            localCanvas.drawOval(localRectF, localPaint);  
            return localBitmap;  
        }  
    }</SPAN>

新建一个MainActivity,代码如下:

public class MainActivity extends Activity {  
  
    @Override  
    protected void onCreate(Bundle savedInstanceState) {  
        super.onCreate(savedInstanceState);  
        setContentView(R.layout.activity_main);  
          
        CircularImage cover_user_photo = (CircularImage) findViewById(R.id.cover_user_photo);  
        cover_user_photo.setImageResource(R.drawable.face);  
    }  
}

其XML布局文件为:

  1. <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"  
        xmlns:tools="http://schemas.android.com/tools"  
        android:layout_width="match_parent"  
        android:layout_height="match_parent"  
        android:gravity="center" >  
      
        <ImageView  
            android:layout_width="82.0dip"  
            android:layout_height="82.0dip"  
            android:layout_centerInParent="true"  
            android:contentDescription="@null"  
            android:src="@drawable/me_head_bg" />  
      
        <com.doublefi123.diary.widget.CircularImage  
            android:id="@+id/cover_user_photo"  
            android:layout_width="74.0dip"  
            android:layout_height="74.0dip"  
            android:layout_centerInParent="true" />  
      
    </RelativeLayout>
  1. <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"  
        xmlns:tools="http://schemas.android.com/tools"  
        android:layout_width="match_parent"  
        android:layout_height="match_parent"  
        android:gravity="center" >  
      
        <ImageView  
            android:layout_width="82.0dip"  
            android:layout_height="82.0dip"  
            android:layout_centerInParent="true"  
            android:contentDescription="@null"  
            android:src="@drawable/me_head_bg" />  
      
        <com.doublefi123.diary.widget.CircularImage  
            android:id="@+id/cover_user_photo"  
            android:layout_width="74.0dip"  
            android:layout_height="74.0dip"  
            android:layout_centerInParent="true" />  
      
    </RelativeLayout>
时间: 2024-08-07 00:15:36

让我的头像圆起来--Android之圆头像 .的相关文章

【Android】更换头像的实现

现在不管什么APP都有个头像,如果你看见没有头像的APP就会感觉非常奇怪,以前头像都是方的,后来就变成圆的,我估计在过个几年就得来个五角星形状的头像,下面我把更换头像的代码写来: <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width

Android :修改头像并使用Bmob保存(显示为圆形)

这几天再写一个项目 之前写登陆注册界面的时候都没有涉及到头像和数据库 所以都比较好实现 这次加上了头像的部分 可以实现和网上的第三方数据库的连接 第三方数据库我使用的是Bmob Bmob 主页 很方便 我们先看一下成果 所以这里面其实东西也还挺多的 所以这篇博客会从这几个方面去介绍如何完成的 1 Bmob的基础配置和注册登录的使用 2 点击修改Button可以出现相册 并且选择一个之后再显示到原来头像位置 3 把头像设置为圆形 选择新头像不论是什么形状都可以显示为圆形 4 上传头像到Bmob 5

【android】 圆角头像

I:画圆角: 1 private void roundImg(ImageView iv){ 2 3 /**本地资源*/ 4 5 InputStream is = getResources().openRawResource(R.drawable.icon); 6 7 Bitmap bitmap = BitmapFactory.decodeStream(is); 8 9 /**网络资源*/ 10 11 //FileInputStream fis = new FileInputStream(url)

如何检测一个圆在多个圆内?

问题定义: 存在多个半径相同的圆,和一个半径不同的圆,如何判断半径不同的圆完全在一群圆内.下图演示了几种情况,左边是完全在圆内,右边不是. 解决方法之一: 对于红圆在某个黑圆之内或者在所有黑圆之外等的特例情形,可以用简单的圆圆之间的几何判断算法得到结果,对于其余部分相交的一般情形,如果同时满足以下两个条件则红圆在黑圆内: 1. 红圆与所有黑圆的交点都在黑圆内: 2. 黑圆之间的交点如果在红圆内,则其也必然在黑圆内. 否则,红圆不在黑圆内.

UVA 12304 /// 圆的综合题 圆的模板

题目大意: ①给出三角形三个点,求三角形外接圆,求外接圆的圆心和半径. ②给出三角形三个点,求三角形内接圆,求内接圆的圆心和半径. ③给出一个圆,和一个点,求过该点的圆的切线与x轴的夹角(0<=angle<180): ④给出一条直线,一个点p,指定半径r,求经过点p的与直线相切的半径为r的圆: ⑤给出两条直线,求与这两条直线相切的圆: ⑥给出两个圆,求同时与这两个圆相切的圆: 贴一下圆的模板 带了一些注释 主要包括以下内容 // 求三角形abc的外接圆c(圆心.半径) C csC(P a,P

Android如何自定义头像控件

如上图效果: 效果分析 根据上面的效果,我们目测需要自定义两个控件,一个就是我们的可自由缩放移动的ImageView,一个就是那个白色的边框:然后一起放置到一个RelativeLayout中:最后对外公布一个裁剪的方法,返回一个Bitmap: 让我们来写代码吧~ 首先是白色框框那个自定义View,我们叫做ClipImageBorderView ClipImageBorderView 分析下这个View,其实就是根据在屏幕中绘制一个正方形,正方形区域以外为半透明,绘制这个正方形需要与屏幕左右边距有

Android版本微信头像剪裁与系统剪裁之间的选择

当然选类似微信的剪裁咯,为什么?请看下文分析 转载请注明:http://blog.csdn.net/tmacsky/article/details/51179789 众所周知头像剪裁上传是绝大部分APP必备的功能之一,但是剪裁的模式有2种交互形式, 第一种是采用系统自带的剪裁功能,我个人是比较青睐系统的这种交互模式的,但是很可惜,在一些手机上出现问题,不得不弃用 第二种是微信版本自定义剪裁图,当然微信的这个并没有判断图片边界与自定义白色矩形框是否相连,我想这是一个bug吧,属于遗留问题 首先我们

Android上传头像代码,相机,相册,裁剪

activity_main.xml <?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" android:layout_height="fill_parent&qu

php使用post动态选择头像和js事件动态改变头像

<html> <head> <meta http-equit="Content-type" content="text/html" charset="utf-8"> <title>动态选择头像logo</title> <script type="text/javascript"> function check(obj){ $("showImage