Вы можете наблюдать событие maptypeid_changed карты.
Проверьте текущий mapTypeId с помощью getMapTypeId () и, если он равен google.maps.MapTypeId.HYBRID
, примените следующий стиль к карте с помощью map.setOptions()
{
featureType: "all",
elementType: "labels",//hides all labels
stylers: [
{ visibility:'off' }
]
},
{
featureType: "road",//hides the roads
stylers: [
{ visibility:'off' }
]
}
Когда mapTypeId не google.maps.MapTypeId.HYBRID
, применять тот же стиль, но установить оба стайлера видимости на на
В конце концов это может выглядеть так:
google.maps.event.addListener(map, 'maptypeid_changed', function() {
var onoff=(this.getMapTypeId()==google.maps.MapTypeId.HYBRID)
?'off'
:'on';
this.setOptions(
{
styles:[{
featureType: "all",
elementType: "labels",
stylers: [{ visibility:onoff }]
},
{
featureType: "road",
stylers: [{ visibility:onoff}]}
]
}
);
});
google.maps.event.trigger(map,'maptypeid_changed');