当前位置:首页 » 《休闲阅读》 » 正文

fabric.js 画圆环,圆弧,弧形区域_T甲甲T的博客

18 人参与  2022年02月15日 17:23  分类 : 《休闲阅读》  评论

点击全文阅读


<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="./fabric.js"></script>
    <style>
        button {
            margin: 10px 0 0 10px;

        }
    </style>
</head>

<body>
    <div style="display: flex;">
        <canvas id='c' width="1000" height="1000"></canvas>
        <div>
            <button class="btn1">画</button>
            <button class="btn2">儿子</button>
        </div>
    </div>

    <script>
        var canvas = new fabric.Canvas('c', {
            backgroundColor: '#ccc',
            selectionColor: 'white',
            selectionLineWidth: 2,
            selectionBorderColor: 'red',
            borderColor: 'red'
        });
        function addRing(angle1, angle2, x, y, r1, r2) {
            let point1 = {};
            let point2 = {};
            let point3 = {};
            let point4 = {};
            let isBig = 0
            angle1 = angle1 % 360;
            angle2 = angle2 % 360;
            if (angle2 > 180) {
                isBig = 1
            }
            if (!angle2) {
                point1.x = r1 + x;
                point1.y = y;
                point2.x = r2 + x;
                point2.y = y;
                var path = new fabric.Path(`M${point1.x},${point1.y} A${r1},${r1} 0 0,1 ${point1.x - 2 * r1},${point1.y} 
                A${r1},${r1} 0 0,1 ${point1.x},${point1.y} 
                M${point2.x},${point2.y} A${r2},${r2} 0 0,1 ${point2.x - 2 * r2},${point2.y} 
                A${r2},${r2} 0 0,1 ${point2.x},${point2.y}`, {
                    stroke: 'red',
                    fill: 'transparent',
                    hasControls: false
                })
            } else {
                point1.x = r1 * Math.cos(angle1 / 180 * Math.PI) + x;
                point1.y = r1 * Math.sin(angle1 / 180 * Math.PI) + y;
                point2.x = r2 * Math.cos(angle1 / 180 * Math.PI) + x;
                point2.y = r2 * Math.sin(angle1 / 180 * Math.PI) + y;
                point3.x = r2 * Math.cos((angle1 + angle2) / 180 * Math.PI) + x;
                point3.y = r2 * Math.sin((angle1 + angle2) / 180 * Math.PI) + y;
                point4.x = r1 * Math.cos((angle1 + angle2) / 180 * Math.PI) + x;
                point4.y = r1 * Math.sin((angle1 + angle2) / 180 * Math.PI) + y;
                var path = new fabric.Path(`M${point1.x},${point1.y} L${point2.x},${point2.y} A${r2},${r2} 0 ${isBig},1 ${point3.x},${point3.y} L${point4.x},${point4.y} A${r1},${r1} 0 ${isBig},0 ${point1.x},${point1.y}`, {
                    stroke: 'red',
                    fill: 'transparent',
                    // hasControls: false
                })
            }
            // path.parmas={
            //     angle1, angle2, x, y, r1, r2
            // }
            // canvas.loadFromJSON({
            //     objects:[ path.toJSON()]
            // })
           
            canvas.add(path)
            
            //  canvas.add( fabric.fromObject(path.toJSON()))  
        }
      
       
        addRing(0, 300, 400, 200, 30, 60);
        addRing(0, 360, 200, 200, 30, 60);
        addRing(0, 280, 600, 200, 60, 60)
       

    </script>
</body>

</html>

addPath 参数说明 angle1, angle2, x, y, r1, r2 分别对应 偏转角度,弧形区域的角度,x,y是圆心,r1小圆半径,r2大圆半径。

fabric.js我是引用的本地的文件,记得修改路径。

效果图


点击全文阅读


本文链接:http://zhangshiyu.com/post/34821.html

半径  小圆  我是  
<< 上一篇 下一篇 >>

  • 评论(0)
  • 赞助本站

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

最新文章

  • 我在回忆里万劫不复优质(秦见鹿谢梵声)_我在回忆里万劫不复优质秦见鹿谢梵声
  • 完结文我在回忆里万劫不复完结+番外列表_完结文我在回忆里万劫不复完结+番外(秦见鹿谢梵声)
  • 爱你是判决无期全文完结版阅读_[宋曦语裴时域林安安]人物羁绊章节精选
  • 画地为牢宝藏文(池念谢宴清)全书浏览_画地为牢宝藏文全书浏览
  • 画地为牢全书+后续+番外(池念谢宴清)列表_画地为牢全书+后续+番外(池念谢宴清)全书+后续+结局在线
  • 「我送卿归去,爱恨不由己」全文完结版阅读_「萧盈孟天楚孟天衡」小说后续在线免费阅读
  • 「重生后手撕职业打假的表妹」剧情悬念章节分段解锁_林婉路过原谅完结版全文
  • (番外)+(全书)沈昭宜傅沉砚(填我十万八千梦+结局+番外)全书在线_沈昭宜傅沉砚免费列表_笔趣阁(填我十万八千梦+结局+番外)
  • (长恨歌全书+后续+结局)人气书荒必读(宋可卿谢景御)_(长恨歌全书+后续+结局)列表_笔趣阁(宋可卿谢景御)
  • 宋思予沈淮霆(往梦难复温+后续+结局)结局_(宋思予沈淮霆往梦难复温+后续+结局全书结局)结局列表_笔趣阁(宋思予沈淮霆)
  • 秦见鹿谢梵声秦见鹿谢梵声全书+后续+结局列表_笔趣阁(秦见鹿谢梵声全书+后续+结局秦见鹿谢梵声)
  • 你是我未拆的遗书结局+番外(桑年裴谨言)全书桑年裴谨言结局_桑年裴谨言+结局列表_笔趣阁(你是我未拆的遗书结局+番外)

    关于我们 | 我要投稿 | 免责申明

    Copyright © 2020-2022 ZhangShiYu.com Rights Reserved.豫ICP备2022013469号-1