D3.js-애니메이션

D3.js는 전환을 통해 애니메이션을 지원합니다. 전환을 적절히 사용하여 애니메이션을 할 수 있습니다. 전환은 제한된 형태의Key Frame Animation두 개의 키 프레임 – 시작과 끝으로. 시작 키 프레임은 일반적으로 DOM의 현재 상태이고 종료 키 프레임은 사용자가 지정하는 속성, 스타일 및 기타 속성의 집합입니다. 전환은 시작 뷰에 의존하는 복잡한 코드없이 새 뷰로 전환하는 데 적합합니다.

Example −“transition_color.html”페이지에서 다음 코드를 살펴 보겠습니다.

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

   <body>
      <h3>Simple transitions</h3>
      <script>
         d3.select("body").style("background-color", "lightblue") 
         // make the background-color lightblue.transition()
         .style("background-color", "gray");
         // make the background-color gray
      </script>
   </body>
</html>

여기서 문서의 배경색이 흰색에서 밝은 회색으로 변경된 다음 회색으로 변경되었습니다.

duration () 메서드

duration () 메서드를 사용하면 속성 변경이 즉시가 아닌 지정된 기간 동안 매끄럽게 발생할 수 있습니다. 다음 코드를 사용하여 5 초가 걸리는 전환을 만들어 보겠습니다.

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

   <body>
      <h3>Simple transitions</h3>
      <script>
         d3.selectAll("h3").transition().style("color","green").duration(5000);
      </script>
   </body>
</html>

여기에서 전환이 부드럽고 균등하게 발생했습니다. 다음 방법을 사용하여 RGB 색상 코드 값을 직접 할당 할 수도 있습니다.

d3.selectAll("h3").transition().style("color","rgb(0,150,120)").duration(5000);

이제 각 색상 번호는 0에서 150까지 천천히 매끄럽고 균등하게 이동합니다. 시작 프레임 값에서 끝 프레임 값까지 중간 프레임의 정확한 혼합을 얻기 위해 D3.js는 내부 보간 방법을 사용합니다. 구문은 다음과 같습니다.

d3.interpolate(a, b)

D3는 다음 보간 유형도 지원합니다.

  • interpolateNumber − 숫자 값을 지원합니다.

  • interpolateRgb − 지원 색상.

  • interpolateString − 지원 문자열.

D3.js는 적절한 보간 방법을 사용하며 고급의 경우 보간 방법을 직접 사용하여 원하는 결과를 얻을 수 있습니다. 필요한 경우 새로운 보간 방법을 만들 수도 있습니다.

delay () 메서드

delay () 메서드를 사용하면 일정 시간 후에 전환이 수행 될 수 있습니다. “transition_delay.html”에서 다음 코드를 고려하십시오.

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

   <body>
      <h3> Simple transitions </h3>
      <script>
         d3.selectAll("h3").transition()
            .style("font-size","28px").delay(2000).duration(2000);
      </script>
   </body>
</html>

전환의 수명주기

전환에는 4 단계 수명주기가 있습니다.

  • 전환이 예정되어 있습니다.
  • 전환이 시작됩니다.
  • 전환이 실행됩니다.
  • 전환이 끝납니다.

이 각각을 하나씩 자세히 살펴 보겠습니다.

전환이 예정되어 있습니다

전환은 생성 될 때 예약됩니다. 우리가 전화 할 때selection.transition, 전환을 예약하고 있습니다. 이것은 또한 우리가 전화 할 때attr(), style() 및 종료 키 프레임을 정의하는 기타 전환 방법.

전환이 시작됩니다

전환이 예약 될 때 지정된 지연을 기반으로 전환이 시작됩니다. 지연이 지정되지 않은 경우 전환은 가능한 한 빨리 시작되며 일반적으로 몇 밀리 초 후에 시작됩니다.

전환에 지연이있는 경우 전환이 시작될 때만 시작 값을 설정해야합니다. 시작 이벤트를 수신하면됩니다.

d3.select("body")
   .transition()
   .delay(200)
   .each("start", function() { d3.select(this).style("color", "green"); })
   .style("color", "red");

전환 실행

전환이 실행되면 0에서 1 사이의 전환 값을 사용하여 반복적으로 호출됩니다. 지연 및 기간 외에도 전환은 타이밍을 제어하는 ​​여유가 있습니다. 이징은 슬로우 인 및 슬로우 아웃과 같이 시간을 왜곡합니다. 일부 여유 함수는 t 값이 1보다 크거나 0보다 작을 수 있습니다.

전환의 끝

전환 종료 시간은 항상 정확히 1이므로 전환이 종료 될 때 종료 값이 정확하게 설정됩니다. 전환은 지연과 지속 시간의 합에 따라 종료됩니다. 전환이 끝나면 end 이벤트가 전달됩니다.