Picasso 图片圆角的实现方式
来源:互联网 发布:光栅衍射实验报告数据 编辑:程序博客网 时间:2024/05/16 05:39
通过Picasso提供的Transformation实现
圆角矩形
import android.graphics.Bitmap;import android.graphics.Canvas;import android.graphics.Paint;import android.graphics.PorterDuff;import android.graphics.PorterDuffXfermode;import android.graphics.Rect;import android.graphics.RectF;import com.squareup.picasso.Transformation;public class PicassoRoundTransform implements Transformation { @Override public Bitmap transform(Bitmap source) { int widthLight = source.getWidth(); int heightLight = source.getHeight(); Bitmap output = Bitmap.createBitmap(source.getWidth(), source.getHeight(), Bitmap.Config.ARGB_8888); Canvas canvas = new Canvas(output); Paint paintColor = new Paint(); paintColor.setFlags(Paint.ANTI_ALIAS_FLAG); RectF rectF = new RectF(new Rect(0, 0, widthLight, heightLight)); canvas.drawRoundRect(rectF, widthLight / 5, heightLight / 5, paintColor); Paint paintImage = new Paint(); paintImage.setXfermode(new PorterDuffXfermode(PorterDuff.Mode.SRC_ATOP)); canvas.drawBitmap(source, 0, 0, paintImage); source.recycle(); return output; } @Override public String key() { return "roundcorner"; }}用法:
Picasso.with(UserDetialActivity.this).load(imageId).error(R.mipmap.ic_launcher).transform(new PicassoRoundTransform()).into(user_detail_header);
圆形图片:
<pre style="background-color: rgb(255, 255, 255);"><pre><span style="font-family:FangSong_GB2312;font-size:12px;">public class CircleTransform implements Transformation { @Override public Bitmap transform(Bitmap source) { int size = Math.min(source.getWidth(), source.getHeight()); int x = (source.getWidth() - size) / 2; int y = (source.getHeight() - size) / 2; Bitmap squaredBitmap = Bitmap.createBitmap(source, x, y, size, size); if (squaredBitmap != source) { source.recycle(); } Bitmap bitmap = Bitmap.createBitmap(size, size, source.getConfig()); Canvas canvas = new Canvas(bitmap); Paint paint = new Paint(); BitmapShader shader = new BitmapShader(squaredBitmap, BitmapShader.TileMode.CLAMP, BitmapShader.TileMode.CLAMP); paint.setShader(shader); paint.setAntiAlias(true); float r = size / 2f; canvas.drawCircle(r, r, r, paint); squaredBitmap.recycle(); return bitmap; } @Override public String key() { return "circle"; }}</span>
0 0
- Picasso 图片圆角的实现方式
- Picasso轻松实现圆角图片
- Android中的Picasso实现圆角图片
- Android Picasso实现圆形图片和圆角图片
- Picasso图片加载方式
- Picasso实现下载圆形头像以及圆角图片
- Picasso实现下载圆形头像以及圆角图片
- Picasso加载圆角图片
- Picasso加载圆角图片
- Picasso加载圆角图片
- Picasso 实现图片的比例缩放
- picasso实现下载圆形图片
- Picasso下载图片到指定路径的实现
- 仿Picasso框架,实现简单的图片三级缓存处理
- Picasso下载图片到指定路径的实现
- Picasso下载图片到指定路径的实现
- 利用swiperefreshlayout和picasso实现图片的下拉刷新
- 学习笔记之——Android中的Picasso实现圆形头像、圆角图片工具类
- 关于Struts2异常或错误不输出到控制台原因
- MVC设计模式
- jQuery easyUI动态的课表
- PHP中使用CURL实现GET和POST请求(详细)
- Python基础语法(三)
- Picasso 图片圆角的实现方式
- C++引入名字空间(namespace)意义何在?为什么using namespace std会成为常用语句?
- springmvc学习笔记(22)-springmvc开发小结
- ubuntu基本使用总结(不断更新中。。。
- iOS开发---MJRefresh下拉刷新/下拉加载
- LTE-TDD随机接入过程(2)-前导码Preamble的格式与时频位置
- JSP生成验证码
- 关于Block的copy和循环引用的问题
- Android 基于google Zxing实现对手机中的二维码进行扫描