该楼层疑似违规已被系统折叠 隐藏此楼查看此楼

一、CustomImageView插件

package com.open_open.android_plantest;

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.Paint;

import android.graphics.PorterDuff;

import android.graphics.PorterDuffXfermode;

import android.graphics.RectF;

import android.util.AttributeSet;

import android.util.TypedValue;

import android.view.View;

/**

* 自定义View,实现圆角,圆形等效果

*

* @author zhy

*

*/

public class CustomImageView extends View

{

/**

* TYPE_CIRCLE / TYPE_ROUND

*/

private int type;

private static final int TYPE_CIRCLE = 0;

private static final int TYPE_ROUND = 1;

/**

* 图片

*/

private Bitmap mSrc;

/**

* 圆角的大小

*/

private int mRadius;

/**

* 控件的宽度

*/

private int mWidth;

/**

* 控件的高度

*/

private int mHeight;

public CustomImageView(Context context, AttributeSet attrs)

{

this(context, attrs, 0);

}

public CustomImageView(Context context)

{

this(context, null);

}

/**

* 初始化一些自定义的参数

*

* @param context

* @param attrs

* @param defStyle

*/

public CustomImageView(Context context, AttributeSet attrs, int defStyle)

{

super(context, attrs, defStyle);

TypedArray a = context.getTheme().obtainStyledAttributes(attrs,

R.styleable.CustomImageView, defStyle, 0);

int n = a.getIndexCount();

for (int i = 0; i < n; i++)

{

int attr = a.getIndex(i);

switch (attr)

{

case R.styleable.CustomImageView_src:

mSrc = BitmapFactory.decodeResource(getResources(),

a.getResourceId(attr, 0));

break;

case R.styleable.CustomImageView_type:

type = a.getInt(attr, 0);// 默认为Circle

break;

case R.styleable.CustomImageView_borderRadius:

mRadius = a.getDimensionPixelSize(attr, (int) TypedValue

.applyDimension(TypedValue.COMPLEX_UNIT_DIP, 10f,

getResources().getDisplayMetrics()));// 默认为10DP

break;

}

}

a.recycle();

}

/**

* 计算控件的高度和宽度

*/

@Override

protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec)

{

// super.onMeasure(widthMeasureSpec, heightMeasureSpec);

/**

* 设置宽度

*/

int specMode = MeasureSpec.getMode(widthMeasureSpec);

int specSize = MeasureSpec.getSize(widthMeasureSpec);

if (specMode == MeasureSpec.EXACTLY)// match_parent , accurate

{

mWidth = specSize;

} else

{

// 由图片决定的宽

int desireByImg = getPaddingLeft() + getPaddingRight()

+ mSrc.getWidth();

if (specMode == MeasureSpec.AT_MOST)// wrap_content

{

mWidth = Math.min(desireByImg, specSize);

} else

mWidth = desireByImg;

}

/***

* 设置高度

*/

specMode = MeasureSpec.getMode(heightMeasureSpec);

specSize = MeasureSpec.getSize(heightMeasureSpec);

if (specMode == MeasureSpec.EXACTLY)// match_parent , accurate

{

mHeight = specSize;

} else

{

int desire = getPaddingTop() + getPaddingBottom()

+ mSrc.getHeight();

if (specMode == MeasureSpec.AT_MOST)// wrap_content

{

mHeight = Math.min(desire, specSize);

} else

mHeight = desire;

}

setMeasuredDimension(mWidth, mHeight);

}

/**

* 绘制

*/

@Override

protected void onDraw(Canvas canvas)

{

switch (type)

{

// 如果是TYPE_CIRCLE绘制圆形

case TYPE_CIRCLE:

int min = Math.min(mWidth, mHeight);

/**

* 长度如果不一致,按小的值进行压缩

*/

mSrc = Bitmap.createScaledBitmap(mSrc, min, min, false);

canvas.drawBitmap(createCircleImage(mSrc, min), 0, 0, null);

break;

case TYPE_ROUND:

canvas.drawBitmap(createRoundConerImage(mSrc), 0, 0, null);

break;

}

}

/**

* 根据原图和变长绘制圆形图片

*

* @param source

* @param min

* @return

*/

private Bitmap createCircleImage(Bitmap source, int min)

{

final Paint paint = new Paint();

paint.setAntiAlias(true);

Bitmap target = Bitmap.createBitmap(min, min, Config.ARGB_8888);

/**

* 产生一个同样大小的画布

*/

Canvas canvas = new Canvas(target);

/**

* 首先绘制圆形

*/

canvas.drawCircle(min / 2, min / 2, min / 2, paint);

/**

* 使用SRC_IN,参考上面的说明

*/

paint.setXfermode(new PorterDuffXfermode(PorterDuff.Mode.SRC_IN));

/**

* 绘制图片

*/

canvas.drawBitmap(source, 0, 0, paint);

return target;

}

/**

* 根据原图添加圆角

*

* @param source

* @return

*/

private Bitmap createRoundConerImage(Bitmap source)

{

final Paint paint = new Paint();

paint.setAntiAlias(true);

Bitmap target = Bitmap.createBitmap(mWidth, mHeight, Config.ARGB_8888);

Canvas canvas = new Canvas(target);

RectF rect = new RectF(0, 0, source.getWidth(), source.getHeight());

canvas.drawRoundRect(rect, mRadius, mRadius, paint);

paint.setXfermode(new PorterDuffXfermode(PorterDuff.Mode.SRC_IN));

canvas.drawBitmap(source, 0, 0, paint);

return target;

}

}

