1
我試圖沿着路徑從資源中重複一個圖像,如使用PathEffect
中的形狀完成的。下面是我有什麼和我想要實現的兩個圖像。沿着路徑繪製重複的圖像(平鋪)
- 我實現什麼用
PathDashPathEffect
倒三角形狀: Screenshot - 我想要的結果應該是這樣的: Desired
這裏是我的代碼:
import android.annotation.SuppressLint;
import android.content.Context;
import android.graphics.Bitmap;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.graphics.Path;
import android.graphics.PathDashPathEffect;
import android.graphics.PathEffect;
import android.util.AttributeSet;
import android.view.MotionEvent;
import android.view.View;
public class ImageLineView extends View {
private Paint mPaint;
private Bitmap mDrawingBitmap;
private Canvas mDrawingCanvas;
private Path mPath;
private Paint mBitmapPaint;
private static final int BACKGROUND_COLOR = Color.WHITE;
private static final int CENTER_STROKE_WIDTH = 10;
public ImageLineView(Context context) {
super(context);
initialize();
}
public ImageLineView(Context context, AttributeSet attrs) {
super(context, attrs);
initialize();
}
public ImageLineView(Context context, AttributeSet attrs, int defStyle) {
super(context, attrs, defStyle);
initialize();
}
@SuppressLint("NewApi")
public ImageLineView(Context context, AttributeSet attrs, int defStyleAttr, int defStyleRes) {
super(context, attrs, defStyleAttr, defStyleRes);
initialize();
}
private void initialize() {
mPath = new Path();
mBitmapPaint = new Paint(Paint.DITHER_FLAG);
mPaint = new Paint();
mPaint.setAntiAlias(true);
mPaint.setDither(true);
mPaint.setFilterBitmap(true);
mPaint.setColor(Color.RED);
mPaint.setStyle(Paint.Style.FILL_AND_STROKE);
mPaint.setStrokeJoin(Paint.Join.ROUND);
mPaint.setStrokeWidth(10);
mPaint.setStrokeCap(Paint.Cap.ROUND);
mPaint.setPathEffect(getTrianglePathEffect(CENTER_STROKE_WIDTH));
setLayerType(LAYER_TYPE_SOFTWARE, null);
}
@Override
protected void onSizeChanged(int w, int h, int oldw, int oldh) {
super.onSizeChanged(w, h, oldw, oldh);
// Foreground Bitmap
if (mDrawingBitmap == null) {
mDrawingBitmap = Bitmap.createBitmap(w, h, Bitmap.Config.ARGB_8888);
} else {
mDrawingBitmap = Bitmap.createScaledBitmap(mDrawingBitmap, w, h, false);
}
mDrawingCanvas = new Canvas(mDrawingBitmap);
drawInitialView();
}
@Override
protected void onDraw(Canvas canvas) {
canvas.drawBitmap(mDrawingBitmap, 0, 0, mBitmapPaint);
}
private void drawInitialView() {
mDrawingCanvas.drawColor(BACKGROUND_COLOR);
}
private void touchDraw(float x, float y) {
mDrawingCanvas.drawColor(BACKGROUND_COLOR);
mPath.reset();
mPath.moveTo(x, y);
int canvasWidth = mDrawingCanvas.getWidth();
int canvasHeight = mDrawingCanvas.getHeight();
mPath.moveTo(x,y);
mPath.lineTo(0,0);
mPath.moveTo(x,y);
mPath.lineTo(0,canvasHeight);
mPath.moveTo(x,y);
mPath.lineTo(canvasWidth,0);
mPath.moveTo(x,y);
mPath.lineTo(canvasWidth,canvasHeight);
mDrawingCanvas.drawPath(mPath, mPaint);
mPath.reset();
}
private PathEffect getTrianglePathEffect(int strokeWidth) {
return new PathDashPathEffect(
getTriangle(strokeWidth),
strokeWidth,
0.0f,
PathDashPathEffect.Style.ROTATE);
}
private Path getTriangle(float size) {
Path path = new Path();
float half = size/2;
path.moveTo(-half, -half);
path.lineTo(half, -half);
path.lineTo(0, half);
path.close();
return path;
}
private void touchDown(float x, float y) {
touchDraw(x, y);
}
private void touchMove(float x, float y) {
touchDraw(x, y);
}
private void touchUp() {
resetCanvas();
}
private void resetCanvas() {
drawInitialView();
}
@SuppressLint("ClickableViewAccessibility")
@Override
public boolean onTouchEvent(MotionEvent event) {
float x = event.getX();
float y = event.getY();
int motionAction = event.getAction();
switch (motionAction) {
case MotionEvent.ACTION_DOWN:
touchDown(x, y);
invalidate();
break;
case MotionEvent.ACTION_MOVE:
touchMove(x, y);
invalidate();
break;
case MotionEvent.ACTION_UP:
touchUp();
invalidate();
break;
default:
break;
}
return true;
}
}
能否請你澄清我如何使用這個代碼來解決我的問題呢?謝謝。 – MohanadMohie