您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
WME script for WazeMY editing moderation
当前为
- // ==UserScript==
- // @name WME WazeMY
- // @namespace https://greasyfork.org/en/scripts/404584-wazemy
- // @version 2022.08.05.02
- // @description WME script for WazeMY editing moderation
- // @author junyianl
- // @match https://beta.waze.com/*
- // @match https://www.waze.com/forum/*
- // @match https://www.waze.com/editor*
- // @match https://www.waze.com/*/editor*
- // @match https://www.waze.com/user/editor*
- // @require https://greasyfork.org/scripts/24851-wazewrap/code/WazeWrap.js
- // @grant GM_xmlhttpRequest
- // @license MIT
- // ==/UserScript==
- // @connect p4.fgies.com
- // @connect www.jalanow.com
- // @connect odis.sgp1.digitaloceanspaces.com
- /* global W */
- /* global WazeWrap */
- /* global $ */
- /* global OL */
- /* global OpenLayers */
- /**
- * All mentions of script names and links in this script is my way of giving credit to where it's due.
- * Without those scripts, I would have no place to start.
- * Big thanks to the original script authors.
- *
- * Huge thanks to Epailxi and dckj for getting the lat/lons for all the cams.
- */
- const updateMessage = "► Add traffic camera layer for Malaysia.";
- var staticUpdateID;
- var trafficCamsData = [
- { desc:'Jalan Sultan Ismail / Jalan Imbi near Berjaya Times Square KL', lat:3.14369, lon:101.71245, url:'https://p4.fgies.com/kl8/img/K012W.jpg' },
- { desc:'Jalan Bukit Bintang / Jalan Raja Chulan near Pavilion KL', lat:3.14833, lon:101.71609, url:'https://p4.fgies.com/kl8/img/K004W.jpg' },
- { desc:'Jalan Sultan Ismail near Sime Darby', lat:3.16102, lon:101.69522, url:'https://p4.fgies.com/kl8/img/K011W.jpg' },
- { desc:'Jalan Sultan Ismail / Jalan P. Ramlee near Shangri-La Hotel', lat:3.15389, lon:101.70761, url:'https://p4.fgies.com/kl8/img/K013W.jpg' },
- { desc:'Jalan Sultan Ismail near Renaissance Hotel', lat:3.15929307072728, lon:101.700892565152, url:'https://p4.fgies.com/kl8/img/K029W.jpg' },
- { desc:'Jalan Raja Laut near KWSP', lat:3.15314, lon:101.69473, url:'https://p4.fgies.com/kl8/img/K037W.jpg' },
- { desc:'Jalan Raja near Stesen LRT Bandaraya', lat:3.15076, lon:101.69461, url:'https://p4.fgies.com/kl8/img/K016W.jpg' },
- { desc:'Bulatan Dato\' Onn near Bank Negara', lat:3.151524, lon:101.693394, url:'https://p4.fgies.com/kl8/img/K036W.jpg' },
- { desc:'Jalan Raja near Dataran Merdeka', lat:3.15130467327156, lon:101.693128740951, url:'https://p4.fgies.com/kl8/img/K028W.jpg' },
- { desc:'Jalan Kuching / Jalan Raja Laut near Bangunan DBKL', lat:3.15328733409485, lon:101.693719456795, url:'https://p4.fgies.com/kl8/img/K001W.jpg' },
- { desc:'Jalan Maharajalela near Maharajalela Monorail Station', lat:3.13992, lon:101.69709, url:'https://p4.fgies.com/kl8/img/K038W.jpg' },
- { desc:'Jalan Kinabalu near Perpustakaan KL', lat:3.14741, lon:101.69247, url:'https://p4.fgies.com/kl8/img/K008W.jpg' },
- { desc:'Jalan Kinabalu near Masjid Negara', lat:3.14325, lon:101.69287, url:'https://p4.fgies.com/kl8/img/K007W.jpg' },
- { desc:'Jalan Kuching near Jalan Sultan Ismail', lat:3.16173, lon:101.69247, url:'https://p4.fgies.com/kl8/img/K047W.jpg' },
- { desc:'Jalan Kuching near Bulatan Kepong', lat:3.20168, lon:101.67037, url:'https://p4.fgies.com/kl8/img/K002W.jpg' },
- { desc:'Jalan Kuching near Hentian Putra / PWTC', lat:3.16693332927155, lon:101.689706476829, url:'https://p4.fgies.com/kl8/img/K046W.jpg' },
- { desc:'Jalan Kuching near Jalan Sultan Ismail', lat:3.16343529038211, lon:101.692232025972, url:'https://p4.fgies.com/kl8/img/K023W.jpg' },
- { desc:'Jalan Tun Razak near Hospital Kuala Lumpur (HKL)', lat:3.17284962099842, lon:101.704733072188, url:'https://p4.fgies.com/kl8/img/K003W.jpg' },
- { desc:'Jalan Tun Razak near U.S Embassy KL', lat:3.15365, lon:101.72267, url:'https://p4.fgies.com/kl8/img/K017W.jpg' },
- { desc:'Jalan Tun Razak near Lembaga Tabung Haji', lat:3.15779, lon:101.72083, url:'https://p4.fgies.com/kl8/img/K024W.jpg' },
- { desc:'Jalan Tuanku Abdul Halim near Taman Duta', lat:3.15073, lon:101.6746, url:'https://p4.fgies.com/kl8/img/K044W.jpg' },
- { desc:'Jalan Tuanku Abdul Halim near Jalan Semantan', lat:3.15269, lon:101.67293, url:'https://p4.fgies.com/kl8/img/K045W.jpg' },
- { desc:'Jalan Damansara near Jalan Istana Lama', lat:3.13603, lon:101.69204, url:'https://p4.fgies.com/kl8/img/K043W.jpg' },
- { desc:'Jalan Syed Putra near Sekolah Kuen Cheng', lat:3.13179, lon:101.69184, url:'https://p4.fgies.com/kl8/img/K034W.jpg' },
- { desc:'Jalan Syed Putra near Kampung Attap', lat:3.13863, lon:101.69531, url:'https://p4.fgies.com/kl8/img/K015W.jpg' },
- { desc:'Jalan Damansara near Carcosa Seri Negara', lat:3.13843, lon:101.68482, url:'https://p4.fgies.com/kl8/img/K005W.jpg' },
- { desc:'Timur–Barat Highway near Bandar Tun Razak', lat:3.09385, lon:101.71095, url:'https://p4.fgies.com/kl8/img/K041W.jpg' },
- { desc:'Timur–Barat Highway near Salak Selatan', lat:3.09785, lon:101.70352, url:'https://p4.fgies.com/kl8/img/K042W.jpg' },
- { desc:'Jalan Cheras near Bulatan Cheras', lat:3.1136, lon:101.72816, url:'https://p4.fgies.com/kl8/img/K031W.jpg' },
- { desc:'Jalan Cheras near Jalan Ikan Ayu', lat:3.11799, lon:101.72806, url:'https://p4.fgies.com/kl8/img/K025W.jpg' },
- { desc:'Bulatan Cheras near Lotus\'s Cheras', lat:3.09925, lon:101.73784, url:'https://p4.fgies.com/kl8/img/K026W.jpg' },
- { desc:'Jalan Sungai Besi Near Lapangan Terbang TUDM', lat:3.12146, lon:101.70823, url:'https://p4.fgies.com/kl8/img/K039W.jpg' },
- { desc:'Jalan Loke Yew near Tsun Jin High School', lat:3.13407, lon:101.70685, url:'https://p4.fgies.com/kl8/img/K035W.jpg' },
- { desc:'Jalan Loke Yew near Viva Shopping Mall', lat:3.11887, lon:101.72196, url:'https://p4.fgies.com/kl8/img/K009W.jpg' },
- { desc:'KL-Seremban Highway near Jalan Sungai Besi (BHP)', lat:3.12252, lon:101.70843, url:'https://p4.fgies.com/kl8/img/K010W.jpg' },
- { desc:'KL-Seremban Highway near Nirvana Memorial Center', lat:3.08873, lon:101.69675, url:'https://p4.fgies.com/kl8/img/K019W.jpg' },
- { desc:'KL-Seremban Highway near Petronas TPM', lat:3.05429, lon:101.70517, url:'https://p4.fgies.com/kl8/img/K040W.jpg' },
- ];
- (function() {
- 'use strict';
- var settings = {};
- function bootstrap(tries = 1) {
- if (W && W.map && W.model && W.loginManager.user &&
- $ && WazeWrap.Ready) {
- init();
- } else if (tries < 1000) {
- setTimeout(function () {bootstrap(++tries);}, 200);
- } else {
- WazeWrap.Alerts.error(GM_info.script.name, "Bootstrap timeout.")
- }
- }
- async function init() {
- let $section = $('<div>');
- $section.html([
- '<div>',
- 'Version: <span id="wazemyVersion"></span><br>',
- '<span id="wazemyUsername"></span> (<span id="wazemyRank"></span>)',
- '</div><br>',
- '<div id="wazemySettings">',
- '<b>Settings</b><br>',
- '<input type="checkbox" id="wazemySettings_tooltip"><label for="wazemySettings_tooltip">Map tooltip</label><br>',
- '<input type="checkbox" id="wazemySettings_trafcam"><label for="wazemySettings_trafcam">Traffic cameras</label><br>',
- '</div><br>',
- '<div>',
- '<b>Shortcuts</b><br>',
- 'Ctrl+Alt+C: Copy lat/lon of mouse position to clipboard.<br>',
- '</div>'
- ].join(' '));
- // Initialize features of WME WazeMY
- wazemyTooltip_init();
- wazemyTrafcam_init();
- new WazeWrap.Interface.Tab('WazeMY', $section.html(), initializeSettings);
- WazeWrap.Interface.ShowScriptUpdate("WME WazeMY", GM_info.script.version,
- updateMessage,
- "https://greasyfork.org/en/scripts/404584-wazemy", null);
- // Initialize keyboard shortcuts
- new WazeWrap.Interface.Shortcut('WazeMY_latloncopy', 'Copies lat/lon of mouse position', 'wazemy', 'WazeMY', 'CA+c', wazemyCopyLatLon, null).add();
- }
- /* ******* */
- /* Tooltip */
- /* ******* */
- function wazemyTooltip_init() {
- let $tooltip = $('<div/>');
- $tooltip.attr('id', 'wazemyTooltip');
- $tooltip.css({
- 'height':'auto',
- 'width':'auto',
- 'background':'rgba(0,0,0,0.5)',
- 'color':'white',
- 'borderRadius':'5px',
- 'padding':'5px',
- 'position':'absolute',
- 'top':'0px',
- 'left':'0px',
- 'visibility':'hidden',
- 'zIndex':'10000'
- })
- $tooltip.appendTo('body');
- }
- function wazemyTooltip_initSettings() {
- setChecked('wazemySettings_tooltip', settings.tooltip);
- if (settings.tooltip) {
- WazeWrap.Events.register('mousemove', null, wazemyTooltip_show);
- }
- $('#wazemySettings_tooltip').change(function () {
- var settingName = $(this)[0].id.substr(15); // strip off the "wazemySettings_" prefix
- settings[settingName] = this.checked;
- saveSettings();
- if (this.checked) {
- WazeWrap.Events.register('mousemove', null, wazemyTooltip_show);
- }
- else {
- WazeWrap.Events.unregister('mousemove', null, wazemyTooltip_show);
- }
- });
- }
- function wazemyTooltip_show(e) { // from URO+
- var result = '';
- var showTooltip = false;
- let landmark = W.map.venueLayer.getFeatureBy('renderIntent', 'highlight');
- let segment = W.map.segmentLayer.getFeatureBy('renderIntent', 'highlight');
- if (landmark != null) {
- result = '<b>' + landmark.model.attributes.name + '</b><br>';
- let address = landmark.model.getAddress();
- try {
- result += address.attributes.houseNumber ? (address.attributes.houseNumber + ', ') : ''
- result += (address.attributes.street.name ? address.attributes.street.name : 'No street') + '<br>';
- result += address.attributes.city.attributes.name + ', ';
- result += address.attributes.state.name + '<br>';
- }
- catch {
- result += 'No address<br>';
- }
- result += '<b>Lock:</b> ' + (landmark.model.getLockRank() + 1);
- showTooltip = true;
- } else if (segment != null) {
- let segmentId = segment.model.attributes.id;
- // let primaryStreetId = WazeWrap.Model.getPrimaryStreetId(segmentId);
- let address = segment.model.getAddress();
- result = '<b>' + (address.attributes.street.name ? address.attributes.street.name : 'No street') + '</b><br>';
- result += address.attributes.city.attributes.name + ', ' + address.attributes.state.name + '<br>';
- result += '<b>ID:</b> ' + segmentId + '<br>';
- result += '<b>Lock:</b> ' + (segment.model.getLockRank() + 1);
- showTooltip = true;
- }
- if (showTooltip == true) {
- let tw = $('#wazemyTooltip').width();
- let th = $('#wazemyTooltip').height();
- var tooltipX = e.clientX + window.scrollX + 15;
- var tooltipY = e.clientY + window.scrollY + 15;
- if ((tooltipX + tw) > W.map.$map.innerWidth()) {
- tooltipX -= tw + 20; // 20 = scroll bar size
- if (tooltipX < 0) tooltipX = 0;
- }
- if ((tooltipY + th) > W.map.$map.innerHeight()) {
- tooltipY -= th + 20;
- if (tooltipY < 0) tooltipY = 0;
- }
- $('#wazemyTooltip').html(result);
- $('#wazemyTooltip').css({
- 'top':tooltipY + 'px',
- 'left':tooltipX + 'px',
- 'visibility':'visible'
- });
- } else {
- $('#wazemyTooltip').css('visibility', 'hidden');
- }
- }
- /* *************** */
- /* Traffic cameras */
- /* *************** */
- // Adapted from WME DOT Cameras
- var wazemyTrafcamLayer;
- function wazemyTrafcam_init() {
- if (!OpenLayers.Icon) {
- wazemyTrafcam_installIconClass();
- }
- wazemyTrafcamLayer = new OpenLayers.Layer.Markers("wazemyTrafcamLayer");
- W.map.addLayer(wazemyTrafcamLayer);
- wazemyTrafcam_show();
- wazemyTrafcamLayer.setVisibility(false);
- }
- function wazemyTrafcam_initSettings() {
- setChecked('wazemySettings_trafcam', settings.trafcam);
- if (settings.trafcam) {
- wazemyTrafcamLayer.setVisibility(true);
- // WazeWrap.Events.register('moveend', null, wazemyTrafcam_show);
- }
- $('#wazemySettings_trafcam').change(function () {
- var settingName = $(this)[0].id.substr(15); // strip off the "wazemySettings_" prefix
- settings[settingName] = this.checked;
- saveSettings();
- if (this.checked) {
- wazemyTrafcamLayer.setVisibility(true);
- // WazeWrap.Events.register('moveend', null, wazemyTrafcam_show);
- } else {
- // WazeWrap.Events.unregister('moveend', null, wazemyTrafcam_show);
- wazemyTrafcamLayer.setVisibility(false);
- }
- });
- }
- function wazemyTrafcam_show(e) {
- trafficCamsData.forEach(e => {
- wazemyTrafcam_drawCam({
- desc:e.desc,
- src:e.url,
- width:20,
- height:20,
- lat:e.lat,
- lon:e.lon
- });
- });
- }
- function wazemyTrafcam_drawCam(spec) {
- const camIcon = '';
- let size = new OpenLayers.Size(20,20);
- let icon = new OpenLayers.Icon(camIcon, size);
- // let offset = new OpenLayers.Pixel(-(size.w/2), -size.h);
- let epsg4326 = new OpenLayers.Projection("EPSG:4326"); // WGS 1984 projection. Malaysia uses EPSG:900913
- let projectTo = W.map.getProjectionObject();
- let lonLat = new OpenLayers.LonLat(spec.lon, spec.lat).transform(epsg4326, projectTo);
- var newMarker = new OpenLayers.Marker(lonLat, icon);
- newMarker.title = spec.desc;
- newMarker.url = spec.src;
- newMarker.width = spec.width;
- newMarker.height = spec.height;
- newMarker.location = lonLat;
- newMarker.events.register('click', newMarker, wazemyTrafcam_popupCam);
- wazemyTrafcamLayer.addMarker(newMarker);
- }
- function wazemyTrafcam_popupCam(e) {
- console.log("wazemyTrafcam_popupCam");
- clearInterval(staticUpdateID);
- $("#gmPopupContainerCam").remove();
- $("#gmPopupContainerCam").hide();
- var popupHTML = (['<div id="gmPopupContainerCam" style="margin: 1;text-align: center;padding: 5px;z-index: 1100; position: absolute; color: white; background: rgba(0,0,0,0.5)">' +
- '<a href="#close" id="gmCloseCamDlgBtn" title="Close" style="color:red">X</a>' +
- '<table border=0><tr><td><div id="mycamdivheader" style="min-height: 20px;">' + this.title + '</div></td></tr>' +
- '<tr><td><img style="width:400px" id="staticimage"></td></tr>' +
- '</table></div>'
- ]);
- $("body").append(popupHTML);
- GM_xmlhttpRequest({
- method: 'GET',
- responseType: 'blob',
- headers: {
- "authority":"p4.fgies.com",
- "referer":'https://www.jalanow.com/',
- 'accept':'image/avif,image/webp,image/apng,image/svg+xml,image/*,*/*;q=0.8'
- },
- url: this.url,
- onload: function (response) {
- document.getElementById('staticimage').src = URL.createObjectURL(response.response);
- }
- });
- $("#gmPopupContainerCam").css({ left: e.clientX + window.scrollX + 15 });
- $("#gmPopupContainerCam").css({ top: e.clientY + window.scrollY + 15 });
- //Add listener for popup's "Close" button
- $("#gmCloseCamDlgBtn").click(function () {
- clearInterval(staticUpdateID);
- $("#gmPopupContainerCam").remove();
- $("#gmPopupContainerCam").hide();
- });
- wazemyTrafcam_dragElement(document.getElementById("gmPopupContainerCam"));
- }
- function wazemyTrafcam_installIconClass() {
- OpenLayers.Icon = OpenLayers.Class({
- url: null,
- size: null,
- offset: null,
- calculateOffset: null,
- imageDiv: null,
- px: null,
- initialize: function (a, b, c, d) {
- this.url = a;
- this.size = b || {
- w: 20,
- h: 20
- };
- this.offset = c || {
- x: -(this.size.w / 2),
- y: -(this.size.h / 2)
- };
- this.calculateOffset = d;
- a = OpenLayers.Util.createUniqueID("OL_Icon_");
- let div = this.imageDiv = OpenLayers.Util.createAlphaImageDiv(a);
- $(div.firstChild).removeClass('olAlphaImg'); // LEAVE THIS LINE TO PREVENT WME-HARDHATS SCRIPT FROM TURNING ALL ICONS INTO HARDHAT WAZERS --MAPOMATIC
- },
- destroy: function () {
- this.erase();
- OpenLayers.Event.stopObservingElement(this.imageDiv.firstChild);
- this.imageDiv.innerHTML = "";
- this.imageDiv = null;
- },
- clone: function () {
- return new OpenLayers.Icon(this.url, this.size, this.offset, this.calculateOffset);
- },
- setSize: function (a) {
- null !== a && (this.size = a);
- this.draw();
- },
- setUrl: function (a) {
- null !== a && (this.url = a);
- this.draw();
- },
- draw: function (a) {
- OpenLayers.Util.modifyAlphaImageDiv(this.imageDiv, null, null, this.size, this.url, "absolute");
- this.moveTo(a);
- return this.imageDiv;
- },
- erase: function () {
- null !== this.imageDiv && null !== this.imageDiv.parentNode && OpenLayers.Element.remove(this.imageDiv);
- },
- setOpacity: function (a) {
- OpenLayers.Util.modifyAlphaImageDiv(this.imageDiv, null, null, null, null, null, null, null, a);
- },
- moveTo: function (a) {
- null !== a && (this.px = a);
- null !== this.imageDiv && (null === this.px ? this.display(!1) : (
- this.calculateOffset && (this.offset = this.calculateOffset(this.size)),
- OpenLayers.Util.modifyAlphaImageDiv(this.imageDiv, null, {
- x: this.px.x + this.offset.x,
- y: this.px.y + this.offset.y
- })
- ));
- },
- display: function (a) {
- this.imageDiv.style.display = a ? "" : "none";
- },
- isDrawn: function () {
- return this.imageDiv && this.imageDiv.parentNode && 11 != this.imageDiv.parentNode.nodeType;
- },
- CLASS_NAME: "OpenLayers.Icon"
- });
- }
- // Make the DIV element draggable:
- function wazemyTrafcam_dragElement(elmnt) {
- var pos1 = 0, pos2 = 0, pos3 = 0, pos4 = 0;
- if (document.getElementById("mycamdivheader")) {
- // if present, the header is where you move the DIV from:
- document.getElementById("mycamdivheader").onmousedown = dragMouseDown;
- } else {
- // otherwise, move the DIV from anywhere inside the DIV:
- elmnt.onmousedown = dragMouseDown;
- }
- function dragMouseDown(e) {
- e = e || window.event;
- e.preventDefault();
- // get the mouse cursor position at startup:
- pos3 = e.clientX;
- pos4 = e.clientY;
- document.onmouseup = closeDragElement;
- // call a function whenever the cursor moves:
- document.onmousemove = elementDrag;
- }
- function elementDrag(e) {
- e = e || window.event;
- e.preventDefault();
- // calculate the new cursor position:
- pos1 = pos3 - e.clientX;
- pos2 = pos4 - e.clientY;
- pos3 = e.clientX;
- pos4 = e.clientY;
- // set the element's new position:
- elmnt.style.top = (elmnt.offsetTop - pos2) + "px";
- elmnt.style.left = (elmnt.offsetLeft - pos1) + "px";
- }
- function closeDragElement() {
- // stop moving when mouse button is released:
- document.onmouseup = null;
- document.onmousemove = null;
- }
- }
- /* ************ */
- /* Copy lat/lon */
- /* ************ */
- function wazemyCopyLatLon(){
- copyToClipboard($('.mouse-position').text());
- }
- function initializeSettings() {
- loadSettings();
- $('#wazemyVersion').text(GM_info.script.version);
- $('#wazemyUsername').text(WazeWrap.User.Username());
- $('#wazemyRank').text(WazeWrap.User.Rank());
- wazemyTooltip_initSettings();
- wazemyTrafcam_initSettings();
- }
- function saveSettings() {
- if (localStorage) {
- var localsettings = {
- tooltip: settings.tooltip,
- trafcam: settings.trafcam
- };
- localStorage.setItem('WME_wazemySettings', JSON.stringify(localsettings));
- }
- }
- function loadSettings() {
- var loadedSettings = $.parseJSON(localStorage.getItem("WME_wazemySettings"));
- var defaultSettings = {
- tooltip: false,
- };
- settings = loadedSettings ? loadedSettings : defaultSettings;
- for (var prop in defaultSettings) {
- if (!settings.hasOwnProperty(prop)) {
- settings[prop] = defaultSettings[prop];
- }
- }
- }
- function setChecked(checkboxId, checked) {
- $('#' + checkboxId).prop('checked', checked);
- }
- // utility functions
- var copyToClipboard = function(str) { // from PIE
- var $temp = $('<input>');
- $('body').append($temp);
- $temp.val(str).select();
- document.execCommand('copy');
- $temp.remove();
- };
- bootstrap();
- })();