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() 方法绘制了路径。由于我们使用了空心画笔,因此只绘制了曲线的轮廓。

相关推荐
恋猫de小郭12 分钟前
KMP / CMP 鸿蒙版本 Beta 发布,他有什么特别之处?
android·前端·flutter
三少爷的鞋1 小时前
Android 协程并发控制:别动线程池,控制好并发语义就够了
android
触底反弹17 小时前
🚀 手把手用 HTML5 Canvas 从零打造飞机大战游戏,代码全开源!
前端·javascript·canvas
weiggle17 小时前
第七篇:状态提升与单向数据流——架构设计的核心
android
xingpanvip17 小时前
星盘接口开发文档:本命盘接口指南
android·开发语言·css·php·lua
goldenrolan17 小时前
A公司物料替代测试系统 v1.7:从需求到 exe/apk 的 AI 辅助全链路实践
android·自动化测试·软件测试·python·ai
AC赳赳老秦19 小时前
用 OpenClaw 搭建服务器故障应急响应系统,自动处理 80% 常见运维故障
android·运维·服务器·python·rxjava·deepseek·openclaw
骇客之技术20 小时前
AutoLua:在安卓上写 Lua 脚本
android·junit·lua
kiros_wang21 小时前
Android 常见面试题
android
货拉拉技术21 小时前
Hook植入日志协助定位问题方案
android