首页 > 其他 > 详细

canvas_05 贝塞尔曲线

时间:2021-09-11 15:27:42      阅读:20      评论:0      收藏:0      [点我收藏+]

技术分享图片

 

 

<template>
    <view class="zcvs">

        <view class="zcvs-item">
            <view>04_贝塞尔曲线</view>
            <view>
                <canvas class="zcvs-cvs" canvas-id="cvs" id="cvs" />
            </view>
        </view>

    </view>
</template>

<script>
    export default {
        data() {
            return {

            };
        },
        onReady() {
            this.drawCvs();
        },
        methods: {
            drawCvs() {
                const ctx = uni.createCanvasContext(cvs);
                ctx.setLineWidth(10);
                ctx.setStrokeStyle("#007AFF");
                ctx.setFillStyle("#DD524D");

                // 贝塞尔曲线
                ctx.beginPath();
                ctx.moveTo(50, 180);
                ctx.bezierCurveTo(41, 40, 332, 40, 325, 180)
                ctx.stroke();

                // 起始点
                ctx.beginPath();
                ctx.arc(50, 180, 5, 0, 2 * Math.PI, false);
                ctx.fill();

                // 控制点1
                ctx.beginPath();
                ctx.arc(41, 40, 5, 0, 2 * Math.PI, false);
                ctx.fill();

                // 控制点2
                ctx.beginPath();
                ctx.arc(332, 40, 5, 0, 2 * Math.PI, false);
                ctx.fill();

                // 终点
                ctx.beginPath();
                ctx.arc(325, 180, 5, 0, 2 * Math.PI, false);
                ctx.fill();

                // 控制点连线
                ctx.beginPath();
                ctx.setStrokeStyle("#DD524D");
                ctx.setLineWidth(2);
                ctx.moveTo(50, 180);
                ctx.lineTo(41, 40);
                ctx.lineTo(332, 40);
                ctx.lineTo(325, 180);
                ctx.stroke();

                // 起点与控制点1 中点
                ctx.beginPath();
                ctx.setFillStyle("#4CD964");
                ctx.arc(46, 115, 5, 0, 2 * Math.PI, false);
                ctx.fill();

                // 控制点1与控制点2 中点
                ctx.beginPath();
                ctx.setFillStyle("#4CD964");
                ctx.arc(188, 40, 5, 0, 2 * Math.PI, false);
                ctx.fill();

                // 控制点2与终点 中点
                ctx.beginPath();
                ctx.setFillStyle("#4CD964");
                ctx.arc(330, 118, 5, 0, 2 * Math.PI, false);
                ctx.fill();

                // 中点 连线
                ctx.beginPath();
                ctx.setStrokeStyle("#F0AD4E")
                ctx.setLineWidth(5);
                ctx.setLineCap("butt");
                ctx.moveTo(46, 115);
                ctx.lineTo(188, 40);
                ctx.lineTo(330, 118);
                ctx.stroke();

                ctx.draw();
            },
        }
    }
</script>

<style lang="scss" scoped>
    .zcvs {

        .zcvs-item {
            margin-bottom: 40upx;
        }

        .zcvs-cvs {
            border: 1px solid #eee;
            height: 500upx;
            width: 100%;
            box-sizing: border-box;
        }
    }
</style>

 

canvas_05 贝塞尔曲线

原文:https://www.cnblogs.com/luwei0915/p/15250824.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!