Picasso轻松实现圆角图片

转载 2016年08月28日 14:39:41

本文参考自:http://blog.csdn.net/wonghoman/article/details/48135281

Picasso轻松实现圆角图片,代码如下:


Main中Java 代码:


<span style="font-size:18px;">import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.widget.ImageView;

import com.squareup.picasso.Picasso;

public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

       ImageView img = (ImageView) findViewById(R.id.img);

        //需要Picasso的酷文件先导入项目中,直接用
        Picasso.with(MainActivity.this).load(R.mipmap.b).error
                (R.mipmap.c).transform(new CircleTransform()).into(img);
    }
}</span>

Main  对应的XML文件:

<span style="font-size:18px;"><?xml version="1.0" encoding="utf-8"?>
<LinearLayout
    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:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    tools:context="com.example.administrator.circularpic.MainActivity">

    <ImageView
        android:id="@+id/img"
        android:layout_gravity="center"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:background="#50ff0000"/>
</LinearLayout></span>

CircleTransform 代码如下:

<span style="font-size:18px;">package com.example.administrator.circularpic;

import android.graphics.Bitmap;
import android.graphics.BitmapShader;
import android.graphics.Canvas;
import android.graphics.Paint;

import com.squareup.picasso.Transformation;

/*
 *  @项目名:  CircularPic 
 *  @包名:    com.example.administrator.circularpic
 *  @文件名:   CircleTransform
 *  @创建者:   Administrator
 *  @创建时间:  2016/8/28 0028 14:33
 *  @描述:    TODO
 */

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>

搞定!




Picasso 图片圆角的实现方式

通过Picasso提供的Transformation实现 圆角矩形 import android.graphics.Bitmap; import android.graphics.Canvas; ...

Picasso实现下载圆形头像以及圆角图片

在使用Picasso的过程中发现原来Picasso在下载图片的过程中可以直接将下载的图片转换成圆形,这样就 更加方便的使用圆形头像 在xml布局里只是简单的写一个ImageView就可以 然后使用Pi...

Android中的Picasso实现圆角图片

注:有关Picasso的基本介绍,请参考我的上篇博客 Android图形缓存库Picasso的使用Picasso支持自定义Transformationpublic class CropSquareTr...

Picasso加载圆角图片

  • 2017年08月24日 17:46
  • 6.14MB
  • 下载

轻松实现圆角图片

轻松实现圆角图片 圆角图片需求很多,教程也很多,本篇博客记录一下实现的步骤,只需要大概几十行代码即可轻松实现。 实现步骤: 1,使用BitmapShader给画笔着色 2,绘制圆 效果图: 使用...

Picasso简单封装demo,实现圆角,圆形

  • 2016年07月29日 22:28
  • 24.81MB
  • 下载

Picasso实现圆形圆角相关类

  • 2017年04月24日 14:18
  • 6KB
  • 下载

毕加索的艺术——Picasso,一个强大的Android图片下载缓存库,OkHttpUtils的使用,二次封装PicassoUtils实现微信精选

毕加索的艺术——Picasso,一个强大的Android图片下载缓存库,OkHttpUtils的使用,二次封装PicassoUtils实现微信精选 官网: http://square.github.i...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Picasso轻松实现圆角图片
举报原因:
原因补充:

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