Android Path.quadTo() 方法绘制二次贝塞尔曲线

在 Android 中,可以使用 Path.quadTo() 方法绘制二次贝塞尔曲线。二次贝塞尔曲线由一个起点、一个控制点和一个终点来定义。控制点控制曲线的形状。

以下是一个示例代码,演示了如何在 Canvas 上使用 Path.quadTo() 方法绘制一个二次贝塞尔曲线:

复制代码
import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.graphics.Path;
import android.view.View;

public class MyView extends View {
    private Paint paint;
    private Path path;

    public MyView(Context context) {
        super(context);
        paint = new Paint();
        paint.setColor(Color.RED);
        paint.setStrokeWidth(5);
        paint.setStyle(Paint.Style.STROKE);

        path = new Path();
        path.moveTo(100, 100);
        path.quadTo(200, 50, 300, 100);
    }

    @Override
    protected void onDraw(Canvas canvas) {
        super.onDraw(canvas);
        canvas.drawPath(path, paint);
    }
}

在上面的代码中,我们创建了一个自定义的 View,并在构造函数中初始化了画笔和路径。我们使用 Path.moveTo() 方法将当前点移动到起始点 (100, 100),然后使用 Path.quadTo() 方法绘制了一条二次贝塞尔曲线,控制点的坐标为 (200, 50),终点的坐标为 (300, 100)。

然后我们重写了 onDraw() 方法,在其中使用 Canvas 的 drawPath() 方法绘制了路径。由于我们使用了空心画笔,因此只绘制了曲线的轮廓。

相关推荐
风起云涌~18 小时前
【Android】浅谈Navigation
android
游戏开发爱好者818 小时前
iOS 商店上架全流程解析 从工程准备到审核通过的系统化实践指南
android·macos·ios·小程序·uni-app·cocoa·iphone
QuantumLeap丶20 小时前
《Flutter全栈开发实战指南:从零到高级》- 18 -自定义绘制与画布
android·flutter·ios
.豆鲨包20 小时前
【Android】 View事件分发机制源码分析
android·java
花落归零21 小时前
Android 小组件AppWidgetProvider的使用
android
弥巷21 小时前
【Android】常见滑动冲突场景及解决方案
android·java
angushine21 小时前
解决MySQL慢日志输出问题
android·数据库·mysql
fouryears_2341721 小时前
Android 与 Flutter 通信最佳实践 - 以分享功能为例
android·flutter·客户端·dart
成都大菠萝1 天前
Android ANR
android
Ryan ZHENG1 天前
[Android][踩坑]Android Studio导入core-libart.jar
android·android studio·jar