D3.js-스케일 API

D3.js는 데이터 변환을 수행하는 확장 기능을 제공합니다. 이러한 함수는 입력 도메인을 출력 범위에 매핑합니다.

API 구성

다음 스크립트를 사용하여 API를 직접 구성 할 수 있습니다.

<script src = "https://d3js.org/d3-array.v1.min.js"></script>
<script src = "https://d3js.org/d3-collection.v1.min.js"></script>
<script src = "https://d3js.org/d3-color.v1.min.js"></script>
<script src = "https://d3js.org/d3-format.v1.min.js"></script>
<script src = "https://d3js.org/d3-interpolate.v1.min.js"></script>
<script src = "https://d3js.org/d3-time.v1.min.js"></script>
<script src = "https://d3js.org/d3-time-format.v2.min.js"></script>
<script src = "https://d3js.org/d3-scale.v1.min.js"></script>
<script>

</script>

Scales API 메서드

D3는 다양한 유형의 차트에 대해 다음과 같은 중요한 크기 조정 방법을 제공합니다. 그럼 자세히 이해합시다.

  • d3.scaleLinear() − 지정된 출력 범위에 매핑되는 데이터 (도메인)를 입력 할 수있는 연속 선형 스케일을 구성합니다.

  • d3.scaleIdentity() − 입력 데이터가 출력과 동일한 선형 스케일을 생성합니다.

  • d3.scaleTime() − 입력 데이터가 날짜에 있고 출력이 숫자로 표시되는 선형 스케일을 구성합니다.

  • d3.scaleLog() − 로그 스케일을 생성합니다.

  • d3.scaleSqrt() − 제곱근 척도를 만듭니다.

  • d3.scalePow() − 지수 척도를 구성합니다.

  • d3.scaleSequential() − 보간 기능에 의해 출력 범위가 고정되는 순차 스케일을 구성합니다.

  • d3.scaleQuantize() − 이산 출력 범위로 양자화 스케일을 구성합니다.

  • d3.scaleQuantile() − 입력 샘플 데이터가 개별 출력 범위에 매핑되는 분위수 척도를 구성합니다.

  • d3.scaleThreshold() − 임의의 입력 데이터가 개별 출력 범위에 매핑되는 스케일을 구성합니다.

  • d3.scaleBand() − 밴드 스케일은 출력 범위가 연속적이고 숫자라는 점을 제외하면 서수 스케일과 유사합니다.

  • d3.scalePoint() − 포인트 척도를 구성합니다.

  • d3.scaleOrdinal() − 입력 데이터에 알파벳이 포함되고 개별 숫자 출력 범위에 매핑되는 서수 스케일을 구성합니다.

작업 예제를 수행하기 전에 먼저 다음 두 용어를 이해하겠습니다.

  • Domain − 도메인은 입력 데이터의 최소값과 최대 값을 나타냅니다.

  • Range − 범위는 입력 값을 매핑하려는 출력 범위입니다.

작업 예

이 예제에서 d3.scaleLinear 함수를 수행해 보겠습니다. 이렇게하려면 다음 단계를 따라야합니다.

Step 1Define variables − 아래 코딩을 사용하여 SVG 변수 및 데이터를 정의합니다.

var data = [100, 200, 300, 400, 800, 0]
   var width = 500, 
      barHeight = 20, 
      margin = 1;

Step 2Create linear scale − 다음 코드를 사용하여 선형 스케일을 생성합니다.

var scale = d3.scaleLinear()
   .domain([d3.min(data), d3.max(data)])
   .range([100, 400]);

여기에서 수동으로 도메인의 최소값과 최대 값에 대해 기본 제공되는 d3.min()d3.max() 함수는 데이터 배열에서 각각 최소값과 최대 값을 반환합니다.

Step 3Append SVG attributes − 아래 코드를 사용하여 SVG 요소를 추가합니다.

var svg = d3.select("body")
   .append("svg")
   .attr("width", width)
   .attr("height", barHeight * data.length);

Step 4Apply transformation − 아래 코드를 사용하여 변환을 적용합니다.

var g = svg.selectAll("g")
   .data(data).enter().append("g")
   .attr("transform", function (d, i) {
      return "translate(0," + i * barHeight + ")";
});

Step 5Append rect elements − 아래와 같이 rect 요소를 스케일링에 추가합니다.

g.append("rect")
   .attr("width", function (d) {
      return scale(d);
   })
   .attr("height", barHeight - margin)

Step 6Display data − 이제 아래 주어진 코딩을 사용하여 데이터를 표시합니다.

g.append("text")
   .attr("x", function (d) { return (scale(d)); })
   .attr("y", barHeight / 2)
   .attr("dy", ".35em")
   .text(function (d) { return d; });

Step 7Working Example − 이제 다음과 같이 d3.scaleLinear () 함수를 사용하여 막대 차트를 생성 해 보겠습니다.

웹 페이지 "scales.html"을 만들고 다음 변경 사항을 추가합니다.

<!DOCTYPE html>
<html>
   <head>
      <script type = "text/javascript" src = "https://d3js.org/d3.v4.min.js"></script>
   </head>

   <body>
      <script>
         var data = [100, 200, 300, 350, 400, 250]
         var width = 500, barHeight = 20, margin = 1;
         
         var scale = d3.scaleLinear()
            .domain([d3.min(data), d3.max(data)])
            .range([100, 400]);
         
         var svg = d3.select("body")
            .append("svg")
            .attr("width", width)
            .attr("height", barHeight * data.length);
         
         var g = svg.selectAll("g")
            .data(data)
            .enter()
            .append("g")
            .attr("transform", function (d, i) {
               return "translate(0," + i * barHeight + ")";
         });
    
         g.append("rect")
         .attr("width", function (d) {
            return scale(d);
         })
         
         .attr("height", barHeight - margin)
         g.append("text")
         .attr("x", function (d) { return (scale(d)); })
         .attr("y", barHeight / 2).attr("dy", ".35em")
         .text(function (d) { return d; });
      </script>
   </body>
</html>

위 코드는 브라우저에 다음 결과를 표시합니다.