javascript - 如何使用谷歌地图角度组件从谷歌地图中删除地标
问题描述
我正在使用谷歌地图角度组件,它工作得很好!
但是现在我想从地图上移除一些地标以减少它的拥堵,以便能够更清楚地显示我的标记。
我在下面找到了这些资源,但不知道如何将其应用于我正在使用的 <google-map> 节点包。
我在这个谷歌文档中看到它显示了使用'setMapStyle()'将样式应用于'googlemap',但这不是角度包中的方法
下面是我使用谷歌地图的组件(不是所有代码),但它显示了我如何使用地图的所有代码
import {
MapInfoWindow,
MapMarker,
GoogleMap
} from '@angular/google-maps';
export class YogabandEventsComponent implements OnInit {
colContentRef: ElementRef;
@ViewChild(GoogleMap, {
static: false
}) googleMap: GoogleMap;
@ViewChild(MapInfoWindow, {
static: false
}) infoWindow: MapInfoWindow;
zoom = 12;
center: google.maps.LatLngLiteral;
options: google.maps.MapOptions = {
mapTypeId: 'roadmap',
mapTypeControl: false,
scrollwheel: true,
maxZoom: 18,
minZoom: 10,
streetViewControl: false,
fullscreenControl: false
};
markers: Marker[];
infoContent = '';
constructor(...) { ...
}
openInfo(marker: MapMarker, content) {
this.infoContent = content;
this.infoWindow.open(marker);
}
showMarkers() {
this.markers = [];
for (const ybEvent of this.yogabandEvents) {
const marker = new Marker();
marker.info = ybEvent.name;
marker.title = ybEvent.name;
marker.position = {
lat: ybEvent.latitude,
lng: ybEvent.longitude
};
marker.label = {
color: '#17a2b8',
text: ybEvent.yogaType,
fontWeight: 'bold',
fontSize: '16px'
};
marker.options = {
icon: {
// scaledSize: new google.maps.Size(40, 40),
url: 'assets/images/marker.svg',
labelOrigin: new google.maps.Point(18, 50)
}
};
this.markers.push(marker);
}
}
}
<div class="col flex-fill h-100 px-0 right-col">
<google-map [options]="options" [zoom]="zoom" [center]="center" class="h-100" height="100%" width="100%">
<map-marker #markerElem *ngFor="let marker of markers" [position]="marker.position" [label]="marker.label" [title]="marker.title" [options]="marker.options" (mapClick)="openInfo(markerElem, marker.info)">
</map-marker>
<map-info-window>{{ infoContent }}</map-info-window>
</google-map>
</div>
解决方案
尝试使用MapOptions 接口的样式属性。像这样:
options: google.maps.MapOptions = {
mapTypeId: 'roadmap',
mapTypeControl: false,
scrollwheel: true,
maxZoom: 18,
minZoom: 10,
streetViewControl: false,
fullscreenControl: false,
styles: [...]
};
详细的造型可能会有点烦人。您可以从此样式向导生成一组样式(它还有一个地标幻灯片以逐渐删除它们,然后只需导出样式数组)。
推荐阅读
- http - HTTP 上 jpeg 图像的权威“内容类型”是什么?
- python - 按目录中的方式列出音频文件
- r - R ggridges plot - 显示 y 轴刻度和标签
- java - 我的 getBindingAdapterrPosition 只返回 -1
- yaml - 如何仅在活动 LTS 甚至当前版本上运行 GitHub 工作流?
- php - 如果子域托管在不同的服务器上,子域上的 SSL 证书是否需要来自同一颁发者?
- reactjs - React JS“npm start”显示无法编译 web-vitals
- javascript - 如何在一个视频结束时连续播放来自不同网站的嵌入多个视频
- python - PyQt5中的窗口切换和线程
- linux - Ubuntu 16.04:在 dockerfile 中运行“apt-get update”命令时出现错误“无法连接到 archive.ubuntu.com:80 (91.189.88.152)”