D3.js-경로 API

경로는 직사각형, 원, 타원, 폴리 라인, 다각형, 직선 및 곡선을 그리는 데 사용됩니다. SVG 경로는 Stroked, Filled, 클리핑 경로로 사용 또는이 세 가지를 모두 조합 할 수있는 모양의 윤곽선을 나타냅니다. 이 장에서는 Paths API에 대해 자세히 설명합니다.

경로 구성

아래 스크립트를 사용하여 Paths API를 구성 할 수 있습니다.

<script src = "https://d3js.org/d3-path.v1.min.js"></script>
<script>

</script>

Paths API 메서드

가장 일반적으로 사용되는 Paths API 메서드 중 일부는 다음과 같이 간략하게 설명됩니다.

  • d3.path() −이 방법은 새로운 경로를 생성하는 데 사용됩니다.

  • path.moveTo(x, y) −이 방법은 지정된 x 및 y 값을 이동하는 데 사용됩니다.

  • path.closePath() −이 방법은 현재 경로를 닫는 데 사용됩니다.

  • path.lineTo(x, y) −이 방법은 현재 지점에서 정의 된 x, y 값까지 선을 생성하는 데 사용됩니다.

  • path.quadraticCurveTo(cpx, cpy, x, y) −이 방법은 현재 지점에서 지정된 지점까지 2 차 곡선을 그리는 데 사용됩니다.

  • path.bezierCurveTo(cpx1, cpy1, cpx2, cpy2, x, y) −이 방법은 현재 지점에서 지정된 지점까지 베 지어 곡선을 그리는 데 사용됩니다.

  • path.arcTo(x1, y1, x2, y2, radius) −이 방법은 현재 지점에서 지정된 지점 (x1, y1)까지 원호를 그리고 지정된 지점 (x1, y1)과 (x2, y2) 사이의 선을 끝내는 데 사용됩니다.

  • path.arc(x, y, radius, startAngle, endAngle[, anticlockwise])−이 방법은 지정된 중심 (x, y), 반경, startAngle 및 endAngle에 원호를 그리는 데 사용됩니다. 반 시계 방향 값이 참이면 호는 반 시계 방향으로 그려지고, 그렇지 않으면 시계 방향으로 그려집니다.

  • path.rect(x, y, w, h)−이 방법은 4 개의 점 (x, y), (x + w, y), (x + w, y + h), (x, y + h) 만 포함하는 새 하위 경로를 만드는 데 사용됩니다. 이 네 점이 직선으로 연결되면 하위 경로가 닫힌 것으로 표시됩니다. context.rect와 동일하며 SVG의 "lineto"명령을 사용합니다.

  • path.toString() − SVG의 경로 데이터 사양에 따라이 경로의 문자열 표현을 반환합니다.

경로 API를 사용하여 D3에서 간단한 선을 그립니다. 웹 페이지 만들기linepath.html 다음 변경 사항을 추가하십시오.

<!DOCTYPE html>
<meta charset = "UTF-8">
   <head>
      <title>SVG path line Generator</title>
   </head>

   <style>
      path {
         fill: green;
         stroke: #aaa;
      }
   </style>
   
   <body>
      <svg width = "600" height = "100">
         <path transform = "translate(200, 0)" />
      </svg>
      
      <script src = "https://d3js.org/d3.v4.min.js"></script>
      <script>
         var data = [[0, 20], [50, 30], [100, 50], [200, 60], [300, 90]];
         var lineGenerator = d3.line();
         var pathString = lineGenerator(data);
         d3.select('path').attr('d', pathString);
      </script>
   </body>
</html>

이제 브라우저를 요청하면 다음 결과가 표시됩니다.