Как установить центр, используя внешний лат, lng? - PullRequest
0 голосов
/ 28 апреля 2018

Я создал приложение, которое рисует адрес из базы данных. Я использовал геокодер (https://www.npmjs.com/package/geocoder), чтобы получить широту и долготу адреса, и теперь хочу, чтобы каждый раз, когда я нажимал кнопку, которая перетаскивала адрес, он обновлял карту, чтобы приблизиться к этому адресу и центру. будет сделано, если я извлекаю адрес, внешний по отношению к компоненту карт?

Вот мой компонент карты:

    const MapWithASearchBox = compose(
  withProps({
    googleMapURL: "https://maps.googleapis.com/maps/api/js?key=AIzaSyDYwerCGhOnkM1sNHmSrckp8D1o9hY3mZ4&v=3.exp&libraries=geometry,drawing,places",
    loadingElement: <div style={{ height: `100%` }} />,
    containerElement: <div style={{ height: `400px` }} />,
    mapElement: <div style={{ height: `100%` }} />,
  }),
  lifecycle({
    componentDidMount(){

    },
    componentWillMount() {
      const refs = {}

      this.setState({

        bounds: null,
        center: {
          lat: -35.015742, lng: 138.520858
        },
        markers: [],
        onMapMounted: ref => {
          refs.map = ref;
        },
        onIdle: () => {
          this.setState({
            center: fullPos,
          })
        },
        onBoundsChanged: () => {
          this.setState({
            bounds: refs.map.getBounds(),
            center: refs.map.getCenter(),
          })
        },
        onSearchBoxMounted: ref => {
          console.log("s. mounted");
          refs.searchBox = ref;
        },
        onPlacesChanged: () => {
          console.log("places changed");
          console.log(refs.searchBox)
          console.log(refs)
          const places = refs.searchBox.getPlaces();
          console.log(places);
          const bounds = new google.maps.LatLngBounds();

          places.forEach(place => {
            if (place.geometry.viewport) {
              bounds.union(place.geometry.viewport)
            } else {
              bounds.extend(place.geometry.location)
            }
          });
          const nextMarkers = places.map(place => ({
            position: place.geometry.location,
          }));
          const nextCenter = _.get(nextMarkers, '0.position', this.state.center);

          this.setState({
            center: nextCenter,
            markers: nextMarkers,
          });
          // refs.map.fitBounds(bounds);
        },

      })
    },
  }),
  withScriptjs,
  withGoogleMap
)(props =>
  <GoogleMap
    ref={props.onMapMounted}
    defaultZoom={20}
    center={props.center}
    onBoundsChanged={props.onBoundsChanged}
    mapTypeId={google.maps.MapTypeId.SATELLITE}
    panControl={true}
    scrollwheel={false}
  >
    <SearchBox
      ref={props.onSearchBoxMounted}
      bounds={props.bounds}
      controlPosition={google.maps.ControlPosition.TOP_LEFT}
      onPlacesChanged={props.onPlacesChanged}
    >
      <input
        type="text"
        placeholder="Customized your placeholder"
        value={fullAdd}
        style={{
          boxSizing: `border-box`,
          border: `1px solid transparent`,
          width: `240px`,
          height: `32px`,
          marginTop: `27px`,
          padding: `0 12px`,
          borderRadius: `3px`,
          boxShadow: `0 2px 6px rgba(0, 0, 0, 0.3)`,
          fontSize: `14px`,
          outline: `none`,
          textOverflow: `ellipses`,
        }}
      />
    </SearchBox>
    {props.isMarkerShown && (
      <Marker position={fullPos} />
    )}
  </GoogleMap>
);

Где fullPos - это переменная lat, lng, с которой я играл в разных областях в надежде, что она будет работать.

1 Ответ

0 голосов
/ 28 апреля 2018

извлечение адреса, внешнего по отношению к компоненту карт

Не уверен, что вы имеете в виду Передача нового адреса извне компонента к нему в качестве реквизита , тогда, возможно, вы можете использовать ComponentWillUpdate и создать несколько прекрасных условий (чтобы избежать плохих бесконечных циклов) ), а также для проверки только того, был ли изменен параметр,4.

или

Скорее всего, очевидно, что вы имеете в виду Я получил этот адрес где-то очень далеко от этого компонента, поэтому нет никакой возможности, что они смогут общаться , тогда, возможно, решение находится в redux / mobx (в зависимости от того, что вы предпочитаете / используете) ) и когда адрес изменяется, вы можете запустить действие с новым адресом, и этот компонент прослушивает эту часть состояния, также с некоторым прекрасным условием внутри componentWillUpdate, вы можете изменить this.state.center, когда эта глобальная часть состояния меняется.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...