您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Shows a layer displaying the available street view roads and locations
当前为
- // ==UserScript==
- // @name WME Street View Availability
- // @namespace http://www.tomputtemans.com/
- // @description Shows a layer displaying the available street view roads and locations
- // @include /^https:\/\/(www|beta)\.waze\.com\/(?!user\/)(.{2,6}\/)?editor\/.*$/
- // @icon 
- // @version 0.6.1
- // @grant none
- // ==/UserScript==
- (function() {
- var tilelayerServers = [
- 'https://mts0.google.com/mapslt',
- 'https://mts1.google.com/mapslt',
- 'https://mts2.google.com/mapslt',
- 'https://mts3.google.com/mapslt'
- ];
- function init(e) {
- if (e && e.user === null) {
- return;
- }
- if (typeof I18n === 'undefined') {
- setTimeout(init, 300);
- return;
- }
- if (typeof Waze === 'undefined' ||
- typeof Waze.loginManager === 'undefined') {
- setTimeout(init, 100);
- return;
- }
- if (!Waze.loginManager.hasUser()) {
- Waze.loginManager.events.register("login", null, init);
- Waze.loginManager.events.register("loginStatus", null, init);
- if (!Waze.loginManager.hasUser()) {
- return;
- }
- }
- if (document.getElementById('layer-switcher') === null && document.getElementById('layer-switcher-group_display') === null) {
- setTimeout(init, 200);
- return;
- }
- var streetViewControl = document.querySelector('.street-view-control');
- if (streetViewControl === null) {
- setTimeout(init, 400);
- log('Street view elements unavailable, retrying in 400ms');
- }
- var enteringStreetView = false, // Set to true when the marker is being dragged to the map
- ignoreStreetViewExit = false; // Set to true to indicate that the street view availability was set to visible manually and should not be reverted
- // Change the opacity with the following bookmarklet:
- // javascript:localStorage.WME_StreetViewAvailability=JSON.stringify({opacity:prompt('Give a percentage between 0 and 100',100)/100});Waze.map.getLayersByName('Street View Availability')[0].setOpacity(JSON.parse(localStorage.WME_StreetViewAvailability).opacity);
- // Add the map layer, hidden by default
- I18n.translations[I18n.currentLocale()].layers.name.street_view_availability = 'Street View Availability';
- var streetViewLayer = new OL.Layer.XYZ('Street View', tilelayerServers[Math.floor(Math.random() * tilelayerServers.length)] + '?lyrs=svv&x=${x}&y=${y}&z=${z}&w=256&h=256&style=40', {
- isBaseLayer: false,
- uniqueName: 'street_view_availability',
- tileSize: new OL.Size(256, 256),
- transitionEffect: 'resize',
- shortcutKey: 'S+t',
- accelerator: 'toggleStreetView',
- zoomOffset: 12,
- displayInLayerSwitcher: true,
- opacity: localStorage.WME_StreetViewAvailability ? JSON.parse(localStorage.WME_StreetViewAvailability).opacity : 1,
- visibility: false
- });
- /*Waze.accelerators.events.register('toggleStreetViewAvailability', this, function() { streetViewLayer.setVisibility(!streetViewLayer.getVisibility()); });
- Waze.accelerators.addAction('toggleStreetViewAvailability', {
- group: 'layers',
- toggler: 'ITEM_STREET_VIEW_AVAILABILITY'
- });
- Waze.accelerators.registerShortcut('S+t', 'toggleStreetViewAvailability');*/
- Waze.map.addLayer(streetViewLayer);
- // Add layer entry in the new layer drawer
- var displayGroupSelector = document.getElementById('layer-switcher-group_display');
- if (displayGroupSelector != null) {
- var displayGroup = displayGroupSelector.parentNode.parentNode.querySelector('.children');
- var toggler = document.createElement('li');
- var togglerContainer = document.createElement('div');
- togglerContainer.className = 'controls-container toggler';
- var checkbox = document.createElement('input');
- checkbox.type = 'checkbox';
- checkbox.id = 'layer-switcher-item_street_view';
- checkbox.disabled = !displayGroupSelector.checked;
- checkbox.className = 'toggle';
- checkbox.addEventListener('click', function(e) {
- streetViewLayer.setVisibility(e.target.checked);
- });
- togglerContainer.appendChild(checkbox);
- var label = document.createElement('label');
- label.htmlFor = checkbox.id;
- var labelText = document.createElement('span');
- labelText.className = 'label-text';
- labelText.appendChild(document.createTextNode('Street View'));
- label.appendChild(labelText);
- togglerContainer.appendChild(label);
- toggler.appendChild(togglerContainer);
- displayGroup.appendChild(toggler);
- displayGroupSelector.addEventListener('change', function() {
- checkbox.disabled = !displayGroupSelector.checked;
- streetViewLayer.setVisibility(displayGroupSelector.checked && checkbox.checked);
- });
- }
- // Add an observer to activate the script whenever the street view marker gets dragged around
- var controlObserver = new MutationObserver(function(mutationRecords) {
- if (mutationRecords[mutationRecords.length-1].target.style.display == 'none' && displayGroupSelector.checked) {
- enteringStreetView = true;
- streetViewLayer.setVisibility(true);
- enteringStreetView = false;
- } else if (!ignoreStreetViewExit) {
- streetViewLayer.setVisibility(false);
- }
- });
- controlObserver.observe(streetViewControl, { attributes: true, attributeFilter: ['style'] });
- // Deal with changes to the layer visibility
- streetViewLayer.events.register('visibilitychanged', null, function() {
- if (!enteringStreetView && streetViewLayer.getVisibility()) {
- ignoreStreetViewExit = true;
- }
- if (!streetViewLayer.getVisibility()) {
- ignoreStreetViewExit = false;
- }
- });
- }
- init();
- function log(message) {
- console.log(message);
- }
- })();