javascript - 如何使用 Canvas 创建辐射线?

标签 javascript canvas

我正在尝试使用 Canvas 或 SVG 创建这样的仪表。我想我会使用 Canvas,除非人们认为使用 SVG 制作会容易得多。我的问题是,使用 Canvas 而不使用图像,您将如何处理,或者是否可以在仪表外部创建虚线。

enter image description here

谢谢

最佳答案

如果您的规范不断变化,Canvas 将是一个不错的选择。

Canvas 擅长快速重绘。

SVG 重绘速度不那么快,但如果需要用户交互性,它就很好。

enter image description here

此 Canvas 函数将在内圆和外圆之间绘制辐射线:

function radiantLine(centerX,centerY,innerRadius,outerRadius,degrees,linewidth,color){

    var radians=degrees*Math.PI/180;
    var innerX = centerX + innerRadius * Math.cos(radians);
    var innerY = centerY + innerRadius * Math.sin(radians);
    var outerX = centerX + outerRadius * Math.cos(radians);
    var outerY = centerY + outerRadius * Math.sin(radians);

    ctx.beginPath();
    ctx.moveTo(innerX,innerY);
    ctx.lineTo(outerX,outerY);
    ctx.strokeStyle=color;
    ctx.lineWidth=linewidth;
    ctx.stroke();

}

您的仪表的值范围为 0-1000。

下面的代码可用于将 (0-1000) 范围内的值映射到仪表弧度 (0-270) 上。

// scale the guage values (0-1000) is mapped
// into the range of a partial circle (0-270 degree arc)
// value==0 is mapped to 0 degrees on the arc
// value==1000 is mapped to 270 degrees on the arc
var scaledValue=scaleIntoRange(0,1000,0,270,value);


function scaleIntoRange(minActual,maxActual,minRange,maxRange,value){
  var scaled=(maxRange-minRange)*(value-minRange)/(maxActual-minActual)+minRange;
  return(scaled);
}

将传入值映射到圆上的度数后,您将旋转 135 度以匹配量规上的起始 Angular (量规上的 0 度约为圆上的 135 度)

// rotate so guage value==0 starts at 135 degrees on the circle
var degrees=scaledValue+135;

这是代码和 fiddle :http://jsfiddle.net/m1erickson/GV8du/

<!doctype html>
<html>
<head>
<link rel="stylesheet" type="text/css" media="all" href="css/reset.css" /> <!-- reset css -->
<script type="text/javascript" src="http://code.jquery.com/jquery.min.js"></script>

<style>
    body{ background-color: ivory; }
    canvas{border:1px solid red;}
</style>

<script>
$(function(){

    var canvas=document.getElementById("canvas");
    var ctx=canvas.getContext("2d");

    var cx=150;
    var cy=150;
    var innerRadius=50;
    var outerRadius=65;
    var startRadians=135*Math.PI/180;
    var endRadians=405*Math.PI/180;


    for(var value=0;value<=1000;value+=25){

        // scale the guage values (0-1000) 
        // to fit into the range of a partial circle (0-270 degrees)
        var scaledValue=scaleIntoRange(0,1000,0,270,value);
        // rotate so guageValue==0 starts at 135 degrees on the circle
        var degrees=scaledValue+135;

        // draw the radiant line
        // draw thicker/longer line every 250
        if(value%250==0){
            radiantLine(cx,cy,innerRadius,outerRadius,degrees,2,"black");
        }else{
            var shorterLine=(outerRadius-innerRadius)/2;
            radiantLine(cx,cy,innerRadius,outerRadius-shorterLine,degrees,2,"lightgray");
        }
    }


    // draw inner arc of guage
    ctx.beginPath();
    ctx.arc(cx,cy,innerRadius,startRadians,endRadians,false);
    ctx.strokeStyle="black";
    ctx.lineWidth=3;
    ctx.stroke();

    // draw outer arc of guage (for illustration only)
    ctx.beginPath();
    ctx.arc(cx,cy,outerRadius,startRadians,endRadians,false);
    ctx.strokeStyle="lightgray";
    ctx.lineWidth=0.33;
    ctx.stroke();


    function radiantLine(centerX,centerY,innerRadius,outerRadius,degrees,linewidth,color){

        var radians=degrees*Math.PI/180;
        var innerX = centerX + innerRadius * Math.cos(radians);
        var innerY = centerY + innerRadius * Math.sin(radians);
        var outerX = centerX + outerRadius * Math.cos(radians);
        var outerY = centerY + outerRadius * Math.sin(radians);

        ctx.beginPath();
        ctx.moveTo(innerX,innerY);
        ctx.lineTo(outerX,outerY);
        ctx.strokeStyle=color;
        ctx.lineWidth=linewidth;
        ctx.stroke();

    }


    function scaleIntoRange(minActual,maxActual,minRange,maxRange,value){
      var scaled=(maxRange-minRange)*(value-minRange)/(maxActual-minActual)+minRange;
      return(scaled);
    }

}); // end $(function(){});
</script>

</head>

<body>
    <canvas id="canvas" width=300 height=300></canvas>
</body>
</html>

关于javascript - 如何使用 Canvas 创建辐射线?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17453208/

相关文章:

javascript - Canvas 径向渐变与 .png 性能

javascript - 一旦 iframe 内容更改,jquery 事件

javascript - Chrome 中的 Express Post 请求超时

javascript - 设置主干模型

javascript - 专门更改笔触不透明度但不更改 Canvas 上的颜色

python - 如何创建以变量命名的 python tkinter Canvas 对象并保留此链接以重新配置该对象?

javascript - 如何导出经过html5功能修饰的canvas图像

javascript - 在 native 底部选项卡导航器中更改屏幕时如何更改图标和文本的颜色?

javascript - jQuery click 在 tr 上工作正常,但在 td 上不行

javascript - html canvas,仅通过鼠标按下围绕中心旋转 Canvas