Help us understand the problem. What is going on with this article?

Google Maps APIのMarker Clusterers libraryを使用した際のcluster iconのclick event

More than 1 year has passed since last update.

やりたいこと

cluster iconをクリックしたときの挙動を変えたい(デフォルトはクリックするとズームする)

コード

markerclusterer.js
/**
 * Triggers the clusterclick event and zoom's if the option is set.
 */
ClusterIcon.prototype.triggerClusterClick = function() {
  var markerClusterer = this.cluster_.getMarkerClusterer();

  // Trigger the clusterclick event.
  google.maps.event.trigger(markerClusterer, 'clusterclick', this.cluster_);

  if (markerClusterer.isZoomOnClick()) {
    // Zoom into the cluster.
    this.map_.fitBounds(this.cluster_.getBounds());
  }
};

ライブラリの上記がcluster iconがクリックされた時のイベント部分です。
markerClusterer.isZoomOnClickはmarkerClustererのオプションです。

Name Type Description
zoomOnClick boolean Whether the default behaviour of clicking on a cluster is to zoom into it.

zoomOnClickがtrueのときにズームされるみたいです。
単純に常にズームしないのであればzoomOnClick:falseにすれば良いです。
また、例えばズームレベルが9未満のときにのみズームさせるのであれば、if (markerClusterer.isZoomOnClick()) {の部分に以下を追記すれば良いです。

markerclusterer.js
  if (markerClusterer.isZoomOnClick()) {
    if(this.map_.getZoom() < 9){
    // Zoom into the cluster.
    this.map_.fitBounds(this.cluster_.getBounds());
    }
  }

私の場合は、単にmapをドラッグしたいだけなのに、cluster iconのところでドラッグしてしまうと、ドラッグした後にズームしてしまう:pouting_cat:のをなんとかしたかったので、上記の部分を「ドラッグしていたらズームしない」というように変えました。

参考:Gmaps Marker Clusterer

bubbles
仕事ではweb開発をしており、現在はphp(framework:laravel5.4.36)、sqlserver、mysql、javascriptを扱っています。
ayudante
いつもユーザー中心で技術者とコンサルタントがとことん考え抜く それがアユダンテです
https://ayudante.jp/
Why not register and get more from Qiita?
  1. We will deliver articles that match you
    By following users and tags, you can catch up information on technical fields that you are interested in as a whole
  2. you can read useful information later efficiently
    By "stocking" the articles you like, you can search right away
Comments
No comments
Sign up for free and join this conversation.
If you already have a Qiita account
Why do not you register as a user and use Qiita more conveniently?
You need to log in to use this function. Qiita can be used more conveniently after logging in.
You seem to be reading articles frequently this month. Qiita can be used more conveniently after logging in.
  1. We will deliver articles that match you
    By following users and tags, you can catch up information on technical fields that you are interested in as a whole
  2. you can read useful information later efficiently
    By "stocking" the articles you like, you can search right away
ユーザーは見つかりませんでした