JS如何实现圆形进度条拖拽滑动

技术JS如何实现圆形进度条拖拽滑动JS如何实现圆形进度条拖拽滑动,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。效果展示半圆进度条效果圆形进度

射流研究…如何实现圆形进度条拖拽滑动,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。

效果展示

半圆进度条效果

JS如何实现圆形进度条拖拽滑动

圆形进度条

JS如何实现圆形进度条拖拽滑动

代码实现

!doctypehtml

htmllang='en '

metachartset=' UTF-8 '/

meta http-equiv=' X-UA-Compatible '内容=' IE=edge,chrome=1'/

标题圆形进度条拖拽滑动/title

/head

身体

canvasId=' canvasId '宽度=' 400 '高度=' 400 '/canvasId

scripttype='text/javascript '

var canvas=文档。getelementbyid(' canvasId ');

varctx=画布。get context(' 2d ');

varox=200

varoy=200

varor=180

varbr=15

varmoveFlag=false

functionoffset(r,d){//根据弧度与距离计算偏移坐标

返回{x:-Math.sin(r)*d,y : ath。cos(r)* d };

};

函数绘图(n){ 0

ctx.clearRect(0,0,canvas.width,canvas。高度);

ctx.strokeStyle=' # 99a

CTX。线宽=5;

CTX。begin path();

ctx.arc(ox,oy,or,0,Math .PI,真);//半圆

//ctx.arc(ox,oy,or,0,2*Math .PI,真);//整圆

CTX。笔画();

ctx.strokeStyle=' # 69f

    ctx.lineWidth = 5;
        ctx.beginPath();
        ctx.arc(ox,oy,or,Math.PI,(n*2+0.5)*Math.PI,false);
        // ctx.arc(ox,oy,or,0.5*Math.PI,(n*2+0.5)*Math.PI,false);
        ctx.stroke();
        ctx.fillStyle = "#69f";
        ctx.font = "80px Arial";
        ctx.textAlign = "center";
        ctx.textBaseline = "middle";
        ctx.fillText(Math.round(n*100-25)+"%",ox,oy);
        ctx.fillStyle = "#00f";
        ctx.beginPath();
        var d =  offset(n*2*Math.PI,or);
        ctx.arc(ox+d.x,oy+d.y,br,0,2*Math.PI,true);
        ctx.fill();
    }
    var on = ("ontouchstart" in document)? {
        start: "touchstart", move: "touchmove", end: "touchend"
    } : {
        start: "mousedown", move: "mousemove", end: "mouseup"
    };
    function getXY(e,obj) {
        var et = e.touches? e.touches[0] : e;
        var x = et.clientX;
        var y = et.clientY;
        return {
            x : x - obj.offsetLeft + (document.body.scrollLeft || document.documentElement.scrollLeft),
            y : y - obj.offsetTop  + (document.body.scrollTop || document.documentElement.scrollTop)
        }
    }
    canvas.addEventListener(on.start, function(e) {
        moveFlag = true;
    }, false);
    canvas.addEventListener(on.move, function(e) {
        if (moveFlag) {
            var k = getXY(e,canvas);
            var r = Math.atan2(k.x-ox, oy-k.y);
            var hd = (Math.PI+r)/(2*Math.PI);
            // 半圆的滑动范围判断
            if (hd <= 0.75 && hd >= 0.25) {
                draw(hd);
            }
        }
    }, false);
    canvas.addEventListener(on.end, function(e) {
        moveFlag = false;
    }, false);
    draw(0.25);
</script>
</body>
</html>

看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注行业资讯频道,感谢您对的支持。

内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/37086.html

(0)

相关推荐

  • 区块链需要学javascript吗(javascript编写区块链)

    技术如何用JS构建你自己的区块链如何用JS构建你自己的区块链,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。前言区块链太复杂,那我们就讲点简单的。用JS来

    攻略 2021年12月14日
  • http协议安全性分析总结(http网络通信报文实时解析)

    技术HTTP协议消息头的示例代码这篇文章主要介绍HTTP协议消息头的示例代码,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!host=gray-scp-getway.9fbank.com
    x-rea

    攻略 2021年12月14日
  • Spring Data JPA怎么使用QueryDsl查询并分页

    技术Spring Data JPA怎么使用QueryDsl查询并分页小编给大家分享一下Spring Data JPA怎么使用QueryDsl查询并分页,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!Spr

    攻略 2021年11月21日
  • 平形四边形,问平形四边形的面积是多少

    技术平形四边形,问平形四边形的面积是多少直角三角形面积=8*6/2=24平方厘米平形四边形和直角三角形重叠后形成平形四边形左一个三角形和右一个三角形平形四边形,说明平行四边形向右倾斜。这两个三角形加上重叠部分是平行四边形

    生活 2021年10月27日
  • 色彩斑斓造句,小学二年级五颜六色造句

    技术色彩斑斓造句,小学二年级五颜六色造句五颜六色的花朵点缀在茂盛的牧草间色彩斑斓造句。他们将房子漆得五颜六色。  不曾料想,这个季节最先盛开的花竟是雨伞,一朵朵摇曳着,像五颜六色的合欢。  它全身有五颜六色的羽毛。  我

    生活 2021年10月22日
  • 使用了索引查询还是慢的原因是什么

    技术使用了索引查询还是慢的原因是什么本篇内容介绍了“使用了索引查询还是慢的原因是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够

    攻略 2021年10月22日