目前一些比较火的图片加载库虽然支持圆角加载,若你是接的别人作了一半的项目,刚好别人用的图片加载库刚好不支持圆角加载,那么这颗控件你值得拥有.(支持网络图片的加载)

1.创建CustomImageView 类在你的项目中(源码如下)
import android.content.Context;
import android.content.res.TypedArray;
import android.graphics.Bitmap;
import android.graphics.Bitmap.Config;
import android.graphics.BitmapFactory;
import android.graphics.Canvas;
import android.graphics.Matrix;
import android.graphics.Paint;
import android.graphics.PorterDuff;
import android.graphics.PorterDuffXfermode;
import android.graphics.RectF;
import android.graphics.drawable.BitmapDrawable;
import android.graphics.drawable.Drawable;
import android.util.AttributeSet;
import android.widget.ImageView;
import com.towatt.charge.towatt.R;
/**
* @author Mr.lynn
* @version 1.0<br>
* 图片圆角实现
*/
public class CustomImageView extends android.support.v7.widget.AppCompatImageView {
private Paint paint;
private Paint paintBorder;
private Bitmap mSrcBitmap;
/**
* 圆角的弧度
*/
private float mRadius;
private boolean mIsCircle;
public CustomImageView(final Context context) {
this(context, null);
}
public CustomImageView(Context context, AttributeSet attrs) {
this(context, attrs, R.attr.customImageViewStyle);
}
public CustomImageView(Context context, AttributeSet attrs, int defStyle) {
super(context, attrs, defStyle);
TypedArray ta = context.obtainStyledAttributes(attrs,
R.styleable.CustomImageView, defStyle, 0);
mRadius = ta.getDimension(R.styleable.CustomImageView_radius, 0);
mIsCircle = ta.getBoolean(R.styleable.CustomImageView_circle, false);
int srcResource = attrs.getAttributeResourceValue(
"http://schemas.android.com/apk/res/android", "src", 0);
if (srcResource != 0)
mSrcBitmap = BitmapFactory.decodeResource(getResources(),
srcResource);
ta.recycle();
paint = new Paint();
paint.setAntiAlias(true);
paintBorder = new Paint();
paintBorder.setAntiAlias(true);
}
@Override
public void onDraw(Canvas canvas) {
int width = canvas.getWidth() - getPaddingLeft() - getPaddingRight();
int height = canvas.getHeight() - getPaddingTop() - getPaddingBottom();
Bitmap image = drawableToBitmap(getDrawable());
if (mIsCircle) {
Bitmap reSizeImage = reSizeImageC(image, width, height);
canvas.drawBitmap(createCircleImage(reSizeImage, width, height),
getPaddingLeft(), getPaddingTop(), null);
} else {
Bitmap reSizeImage = reSizeImage(image, width, height);
canvas.drawBitmap(createRoundImage(reSizeImage, width, height),
getPaddingLeft(), getPaddingTop(), null);
}
}
/**
* 画圆角
*
* @param source
* @param width
* @param height
* @return
*/
private Bitmap createRoundImage(Bitmap source, int width, int height) {
Paint paint = new Paint();
paint.setAntiAlias(true);
Bitmap target = Bitmap.createBitmap(width, height, Config.ARGB_8888);
Canvas canvas = new Canvas(target);
RectF rect = new RectF(0, 0, width, height);
canvas.drawRoundRect(rect, mRadius, mRadius, paint);
// 核心代码取两个图片的交集部分
paint.setXfermode(new PorterDuffXfermode(PorterDuff.Mode.SRC_IN));
canvas.drawBitmap(source, 0, 0, paint);
return target;
}
/**
* 画圆
*
* @param source
* @param width
* @param height
* @return
*/
private Bitmap createCircleImage(Bitmap source, int width, int height) {
Paint paint = new Paint();
paint.setAntiAlias(true);
Bitmap target = Bitmap.createBitmap(width, height, Config.ARGB_8888);
Canvas canvas = new Canvas(target);
canvas.drawCircle(width / 2, height / 2, Math.min(width, height) / 2,
paint);
// 核心代码取两个图片的交集部分
paint.setXfermode(new PorterDuffXfermode(PorterDuff.Mode.SRC_IN));
canvas.drawBitmap(source, (width - source.getWidth()) / 2,
(height - source.getHeight()) / 2, paint);
return target;
}
@Override
protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
int width = MeasureSpec.getSize(widthMeasureSpec);
int height = MeasureSpec.getSize(heightMeasureSpec);
setMeasuredDimension(width, height);
}
/**
* drawable转bitmap
*
* @param drawable
* @return
*/
private Bitmap drawableToBitmap(Drawable drawable) {
if (drawable == null) {
if (mSrcBitmap != null) {
return mSrcBitmap;
} else {
return null;
}
} else if (drawable instanceof BitmapDrawable) {
return ((BitmapDrawable) drawable).getBitmap();
}
Bitmap bitmap = Bitmap.createBitmap(drawable.getIntrinsicWidth(),
drawable.getIntrinsicHeight(), Bitmap.Config.ARGB_8888);
Canvas canvas = new Canvas(bitmap);
drawable.setBounds(0, 0, canvas.getWidth(), canvas.getHeight());
drawable.draw(canvas);
return bitmap;
}
/**
* 重设Bitmap的宽高
*
* @param bitmap
* @param newWidth
* @param newHeight
* @return
*/
private Bitmap reSizeImage(Bitmap bitmap, int newWidth, int newHeight) {
int width = bitmap.getWidth();
int height = bitmap.getHeight();
// 计算出缩放比
float scaleWidth = ((float) newWidth) / width;
float scaleHeight = ((float) newHeight) / height;
// 矩阵缩放bitmap
Matrix matrix = new Matrix();
matrix.postScale(scaleWidth, scaleHeight);
return Bitmap.createBitmap(bitmap, 0, 0, width, height, matrix, true);
}
/**
* 重设Bitmap的宽高
*
* @param bitmap
* @param newWidth
* @param newHeight
* @return
*/
private Bitmap reSizeImageC(Bitmap bitmap, int newWidth, int newHeight) {
int width = bitmap.getWidth();
int height = bitmap.getHeight();
int x = (newWidth - width) / 2;
int y = (newHeight - height) / 2;
if (x > 0 && y > 0) {
return Bitmap.createBitmap(bitmap, 0, 0, width, height, null, true);
}
float scale = 1;
if (width > height) {
// 按照宽度进行等比缩放
scale = ((float) newWidth) / width;
} else {
// 按照高度进行等比缩放
// 计算出缩放比
scale = ((float) newHeight) / height;
}
Matrix matrix = new Matrix();
matrix.postScale(scale, scale);
return Bitmap.createBitmap(bitmap, 0, 0, width, height, matrix, true);
}
}
2.在values目录下创建attrs.xml(若是已存在该文件)直接复制如下代码既可
<resources> <declare-styleable name="Theme"> <attr name="customImageViewStyle" format="reference" /> </declare-styleable> <!-- 自定义圆角ImageView --> <declare-styleable name="CustomImageView"> <attr name="circle" format="boolean" /> <attr name="radius" format="dimension" /> </declare-styleable> </resources>
3.正确的使用方式(在布局文件中)
注意此路径是你控件所在包
<com.xxx.xxx.view.CustomImageView android:layout_marginTop="5dp" android:layout_width="77dp" android:layout_height="77dp" lynn:radius="@dimen/size_10dp" android:src="@drawable/position_icon" android:id="@+id/iv_build_icon" />
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# Android
# 圆角
# ImageView
# Android自定义ImageView实现圆角功能
# Android实现自定义ImageView的圆角矩形图片效果
# Android自定义控件之圆形、圆角ImageView
# Android ImageView绘制圆角效果
# Android实现圆角矩形和圆形ImageView的方式
# Android 圆角 ImageView类可设置弧度(代码简单)
# Android自定义圆角ImageView
# Android中通过反射实现圆角ImageView代码实例
# Android自定义带圆角的ImageView
# 加载
# 计算出
# 作了
# 自定义
# 不支持
# 既可
# 该文件
# 这颗
# 大家多多
# 若你
# 目录下
# float
# mRadius
# paintBorder
# mSrcBitmap
# boolean
# final
# context
# null
相关文章:
制作网站怎么制作,*游戏网站怎么搭建?
西安制作网站公司有哪些,西安货运司机用的最多的app或者网站是什么?
深圳防火门网站制作公司,深圳中天明防火门怎么编码?
建站之星上传入口如何快速找到?
建站主机如何安装配置?新手必看操作指南
建站之星导航配置指南:自助建站与SEO优化全解析
儿童网站界面设计图片,中国少年儿童教育网站-怎么去注册?
建站主机CVM配置优化、SEO策略与性能提升指南
如何配置支付宝与微信支付功能?
如何在万网自助建站平台快速创建网站?
太平洋网站制作公司,网络用语太平洋是什么意思?
详解ASP.NET 生成二维码实例(采用ThoughtWorks.QRCode和QrCode.Net两种方式)
临沂网站制作企业,临沂第三中学官方网站?
html制作网站的步骤有哪些,iapp如何添加网页?
如何在Windows服务器上快速搭建网站?
建站之星后台密码遗忘如何找回?
建站VPS能否同时实现高效与安全翻墙?
nginx修改上传文件大小限制的方法
微网站制作教程,不会写代码,不会编程,怎么样建自己的网站?
建站上市公司网站建设方案与SEO优化服务定制指南
建站之星Pro快速搭建教程:模板选择与功能配置指南
北京制作网站的公司,北京铁路集团官方网站?
攀枝花网站建设,攀枝花营业执照网上怎么年审?
如何做静态网页,sublimetext3.0制作静态网页?
c# 在ASP.NET Core中管理和取消后台任务
北京企业网站设计制作公司,北京铁路集团官方网站?
全景视频制作网站有哪些,全景图怎么做成网页?
建站之星代理平台如何选择最佳方案?
简历在线制作网站免费版,如何创建个人简历?
C++用Dijkstra(迪杰斯特拉)算法求最短路径
如何在宝塔面板中修改默认建站目录?
电影网站制作价格表,那些提供免费电影的网站,他们是怎么盈利的?
长春网站建设制作公司,长春的网络公司怎么样主要是能做网站的?
沈阳制作网站公司排名,沈阳装饰协会官方网站?
手机网站制作与建设方案,手机网站如何建设?
购物网站制作公司有哪些,哪个购物网站比较好?
阿里云网站制作公司,阿里云快速搭建网站好用吗?
如何在云主机上快速搭建多站点网站?
江苏网站制作公司有哪些,江苏书法考级官方网站?
c++怎么编写动态链接库dll_c++ __declspec(dllexport)导出与调用【方法】
建站VPS选购需注意哪些关键参数?
如何高效利用200m空间完成建站?
网站制作培训多少钱一个月,网站优化seo培训课程有哪些?
mc皮肤壁纸制作器,苹果平板怎么设置自己想要的壁纸我的世界?
如何挑选优质建站一级代理提升网站排名?
广州网站设计制作一条龙,广州巨网网络科技有限公司是干什么的?
内网网站制作软件,内网的网站如何发布到外网?
如何在新浪SAE免费搭建个人博客?
如何批量查询域名的建站时间记录?
如何高效生成建站之星成品网站源码?
*请认真填写需求信息,我们会在24小时内与您取得联系。