移动开发----自定义圆形图片

原创 2016年05月30日 21:35:32

package com.example.view;


import android.content.Context;
import android.graphics.Bitmap;
import android.graphics.Bitmap.Config;
import android.graphics.Canvas;
import android.graphics.Color;
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 RoundImageView extends ImageView {


public RoundImageView(Context context, AttributeSet attrs, int defStyle) {
super(context, attrs, defStyle);
// TODO Auto-generated constructor stub
}


public RoundImageView(Context context, AttributeSet attrs) {
super(context, attrs);
// TODO Auto-generated constructor stub
}


public RoundImageView(Context context) {
super(context);
// TODO Auto-generated constructor stub
}
@Override  
protected void onDraw(Canvas canvas) {  
 
   Drawable drawable = getDrawable();  
 
   if (drawable == null) {  
       return;  
   }  
 
   if (getWidth() == 0 || getHeight() == 0) {  
       return;   
   }  
     
   Bitmap b =  ((BitmapDrawable)drawable).getBitmap();  
   
   if(null == b)  
   {  
       return;  
   }  
     
   Bitmap bitmap = b.copy(Bitmap.Config.ARGB_8888, true);  
 
   int w = getWidth(), h = getHeight();  
 
 
   Bitmap roundBitmap =  getCroppedBitmap(bitmap, w);  
   canvas.drawBitmap(roundBitmap, 0,0, null);  
 
}  
 
public static Bitmap getCroppedBitmap(Bitmap bmp, int radius) {  
   Bitmap sbmp;  
   if(bmp.getWidth() != radius || bmp.getHeight() != radius)  
       sbmp = Bitmap.createScaledBitmap(bmp, radius, radius, false);  
   else  
       sbmp = bmp;  
   Bitmap output = Bitmap.createBitmap(sbmp.getWidth(),  
           sbmp.getHeight(), Config.ARGB_8888);  
   Canvas canvas = new Canvas(output);  
 
   final int color = 0xffa19774;  
   final Paint paint = new Paint();  
   final Rect rect = new Rect(0, 0, sbmp.getWidth(), sbmp.getHeight());  
 
   paint.setAntiAlias(true);  
   paint.setFilterBitmap(true);  
   paint.setDither(true);  
   canvas.drawARGB(0, 0, 0, 0);  
   paint.setColor(Color.parseColor("#BAB399"));  
   canvas.drawCircle(sbmp.getWidth() / 2+0.7f, sbmp.getHeight() / 2+0.7f,  
           sbmp.getWidth() / 2+0.1f, paint);  
   paint.setXfermode(new PorterDuffXfermode(Mode.SRC_IN));  
   canvas.drawBitmap(sbmp, rect, rect, paint);  
 
 
           return output;  
}  
}



//////////////////////////////////////////////以防万一/////////////////////////////////////////////////////////////
if(drawable instanceof BitmapDrawable){         
b = ((BitmapDrawable)drawable).getBitmap();
}






///////////////////////////不相关的  viewpager冲突、、、、、、、、、、、、、、、、、、、
// 瑙e喅ViewPager婊戝姩鐨勬晥鏋�

launch_vp.setOnTouchListener(new OnTouchListener() {
@Override
public boolean onTouch(View v, MotionEvent event) {
if (event.getAction() == MotionEvent.ACTION_UP) {
launch_vp.requestDisallowInterceptTouchEvent(false);
} else {
launch_vp.requestDisallowInterceptTouchEvent(true);
}
return false;


}
});


版权声明:本文为博主原创文章,未经博主允许不得转载。

[Phonegap+Sencha Touch] 移动开发7、Sencha Touch图标的使用与自定义

Sencha touch 2.2之前,图标都是通过 几张不同分辨率png格式的图片(适应不同分辨率的设备),加上css3样式-webkit-mask,实现的单色图标。 2.2之后,图标的实现方式,换成...

【Android移动开发技术】AndroidStudio常用快捷键(Mac)(自定义快捷键)

这里的快捷键是基于OSX个人定制版本的,具体请到 setting -> keymap 设置 快捷键 作用 Option + Enter 自动修正 Comm...
  • ourpush
  • ourpush
  • 2016年08月27日 10:45
  • 184

【Android移动开发技术】Android Studio常用快捷键(Windows&Mac)(自定义快捷键)

Android Studio for Window(Default)快捷键 Shift + F6  重命名 Shift + Alt + C  对比最近修改的代码 F2  高亮错误...
  • ourpush
  • ourpush
  • 2016年08月27日 10:52
  • 142

移动开发----ExpandableTextView(带收缩和展开的简单自定义textview)

ExpandableTextView an ExpandableTextView on Android platform which can shrink TextView height if it...

Android移动开发-在Android 5.0 以上版本自定义Toolbar的实现

Google在Android 5.0 以上版本新增了自定义Toolbar的功能,对于开发者是一件喜事。相比于Actionbar,Toolbar最明显的一点就是变得很自由,可随处放置。使用Toolbar...

【移动开发】如何自定义ViewGroup

依照惯例,先从一个例子说起。 很简单,3张扑克牌叠在一起显示。这个布局效果该如何实现呢?有的同学该说了,这很简单啊,用RelativeLayout或FrameLayout,然后为每一个扑克牌设置ma...
  • manoel
  • manoel
  • 2014年09月05日 00:14
  • 9787

安卓开发中实现广告图片自动切换的ViewPager广告栏的自定义类(可以根据广告数自动设置导航圆形图标个数)

在安卓开发,我们经常看到一些app的主页上面有一个banner广告界面,循环播放多个广告图片,也响应左右滑动事件,大家一定回想到ViewPager,确实该banner广告界面用到了ViewPager,...

android自定义圆形头像图片

  • 2016年12月23日 14:27
  • 22.39MB
  • 下载

android实现自定义圆形图片

  • 2015年10月27日 22:41
  • 1.32MB
  • 下载

自定义圆形View:实现跟随手指移动的小球

一. 需求功能: 手指在屏幕上滑动,红色的小球始终跟随手指移动。 实现的思路: 1)自定义View,在onDraw中画圆作为小球; 2)重写自定义View的onTouchEvent方法,记...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:移动开发----自定义圆形图片
举报原因:
原因补充:

(最多只允许输入30个字)