package com.hdl.photovoltaic.utils; import android.content.Context; import android.graphics.Bitmap; import android.graphics.BitmapFactory; 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 android.widget.ImageView; import androidx.core.graphics.drawable.RoundedBitmapDrawable; import androidx.core.graphics.drawable.RoundedBitmapDrawableFactory; import com.bumptech.glide.Glide; import com.bumptech.glide.load.resource.bitmap.CenterCrop; import com.bumptech.glide.load.resource.bitmap.CircleCrop; import com.bumptech.glide.load.resource.bitmap.GranularRoundedCorners; import com.bumptech.glide.load.resource.bitmap.RoundedCorners; import com.bumptech.glide.request.RequestOptions; import com.hdl.photovoltaic.R; import com.hdl.photovoltaic.other.HdlThreadLogic; import java.io.InputStream; import java.net.HttpURLConnection; import java.net.URL; /** * [Android]图片加载库Glide */ public class GlideUtils { /** * 标准图片 * * @param context 上下文 * @param url 图片地址 * @param imageview 显示图片组件 */ public static void getGeneralImage(Context context, String url, ImageView imageview) { Glide.with(context) .load(url) .apply(getRequestOptions()) .into(imageview); } /** * 图片四个角度单独指定 * * @param context 上下文 * @param url 图片地址 * @param imageview 显示图片组件 * @param granularRoundedCorners 设置图片角度 */ public static void getGranularRoundedCornersImage(Context context, String url, ImageView imageview, GranularRoundedCorners granularRoundedCorners) { Glide.with(context) .load(url) .apply(getRequestOptions()) .transform(granularRoundedCorners)//new GranularRoundedCorners(30f,80f,80f,30f) .into(imageview); } /** * 图片四个角统一指定 * * @param context 上下文 * @param url 图片地址 * @param imageview 显示图片组件 * @param roundedCorners 设置图片角度值 */ public static void getRoundedCornersImage(Context context, String url, ImageView imageview, RoundedCorners roundedCorners) { Glide.with(context) .load(url) .apply(getRequestOptions()) .transform(new CenterCrop(), roundedCorners)//Glide加载图片圆角效果与ImageView的ScaleType冲突问题 // .transform(roundedCorners) .into(imageview); } /** * 圆角 * * @param context 上下文 * @param url 图片地址 * @param imageview 显示图片组件 */ public static void getCircleCropImage(Context context, String url, ImageView imageview) { Glide.with(context) .load(url) .apply(getRequestOptions()) .transform(new CircleCrop()) .into(imageview); } private static RequestOptions getRequestOptions() { return new RequestOptions() .placeholder(R.drawable.default_user) .error(R.drawable.default_user) .fallback(R.drawable.default_user); // .override(113, 130); } /** * 设置图片 * * @param path 图片地址 * @param imageView 显示图片组件 * @param pixels 设置圆角值 */ public static void getImage(String path, ImageView imageView, int pixels) { HdlThreadLogic.runSubThread(new Runnable() { @Override public void run() { try { URL url = new URL(path); HttpURLConnection conn = (HttpURLConnection) url.openConnection(); conn.setConnectTimeout(3000); conn.setRequestMethod("GET"); if (conn.getResponseCode() == 200) { InputStream inStream = conn.getInputStream(); Bitmap bitmap = BitmapFactory.decodeStream(inStream); imageView.setImageBitmap(getRoundedCornerBitmap(bitmap,pixels)); } } catch (Exception e) { } } }, null, null); } /** * @param bitmap 需要修改的图片 * @param pixels 圆角的弧度 * @return 圆角图片 */ public static Bitmap getRoundedCornerBitmap(Bitmap bitmap, int pixels) { Bitmap output = Bitmap.createBitmap(bitmap.getWidth(), bitmap.getHeight(), Bitmap.Config.ARGB_8888); Canvas canvas = new Canvas(output); final int color = 0xff424242; final Paint paint = new Paint(); final Rect rect = new Rect(0, 0, bitmap.getWidth(), bitmap.getHeight()); final RectF rectF = new RectF(rect); final float roundPx = pixels; //防止锯齿 paint.setAntiAlias(true); //相当于清屏 canvas.drawARGB(0, 0, 0, 0); paint.setColor(color); //先画了一个带圆角的矩形 canvas.drawRoundRect(rectF, roundPx, roundPx, paint); paint.setXfermode(new PorterDuffXfermode(PorterDuff.Mode.SRC_IN)); //再把原来的bitmap画到现在的bitmap canvas.drawBitmap(bitmap, rect, rect, paint); return output; } }