通过缩放级别控制标记可见性Reactjs

问题描述 投票:0回答:1

我从后端接收带有位置的数据,然后将它们显示在地图上。我怎样才能做到,在地图上,根据缩放,标记的数量发生变化,当你靠近时,标记的数量会增加?

<GoogleMap zoom={zoom} center={center} mapContainerClassName="map-container"
            options={{
                restriction: {
                    latLngBounds: azerbaijanBounds,
                    strictBounds: false,
                },
            }}
        >
            {counter && data && data.map((loc) => (
                <div key={loc.id} className="custom-marker-wrapper">
                    <Marker
                        position={{ lat: loc.location[0], lng: loc.location[1] }}
                        onClick={() => handleMarkerClick(loc)}
                        icon={''}
                    >
                        {loc.isOpen && loc.title && (
                            <InfoWindowF onCloseClick={() => handleMarkerClose(loc)}>
                                <div className='infoWindowDiv' onClick={(e) => { window.open(`https://example.com/item/${offerType}/${loc.id}`) }}>
                                    <span className='infoWindowTitle'>{loc.title}</span>
                                    <span className='infoWindowInfo'>Qiymet - <span className='infoWindowPrice'>{loc.price} AZN</span></span>
                                    <span className='infoWindowInfo'>Sahə - <span className='infoWindowPrice'>{loc.area} m <sup><small>2</small></sup></span></span>
                                    <span className='infoWindowInfo'>1kv/qiymet - <span className='infoWindowPrice'>{Math.round(loc.m2)} AZN</span></span>
                                </div>
                            </InfoWindowF>
                        )}
                    </Marker>
                </div>
            ))}
        </GoogleMap >

我尝试添加类名以便根据距离更改显示值,但它不起作用

reactjs google-maps google-maps-api-3 google-maps-markers google-maps-api-2
1个回答
0
投票

我只是相对于一个点进行排序,然后根据缩放来更改状态

const groupMarkers = ((locations, zoom) => {
    const groupingThreshold = 0.5 / Math.pow(2, zoom / 2);
    const groupedMarkers = [];
    const sortByLocation = (properties, lat, lng) => {
        return properties?.sort((a, b) => {
            const distanceA = calculateDistance(a.location[0], a.location[1], lat, lng);
            const distanceB = calculateDistance(b.location[0], b.location[1], lat, lng);
            return distanceA - distanceB;
        });
    }
    const calculateDistance = (lat1, lng1, lat2, lng2) => {
        const earthRadius = 6371;
        const radLat1 = (Math.PI * lat1) / 180;
        const radLat2 = (Math.PI * lat2) / 180;
        const deltaLat = (Math.PI * (lat2 - lat1)) / 180;
        const deltaLng = (Math.PI * (lng2 - lng1)) / 180;
        const a = Math.sin(deltaLat / 2) * Math.sin(deltaLat / 2) + Math.cos(radLat1) * Math.cos(radLat2) * Math.sin(deltaLng / 2) * Math.sin(deltaLng / 2);
        const c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1 - a));
        const distance = earthRadius * c;
        return distance;
    }
    const sortedProperties = sortByLocation(locations, 40.317574, 50.339039);
    for (let i = 0; i < sortedProperties?.length - 1; i++) {
        if ((Math.abs(sortedProperties[i].location[0] - sortedProperties[i + 1].location[0])) > groupingThreshold && (Math.abs(sortedProperties[i].location[1] - sortedProperties[i + 1].location[1])) > groupingThreshold) {
            groupedMarkers.push(sortedProperties[i]);
        }
    }
    setData2(groupedMarkers)
})
© www.soinside.com 2019 - 2024. All rights reserved.