reactjs 使用react-google-maps-api在街道视图上显示InfoBox/InfoWindow

63lcw9qa  于 2023-06-05  发布在  React
关注(0)|答案(1)|浏览(287)

bounty还有2天到期。此问题的答案有资格获得+50声望奖励。Amir-Mousavi正在寻找一个规范答案

In this code sandbox,我有一些标记,其中Infobox嵌套在单击时显示的标记中。我如何在切换到街景模式时也显示该信息框?

// The imports 
import { GoogleMap, InfoBox, Marker, OverlayView, Polyline, useJsApiLoader } from '@react-google-maps/api';
  {data.map(({ source, destination, distance }, index) => (
    <Marker key={index} position={source}>
      <InfoBox
        options={{
          enableEventPropagation: true,
          boxStyle: {...}
        }}
      >
        <div
          style={{...}}
        >
          <p>Some text here</p>
        </div>
      </InfoBox>
    </Marker>
  ))}

注意:代码沙箱中不提供API密钥。提供API密钥将显示StreetView图标,该图标可以在Map上靠近标记拖放。

ej83mcc0

ej83mcc01#

将调用InfoWindow#open方法中的Map替换为StreetViewPanorama

Google's documentation for the Maps JavaScript API on overlays within street view中,需要注意的是,当调用open()方法时,通过传递StreetViewPanorama而不是Map,可以在StreetViewPanorama中打开InfoWindow
@react-google-maps/api代码库中,InfoWindow.tsx文件通过React的Context API获取Map示例,并使用它打开InfoWindow示例:

const map = useContext<google.maps.Map | null>(MapContext)
// ...
instance.open(map)

这样,我们就可以导入MapContext并用它 Package 我们的<InfoWindow>,以将map替换为StreetViewPanorama示例,我们可以通过使用<StreetViewPanorama>onLoad事件来获得StreetViewPanorama示例。

import { createRoot } from "react-dom/client";
import {
  useLoadScript,
  GoogleMap,
  StreetViewPanorama,
  Marker,
  InfoWindow,
  MapContext,
} from "@react-google-maps/api";
import React, { useContext, useState } from "react";

function App() {
  const astorPlace = { lat: 40.729884, lng: -73.990988 };
  const [panorama, setPanorama] =
    useState<google.maps.StreetViewPanorama | null>(null);
  const markers = [
    {
      position: { lat: 40.730031, lng: -73.991428 },
      icon: "https://chart.apis.google.com/chart?chst=d_map_pin_icon&chld=cafe|FFFF00",
      title: "Cafe",
    },
    {
      position: { lat: 40.729681, lng: -73.991138 },
      icon: "https://chart.apis.google.com/chart?chst=d_map_pin_icon&chld=dollar|FFFF00",
      title: "Bank",
    },
    {
      position: { lat: 40.729559, lng: -73.990741 },
      icon: "https://chart.apis.google.com/chart?chst=d_map_pin_icon&chld=bus|FFFF00",
      title: "Bus Stop",
    },
  ];

  function onPanoramaLoad(panorama: google.maps.StreetViewPanorama) {
    panorama.setPosition(astorPlace);
    panorama.setPov({
      heading: 265,
      pitch: 0,
    });
    panorama.setVisible(true);
    setPanorama(panorama);
  }

  const { isLoaded, loadError } = useLoadScript({
    googleMapsApiKey: import.meta.env.VITE_GOOGLE_MAPS_API_KEY,
  });

  return (
    <>
      {isLoaded ? (
        <GoogleMap center={astorPlace} zoom={18} id="map">
          <StreetViewPanorama onLoad={onPanoramaLoad} />
          {panorama ? (
            // @ts-ignore
            <MapContext.Provider value={panorama}>
              {markers.map((marker) => (
                <Marker key={marker.title} {...marker}>
                  <InfoWindow position={marker.position}>
                    <div
                      style={{
                        backgroundColor: "white",
                        opacity: 0.8,
                      }}
                    >
                      <h2>{marker.title}</h2>
                    </div>
                  </InfoWindow>
                </Marker>
              ))}
            </MapContext.Provider>
          ) : null}
        </GoogleMap>
      ) : null}
      {loadError ? <p>{loadError.message}</p> : null}
    </>
  );
}

createRoot(document.getElementById("app")!).render(<App />);

View this example live at CodeSandbox.

相关问题