D3.js-Zooming API

확대 / 축소는 콘텐츠를 확장하는 데 도움이됩니다. 클릭 앤 드래그 방식을 사용하여 특정 영역에 집중할 수 있습니다. 이 장에서는 Zooming API에 대해 자세히 설명합니다.

API 구성

다음 스크립트를 사용하여“d3js.org”에서 직접 Zooming API를로드 할 수 있습니다.

<script src = "https://d3js.org/d3-color.v1.min.js"></script>
<script src = "https://d3js.org/d3-dispatch.v1.min.js"></script>
<script src = "https://d3js.org/d3-ease.v1.min.js"></script>
<script src = "https://d3js.org/d3-interpolate.v1.min.js"></script>
<script src = "https://d3js.org/d3-selection.v1.min.js"></script>
<script src = "https://d3js.org/d3-timer.v1.min.js"></script>
<script src = "https://d3js.org/d3-transition.v1.min.js"></script>
<script src = "https://d3js.org/d3-drag.v1.min.js"></script>
<script src = "https://d3js.org/d3-zoom.v1.min.js"></script>

<body>
   <script>
   </script>
</body>

Zooming API 메서드

다음은 가장 일반적으로 사용되는 Zooming API 메소드 중 일부입니다.

  • d3.zoom()
  • zoom(selection)
  • zoom.transform (선택, 변형)
  • zoom.translateBy (선택, x, y)
  • zoom.translateTo (선택, x, y)
  • zoom.scaleTo (선택, k)
  • zoom.scaleBy (선택, k)
  • zoom.filter([filter])
  • zoom.wheelDelta([delta])
  • zoom.extent([extent])
  • zoom.scaleExtent([extent])
  • zoom.translateExtent([extent])
  • zoom.clickDistance([distance])
  • zoom.duration([duration])
  • zoom.interpolate([interpolate])
  • zoom.on (유형 이름 [, 리스너])

이러한 모든 Zooming API 메서드를 간략하게 살펴 보겠습니다.

d3.zoom ()

새로운 확대 / 축소 동작을 생성합니다. 아래 스크립트를 사용하여 액세스 할 수 있습니다.

<script>
   var zoom = d3.zoom();
</script>

줌 (선택)

선택한 요소에 확대 / 축소 변환을 적용하는 데 사용됩니다. 예를 들어 다음 구문을 사용하여 mousedown.zoom 동작을 인스턴스화 할 수 있습니다.

selection.call(d3.zoom().on("mousedown.zoom", mousedowned));

zoom.transform (선택, 변형)

선택한 요소의 현재 확대 / 축소 변환을 지정된 변환으로 설정하는 데 사용됩니다. 예를 들어 아래 구문을 사용하여 확대 / 축소 변환을 ID 변환으로 재설정 할 수 있습니다.

selection.call(zoom.transform, d3.zoomIdentity);

다음 구문을 사용하여 1000 밀리 초 동안 확대 / 축소 변환을 ID 변환으로 재설정 할 수도 있습니다.

selection.transition().duration(1000).call(zoom.transform, d3.zoomIdentity);

zoom.translateBy (선택, x, y)

선택한 요소의 현재 확대 / 축소 변환을 x 및 y 값으로 변환하는 데 사용됩니다. x 및 y 변환 값을 숫자 또는 숫자를 반환하는 함수로 지정할 수 있습니다. 선택한 요소에 대해 함수가 호출되면 DOM에 대한 현재 데이텀 'd'및 인덱스 'i'를 통해 전달됩니다. 샘플 코드는 아래에 정의되어 있습니다.

zoom.translateBy(selection, x, y) {
   zoom.transform(selection, function() {
      return constrain(this.__zoom.translate(
         x = = = "function" ? x.apply(this, arguments) : x,
         y = = = "function" ? y.apply(this, arguments) : y
      );
   }
};

zoom.translateTo (선택, x, y)

선택한 요소의 현재 확대 / 축소 변환을 지정된 x 및 y 위치로 변환하는 데 사용됩니다.

zoom.scaleTo (선택, k)

선택한 요소의 현재 확대 / 축소 변환을 다음으로 조정하는 데 사용됩니다. k. 여기,k 숫자 또는 함수로 지정되는 축척 비율입니다.

zoom.scaleTo = function(selection, k) {
   zoom.transform(selection, function() {
      k = = = "function" ? k.apply(this, arguments) : k;
   });
};

zoom.scaleBy (선택, k)

선택한 요소의 현재 zoon 변환을 다음과 같이 조정하는 데 사용됩니다. k. 여기,k 스케일 인자로, 숫자 또는 숫자를 반환하는 함수로 지정됩니다.

zoom.scaleBy = function(selection, k) {
   zoom.scaleTo(selection, function() {
      var k0 = this.__zoom.k,
      k1 = k = = = "function" ? k.apply(this, arguments) : k;
      return k0 * k1;
   });
};

zoom.filter ([필터])

줌 동작을 위해 필터를 지정된 기능으로 설정하는 데 사용됩니다. 필터를 지정하지 않으면 아래와 같이 현재 필터를 반환합니다.

function filter() {
   return !d3.event.button;
}

zoom.wheelDelta ([델타])

의 가치 Δ휠 델타 함수에 의해 반환됩니다. 델타를 지정하지 않으면 현재 휠 델타 함수를 반환합니다.

zoom.extent ([extent])

지정된 배열 포인트에 범위를 설정하는 데 사용됩니다. 익스텐트가 지정되지 않은 경우 현재 익스텐트 접근자를 반환합니다. 기본값은 [[0, 0], [너비, 높이]]입니다. 여기서 너비는 요소의 클라이언트 너비이고 높이는 클라이언트 높이입니다.

zoom.scaleExtent ([extent])

스케일 범위를 지정된 숫자 배열 [k0, k1]로 설정하는 데 사용됩니다. 여기,k0허용되는 최소 축척 비율입니다. 동안,k1허용되는 최대 축척 비율입니다. 범위를 지정하지 않으면 현재 스케일 범위를 반환하며 기본값은 [0, ∞]입니다. 아래 정의 된 샘플 코드를 고려하십시오.

selection
   .call(zoom)
   .on("wheel", function() { d3.event.preventDefault(); });

사용자는 이미 스케일 범위의 해당 한계에 도달했을 때 휠링으로 줌을 시도 할 수 있습니다. 스케일 범위에 관계없이 휠 입력에서 스크롤을 방지하려면 휠 이벤트 리스너를 등록하여 브라우저 기본 동작을 방지하십시오.

zoom.translateExtent ([extent])

범위가 지정되면 변환 범위를 지정된 포인트 배열로 설정합니다. 범위를 지정하지 않으면 현재 변환 범위를 반환하며 기본값은 [[-∞, -∞], [+ ∞, + ∞]]입니다.

zoom.clickDistance ([거리])

이 방법은 확대 / 축소 가능 영역이 위아래로 이동할 수있는 최대 거리를 설정하는 데 사용되며 후속 클릭 이벤트를 트리거합니다.

zoom.duration ([기간])

이 메서드는 더블 클릭시 확대 / 축소 전환 기간을 설정하고 지정된 밀리 초까지 두 번 탭하는 데 사용되며 확대 / 축소 동작을 반환합니다. 기간이 지정되지 않은 경우 현재 기간을 반환하며 기본값은 아래에 정의 된 250 밀리 초입니다.

selection
   .call(zoom)
   .on("dblclick.zoom", null);

zoom.interpolate ([보간])

이 메서드는 지정된 함수로 확대 / 축소 전환을 보간하는 데 사용됩니다. interpolate가 지정되지 않으면 현재 보간 팩토리를 반환하며 기본값은 d3.interpolateZoom입니다.

zoom.on (유형 이름 [, 리스너])

리스너가 지정되면 지정된 유형 이름에 대한 이벤트 리스너를 설정하고 확대 / 축소 동작을 반환합니다. typenames는 공백으로 구분 된 하나 이상의 typename을 포함하는 문자열입니다. 각 유형 이름은 유형이며 선택적으로 마침표 (.)와 이름 (예 : zoom.one 및 zoom.second)이 뒤 따릅니다. 이름을 사용하면 동일한 유형에 대해 여러 리스너를 등록 할 수 있습니다. 이 유형은 다음 중 하나 여야합니다.

  • Start − 확대가 시작된 후 (예 : mousedown).

  • Zoom − 확대 / 축소 변환 변경 후 (예 : mousemove).

  • End − 확대 / 축소 종료 후 (예 : mouseup).

다음 장에서는 D3.js의 다양한 요청 API에 대해 설명합니다.