Maison  >  Article  >  interface Web  >  Comment puis-je personnaliser le style de Google Maps InfoWindows ?

Comment puis-je personnaliser le style de Google Maps InfoWindows ?

Patricia Arquette
Patricia Arquetteoriginal
2024-11-05 08:09:02958parcourir

How can I customize the styling of Google Maps InfoWindows?

Styler les InfoWindows de Google Maps

Google Maps fournit un guide limité pour styliser les InfoWindows. Cet article examine les techniques de personnalisation de ces éléments.

InfoBubble

Vous pouvez obtenir de nombreuses options de style avec InfoBubble, une alternative à InfoWindow.

infoBubble = new InfoBubble({
  map: map,
  content: '<div class="mylabel">The label</div>',
  position: new google.maps.LatLng(-32.0, 149.0),
  shadowStyle: 1,
  padding: 0,
  backgroundColor: 'rgb(57,57,57)',
  borderRadius: 5,
  arrowSize: 10,
  borderWidth: 1,
  borderColor: '#2c2c2c',
  disableAutoPan: true,
  hideCloseButton: true,
  arrowPosition: 30,
  backgroundClassName: 'transparent',
  arrowStyle: 2
});
infoBubble.open();

Fenêtre d'informations personnalisée

Ce script étend GOverlay, créant une fenêtre d'informations plus flexible et personnalisable.

/* An InfoBox is like an info window, but it displays
 * under the marker, opens quicker, and has flexible styling.
 * @param {GLatLng} latlng Point to place bar at
 * @param {Map} map The map on which to display this InfoBox.
 * @param {Object} opts Passes configuration options - content,
 *   offsetVertical, offsetHorizontal, className, height, width
 */
function InfoBox(opts) {
  google.maps.OverlayView.call(this);
  this.latlng_ = opts.latlng;
  this.map_ = opts.map;
  this.offsetVertical_ = -195;
  this.offsetHorizontal_ = 0;
  this.height_ = 165;
  this.width_ = 266;

  var me = this;
  this.boundsChangedListener_ =
    google.maps.event.addListener(this.map_, "bounds_changed", function() {
      return me.panMap.apply(me);
    });

  // Once the properties of this OverlayView are initialized, set its map so
  // that we can display it.  This will trigger calls to panes_changed and
  // draw.
  this.setMap(this.map_);
}

Notez que vous devrez peut-être remplacer plusieurs méthodes lors de l'utilisation de la fenêtre d'informations personnalisée.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn