android 特效绘图,android绘图Path类仿加速球水面波动效果

本文通过示例展示了如何使用Android的Path类绘制三角形和贝塞尔曲线,并创建了一个自定义View `MyPathView` 实现了类似水波纹的动态效果。主要涉及的技术包括Path的moveTo、lineTo、quadTo方法,以及Canvas的drawPath和drawRect等绘制方法,结合Handler实现定时刷新来达到动画效果。
摘要由CSDN通过智能技术生成

android提供的Path类,他可以预先在View上连成路径,然后调用Canvas的drawPath(path,paint),沿着路径画出来即可;

【1】画三角形

// path.moveTo(100, 100);

// path.lineTo(0, 200);

// path.lineTo(200, 200);

// path.close();//连接首尾

// canvas.drawPath(path, paint);

// canvas.drawTextOnPath(我沿着这条线走, path, 0, 0, paint);

【画贝塞尔曲线】

//贝塞尔曲线

// path.moveTo(100,100);

// path.quadTo(100, 400, 300, 300);//两个点:控制点;结束点

// canvas.drawPath(path, paint);

//canvas.drawPoint(100, 100, paintPoint);

//canvas.drawPoint(100,400,paintPoint);

//canvas.drawPoint(300,300,paintPoint);

【仿水边波动效果】

217370_0.gif

public class MyPathView extends View {

private Paint paint;

private Path path;

private Paint paintPoint;

private int width;

private int height;

private int count = 0;

private int size = 0;

private boolean isAdd=true;

private Handler handler = new Handler() {

@Override

public void handleMessage(Message msg) {

super.handleMessage(msg);

switch (msg.what){

case 0x23:

count+=5;

if(count>=80){

count=0;

}

if (isAdd){

size++;

if(size>10){

isAdd = false;

}

}else{

size--;

if(size<=-10){

isAdd =true;

}

}

invalidate();

sendEmptyMessageDelayed(0x23,100);

break;

}

}

};

public MyPathView(Context context, AttributeSet attrs) {

super(context, attrs);

paint = new Paint();

paint.setAntiAlias(true);

paint.setTextSize(30);

paint.setStyle(Paint.Style.STROKE);

paintPoint = new Paint();

paintPoint.setStrokeWidth(10);

paintPoint.setColor(Color.GREEN);

paintPoint.setStyle(Paint.Style.FILL);

path = new Path();

handler.sendEmptyMessageDelayed(0x23, 1000);

}

@Override

protected void onDraw(Canvas canvas) {

super.onDraw(canvas);

path.reset();

path.moveTo(count, 100);

for (int i = 0; i < 10; i++) {

path.rQuadTo(20, 20, 40, 0);

path.rQuadTo(20, -20, 40, 0);

}

canvas.drawPath(path, paint);

canvas.drawRect(200, 0, 400, 200, paint);

}

protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {

super.onMeasure(widthMeasureSpec, heightMeasureSpec);

width = getDefaultSize(getSuggestedMinimumWidth(), widthMeasureSpec);

height = getDefaultSize(getSuggestedMinimumHeight(), heightMeasureSpec);

setMeasuredDimension(width, height);

}

}

布局

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值