android圖片處理,讓圖片變成圓形
這幾天做專案,有些地方的圖片需要用到圓形圖片,所以百度了一下,在github上找到一個開源專案,處理很簡單,效果如下:
使用起來特別簡單,一共三步,具體如下:
1,建立一個Java類CircleImageView把下面的程式碼複製過去,報錯的導包
-
package de.hdodenhof.circleimageview;
-
import edu.njupt.zhb.main.R;
-
import android.content.Context;
-
import android.content.res.TypedArray;
-
import android.graphics.Bitmap;
-
import android.graphics.BitmapShader;
-
import android.graphics.Canvas;
-
import android.graphics.Color;
-
import android.graphics.Matrix;
-
import android.graphics.Paint;
-
import android.graphics.RectF;
-
import android.graphics.Shader;
-
import android.graphics.drawable.BitmapDrawable;
-
import android.graphics.drawable.ColorDrawable;
-
import android.graphics.drawable.Drawable;
-
import android.util.AttributeSet;
-
import android.widget.ImageView;
-
public class CircleImageView extends ImageView {
-
private static final ScaleType SCALE_TYPE = ScaleType.CENTER_CROP;
-
private static final Bitmap.Config BITMAP_CONFIG = Bitmap.Config.ARGB_8888;
-
private static final int COLORDRAWABLE_DIMENSION = 1;
-
private static final int DEFAULT_BORDER_WIDTH = 0;
-
private static final int DEFAULT_BORDER_COLOR = Color.BLACK;
-
private final RectF mDrawableRect = new RectF();
-
private final RectF mBorderRect = new RectF();
-
private final Matrix mShaderMatrix = new Matrix();
-
private final Paint mBitmapPaint = new Paint();
-
private final Paint mBorderPaint = new Paint();
-
private int mBorderColor = DEFAULT_BORDER_COLOR;
-
private int mBorderWidth = DEFAULT_BORDER_WIDTH;
-
private Bitmap mBitmap;
-
private BitmapShader mBitmapShader;
-
private int mBitmapWidth;
-
private int mBitmapHeight;
-
private float mDrawableRadius;
-
private float mBorderRadius;
-
private boolean mReady;
-
private boolean mSetupPending;
-
public CircleImageView(Context context) {
-
super(context);
-
}
-
public CircleImageView(Context context, AttributeSet attrs) {
-
this(context, attrs, 0);
-
}
-
public CircleImageView(Context context, AttributeSet attrs, int defStyle) {
-
super(context, attrs, defStyle);
-
super.setScaleType(SCALE_TYPE);
-
TypedArray a = context.obtainStyledAttributes(attrs, R.styleable.CircleImageView, defStyle, 0);
-
mBorderWidth = a.getDimensionPixelSize(R.styleable.CircleImageView_border_width, DEFAULT_BORDER_WIDTH);
-
mBorderColor = a.getColor(R.styleable.CircleImageView_border_color, DEFAULT_BORDER_COLOR);
-
a.recycle();
-
mReady = true;
-
if (mSetupPending) {
-
setup();
-
mSetupPending = false;
-
}
-
}
-
@Override
-
public ScaleType getScaleType() {
-
return SCALE_TYPE;
-
}
-
@Override
-
public void setScaleType(ScaleType scaleType) {
-
if (scaleType != SCALE_TYPE) {
-
throw new IllegalArgumentException(String.format("ScaleType %s not supported.", scaleType));
-
}
-
}
-
@Override
-
protected void onDraw(Canvas canvas) {
-
if (getDrawable() == null) {
-
return;
-
}
-
canvas.drawCircle(getWidth() / 2, getHeight() / 2, mDrawableRadius, mBitmapPaint);
-
canvas.drawCircle(getWidth() / 2, getHeight() / 2, mBorderRadius, mBorderPaint);
-
}
-
@Override
-
protected void onSizeChanged(int w, int h, int oldw, int oldh) {
-
super.onSizeChanged(w, h, oldw, oldh);
-
setup();
-
}
-
public int getBorderColor() {
-
return mBorderColor;
-
}
-
public void setBorderColor(int borderColor) {
-
if (borderColor == mBorderColor) {
-
return;
-
}
-
mBorderColor = borderColor;
-
mBorderPaint.setColor(mBorderColor);
-
invalidate();
-
}
-
public int getBorderWidth() {
-
return mBorderWidth;
-
}
-
public void setBorderWidth(int borderWidth) {
-
if (borderWidth == mBorderWidth) {
-
return;
-
}
-
mBorderWidth = borderWidth;
-
setup();
-
}
-
@Override
-
public void setImageBitmap(Bitmap bm) {
-
super.setImageBitmap(bm);
-
mBitmap = bm;
-
setup();
-
}
-
@Override
-
public void setImageDrawable(Drawable drawable) {
-
super.setImageDrawable(drawable);
-
mBitmap = getBitmapFromDrawable(drawable);
-
setup();
-
}
-
@Override
-
public void setImageResource(int resId) {
-
super.setImageResource(resId);
-
mBitmap = getBitmapFromDrawable(getDrawable());
-
setup();
-
}
-
private Bitmap getBitmapFromDrawable(Drawable drawable) {
-
if (drawable == null) {
-
return null;
-
}
-
if (drawable instanceof BitmapDrawable) {
-
return ((BitmapDrawable) drawable).getBitmap();
-
}
-
try {
-
Bitmap bitmap;
-
if (drawable instanceof ColorDrawable) {
-
bitmap = Bitmap.createBitmap(COLORDRAWABLE_DIMENSION, COLORDRAWABLE_DIMENSION, BITMAP_CONFIG);
-
} else {
-
bitmap = Bitmap.createBitmap(drawable.getIntrinsicWidth(), drawable.getIntrinsicHeight(), BITMAP_CONFIG);
-
}
-
Canvas canvas = new Canvas(bitmap);
-
drawable.setBounds(0, 0, canvas.getWidth(), canvas.getHeight());
-
drawable.draw(canvas);
-
return bitmap;
-
} catch (OutOfMemoryError e) {
-
return null;
-
}
-
}
-
private void setup() {
-
if (!mReady) {
-
mSetupPending = true;
-
return;
-
}
-
if (mBitmap == null) {
-
return;
-
}
-
mBitmapShader = new BitmapShader(mBitmap, Shader.TileMode.CLAMP, Shader.TileMode.CLAMP);
-
mBitmapPaint.setAntiAlias(true);
-
mBitmapPaint.setShader(mBitmapShader);
-
mBorderPaint.setStyle(Paint.Style.STROKE);
-
mBorderPaint.setAntiAlias(true);
-
mBorderPaint.setColor(mBorderColor);
-
mBorderPaint.setStrokeWidth(mBorderWidth);
-
mBitmapHeight = mBitmap.getHeight();
-
mBitmapWidth = mBitmap.getWidth();
-
mBorderRect.set(0, 0, getWidth(), getHeight());
-
mBorderRadius = Math.min((mBorderRect.height() - mBorderWidth) / 2, (mBorderRect.width() - mBorderWidth) / 2);
-
mDrawableRect.set(mBorderWidth, mBorderWidth, mBorderRect.width() - mBorderWidth, mBorderRect.height() - mBorderWidth);
-
mDrawableRadius = Math.min(mDrawableRect.height() / 2, mDrawableRect.width() / 2);
-
updateShaderMatrix();
-
invalidate();
-
}
-
private void updateShaderMatrix() {
-
float scale;
-
float dx = 0;
-
float dy = 0;
-
mShaderMatrix.set(null);
-
if (mBitmapWidth * mDrawableRect.height() > mDrawableRect.width() * mBitmapHeight) {
-
scale = mDrawableRect.height() / (float) mBitmapHeight;
-
dx = (mDrawableRect.width() - mBitmapWidth * scale) * 0.5f;
-
} else {
-
scale = mDrawableRect.width() / (float) mBitmapWidth;
-
dy = (mDrawableRect.height() - mBitmapHeight * scale) * 0.5f;
-
}
-
mShaderMatrix.setScale(scale, scale);
-
mShaderMatrix.postTranslate((int) (dx + 0.5f) + mBorderWidth, (int) (dy + 0.5f) + mBorderWidth);
-
mBitmapShader.setLocalMatrix(mShaderMatrix);
-
}
-
}
2,在values資料夾下面建立一個xlm檔案attrs.xml把下面的程式碼複製進去
-
<?xml version="1.0" encoding="utf-8"?>
-
<resources>
-
<declare-styleable name="CircleImageView">
-
<attr name="border_width" format="dimension" />
-
<attr name="border_color" format="color" />
-
</declare-styleable>
-
</resources>
3,接下來就是使用了,直接在佈局檔案中使用,具體使用如下:
直接建立一個自定義的CircleImageView src屬性設定你要改變成圓形的圖片
-
<RelativeLayout 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:background="#ff00ff"
-
>
-
<com.example.circleimageview.CircleImageView
-
android:id="@+id/imageview"
-
android:layout_width="100dp"
-
android:layout_height="100dp"
-
android:layout_centerInParent="true"
-
android:src="@drawable/control_image"
-
/>
-
</RelativeLayout>
就是這麼簡單,希望對大家有用
demo的地址:http://download.csdn.net/detail/dl10210950/9600196
相關文章
- CGContextRef處理圓形圖片GCContext
- Glide實現圓角圖片,以及圓形圖片IDE
- CSS圓形圖片效果CSS
- 微信小程式裁剪圖片成圓形微信小程式
- Android自定義View之圖片外形特效——輕鬆實現圓角和圓形圖片AndroidView特效
- 微信小程式之裁剪圖片成圓形微信小程式
- 圖片上傳及圖片處理
- 002.00 圖片處理
- Thumbnailator處理圖片AI
- 【YLCircleImageView】圖片處理View
- webpack圖片處理Web
- Android中圖片圓形設定三種方法介紹Android
- DDGScreenShot —iOS 圖片處理--多圖片拼接 (swift)iOSSwift
- Android 載入網路圖片 以及實現圓角圖片效果Android
- 直播原始碼網站,js處理圖片變形、方向、壓縮等原始碼網站JS
- SwiftUI Image 圖片處理SwiftUI
- webpack 圖片處理 loaderWeb
- Python批量處理圖片Python
- Android中OpenGL濾鏡和RenderScript圖片處理Android
- SwiftUI圖片處理(縮放、拼圖)SwiftUI
- 處理圖片流資料
- java thumbnailator 做圖片處理JavaAI
- OpenCv--圖片處理操作OpenCV
- java 圖片水印處理類Java
- JavaScript WebGL 圖片透明處理JavaScriptWeb
- webpack(6)webpack處理圖片Web
- Golang 圖片處理 — image 庫Golang
- photoshop常用圖片處理技巧
- 圖片編輯工具:FotoJet Photo Editor更好的處理圖片
- 圖形影像處理之簡單圖片
- Laravel 使用 Intervention/image 處理圖片Laravel
- Photoshop類圖片處理軟體
- 002.01 圖片去外框處理
- 002.00 圖片處理 PIL.Image
- 圖片展示 [ Numpy 處理, Matplotlib 展示 ]
- 如何處理 Web 圖片優化?Web優化
- 分享一個圖片處理類
- 圖片區域點選處理