D3.js-타이머 API

Timer API 모듈은 동기화 된 타이밍 지연으로 동시 애니메이션을 수행하는 데 사용됩니다. 그것은 사용합니다requestAnimationFrame애니메이션 이 장에서는 Timer API 모듈에 대해 자세히 설명합니다.

requestAnimationFrame

이 메서드는 애니메이션을 수행 할 것을 브라우저에 알리고 브라우저가 애니메이션을 업데이트하기 위해 지정된 함수를 호출하도록 요청합니다.

타이머 구성

다음 스크립트를 사용하여 d3js.org에서 직접 타이머를 쉽게로드 할 수 있습니다.

<script src = "https://d3js.org/d3-timer.v1.min.js"></script>
<script>
   var timer = d3.timer(callback);
</script>

타이머 API 메서드

Timer API는 다음과 같은 중요한 방법을 지원합니다. 이들 모두는 다음과 같이 자세히 설명됩니다.

d3.now ()

이 메서드는 현재 시간을 반환합니다.

d3.timer (콜백 [, 지연 [, 시간]])

이 메서드는 새 타이머를 예약하는 데 사용되며 중지 될 때까지 타이머를 호출합니다. MS에서 숫자 지연을 설정할 수 있지만, 그렇지 않으면 선택 사항이며 기본값은 0입니다. 시간을 지정하지 않으면 d3.now ()로 간주됩니다.

timer.restart (콜백 [, 지연 [, 시간]])

지정된 콜백과 선택적 지연 및 시간으로 타이머를 다시 시작합니다.

timer.stop ()

이 메서드는 타이머를 중지하여 후속 콜백을 방지합니다.

d3.timeout (콜백 [, 지연 [, 시간]])

첫 번째 콜백에서 타이머를 중지하는 데 사용됩니다. 콜백은 경과 시간으로 전달됩니다.

d3.interval (콜백 [, 지연 [, 시간]])

특정 시간 지연 간격에서 호출됩니다. 지연을 지정하지 않으면 타이머 시간이 걸립니다.

웹 페이지“timer.html”을 만들고 여기에 다음 스크립트를 추가합니다.

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

   <body>
      <h3> Timer API </h3>
      <script>
         var timer = d3.timer(function(duration) {
            console.log(duration);
            if (duration > 150) timer.stop();
         }, 100);
      </script>
   </body>
</html>

화면에 다음과 같은 응답이 표시됩니다.