android 圆角图片 imageview,【android 图片圆角设定】CustomImageView简单一览相关推荐

  1. android view存储为jpg,Android长按imageview把图片保存到本地的实例代码

    工具类 之前用 AsyncTask 现在改用rxJava public class SaveImageUtils { public static void imageSave(final ImageV ...

  2. 【Android Studio】ImageView / ImageButton 图片太大或者太小解决方法

    第一步:指定layout_width与layout_height 在xml文件中设置的ImageButton的宽和高为: android:layout_width="100dp" ...

  3. android 点击图片旋转90度,Android UI之ImageView实现图片旋转和缩放

    这一篇,给大家介绍一下ImageView控件的使用,ImageView主要是用来显示图片,可以对图片进行放大.缩小.旋转的功能. android:sacleType属性指定ImageVIew控件显示图 ...

  4. android如何隐藏imageview,Android编程实现切换imageView的方法分析

    本文实例讲述了Android编程实现切换imageView的方法.分享给大家供大家参考,具体如下: 最近在做五子棋的界面的时候,需要有一块区域动态显示当前棋局的情况,考虑到字体和现实效果,我决定用图片 ...

  5. android如何隐藏imageview,Android:隐藏Imageview

    尝试这个 你的xml android:id="@+id/custom" android:layout_width="wrap_content" android: ...

  6. Android笔记之ImageView设置图片以灰色显示

    有时候我们需要将ImageView加载的图片去彩色,以黑白灰度显示,如qq的不在线头像. 第一种,我们可以通过将彩色bitmap图转换成黑白灰度bitmap图: /*** 图片去色,返回灰度图片* @ ...

  7. Android自定义控件:imageview重写onMeasure方法实现图片按指定比例显示,拉伸永不变形,解决屏幕适配问题

    使用ImageView会遇到的问题 在Android应用中,都少不了图片的显示,ImageView,轮播图,ViewPager等等,很多都是来显示图片的,比如一个广告条的轮播效果,参看博客:广告条效果 ...

  8. android 自定义圆形pop,Android布局自定义Shap圆形ImageView可以单独设置背景与图片...

    一.图片预览: 一.实现功能: 需求要实现布局中为圆形图片,图片背景与图标分开且合并到一个ImageView. 二.具体实现: XML中布局中定义ImageView,关健设置两个参数 Android: ...

  9. Android ViewPager实现多个图片水平滚动

    1.示意图                       2.实现分析 (1).xml配置 <!-- 配置container和pager的clipChildren=false, 并且指定margi ...

  10. Android学习笔记进阶十一图片动画播放(AnimationDrawable)

    大家平时见到的最多的可能就是Frame动画了,Android中当然也少不了它.它的使用更加简单,只需要创建一个 AnimationDrawabledF对象来表示Frame动画,然后通过addFrame ...

最新文章

  1. linux密码时效更改方法
  2. Jmeter接口测试踩过的坑,快来看鸭~
  3. 专访1药网技术副总裁黄哲铿:揭秘技术跨界管理之道
  4. Matlab实用程序--图形应用-图形的叠加
  5. pythonexcel工具介绍_Python处理excel的强大工具
  6. 【Linux入门学习之】Linux连接文件:硬连接和软连接
  7. 虚拟化部署之创建Hyper-V虚拟硬盘
  8. vue点击网页全屏_vue中实现点击变成全屏的多种方法
  9. Atitit 程序设计概论 艾提拉著作 目录 1. 界面ui设计 1 2. 编程语言部分 1 3. 面向对象的程序设计 1 4. 算法章节 数据结构 1 5. 第21章 标准库 2 5.1. 文件i
  10. 大数据学习的思维原理和方法?
  11. C语言中除法怎么取得小数
  12. Maven下载安装与配置IDEA
  13. 一筐鸡蛋c语言编程,求答案-求答案?一筐鸡蛋?求答案?一筐鸡蛋:1个1个拿,正好拿完2个2 爱问知识人...
  14. Python实战:将头像变成动漫风
  15. 硬核干货 | 人大金仓数据库产品体系合集
  16. 湖南农业大学有计算机应用,计算机应用基础复习资料–湖南农业大学.doc
  17. 源码天空java新闻_Java UpdateRequest类代码示例
  18. 【问题】Ubuntu20.04桌面某些图标不显示
  19. [转]最短路径算法—Dijkstra(迪杰斯特拉)算法分析与实现
  20. MOD13Q1数据最大合成NDVI数据

热门文章

  1. synchronized工作原理剖析(二)
  2. Spring Cloud Alibaba Sentinel之服务熔断篇
  3. 并发编程学习之Lock同步锁
  4. RabbitMQ死信队列应用场景之模拟未支付订单自动取消
  5. RedissonMultiLock + RedissonLock部分源码
  6. springboot整合shiro之实现记住我
  7. thymeleaf使用总结
  8. NB-IoT、eMTC与LoRa三大物联网技术相争,共存还是鏖战?
  9. MySQL 简单语句(2)
  10. Swift - 使用下划线(_)来分隔数值中的数字