WME Street View Availability

Shows a layer displaying the available street view roads and locations

目前為 2016-11-20 提交的版本,檢視 最新版本

您需要先安裝使用者腳本管理器擴展,如 TampermonkeyGreasemonkeyViolentmonkey 之後才能安裝該腳本。

You will need to install an extension such as Tampermonkey to install this script.

您需要先安裝使用者腳本管理器擴充功能,如 TampermonkeyViolentmonkey 後才能安裝該腳本。

您需要先安裝使用者腳本管理器擴充功能,如 TampermonkeyUserscripts 後才能安裝該腳本。

你需要先安裝一款使用者腳本管理器擴展,比如 Tampermonkey,才能安裝此腳本

您需要先安裝使用者腳本管理器擴充功能後才能安裝該腳本。

(我已經安裝了使用者腳本管理器,讓我安裝!)

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

(我已經安裝了使用者樣式管理器,讓我安裝!)

// ==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.5
// @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') {
      log('No internationalisation object found yet, snoozing');
      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;
      }
    }

    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);

    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',
      zoomOffset: 12,
      displayInLayerSwitcher: true,
      opacity: localStorage.WME_StreetViewAvailability ? JSON.parse(localStorage.WME_StreetViewAvailability).opacity : 1,
      visibility: false
    });
    Waze.map.addLayer(streetViewLayer);
    var controlObserver = new MutationObserver(function(mutationRecords) {
      console.log('Observer: entering street view', mutationRecords[mutationRecords.length-1].target.style.display == 'none');
      if (mutationRecords[mutationRecords.length-1].target.style.display == 'none') {
        enteringStreetView = true;
        streetViewLayer.setVisibility(true);
        enteringStreetView = false;
      } else if (!ignoreStreetViewExit) {
        streetViewLayer.setVisibility(false);
      }
    });
    controlObserver.observe(streetViewControl, { attributes: true, attributeFilter: ['style'] });
    streetViewLayer.events.register('visibilitychanged', null, function() {
      if (!enteringStreetView && streetViewLayer.getVisibility()) {
        ignoreStreetViewExit = true;
      }
      if (!streetViewLayer.getVisibility()) {
        ignoreStreetViewExit = false;
      }
    });
  }
  init();

  function log(message) {
    console.log(message);
  }
})();