您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Open selected element in Josm
当前为
// ==UserScript== // @name OpenInJosm // @namespace https://github.com/infeeeee/userscripts // @version 0.3 // @description Open selected element in Josm // @author infeeeee // @match *://*.openstreetmap.org/* // @exclude *://*.openstreetmap.org/id* // @grant none // ==/UserScript== function openJosm() { let id = location.href.match(/www\.openstreetmap\.org\/(?:(relation|node|way|changeset|note)\/(\d+))?.*(\#map=)(\d{1,2}(?:\/-?[\d\.]+){2})/) console.log(id) if (id) { switch (id[1]) { case "changeset": case "note": window.open('http://127.0.0.1:8111/import?url=https://www.openstreetmap.org/api/0.6/' + id[1] + '/' + id[2] + '/download') break; case undefined: { let zll = id[4].split("/") let bbox = calcBbox(zll) window.open('http://127.0.0.1:8111/load_and_zoom?left=' + bbox[0] + '&right=' + bbox[1] + '&top=' + bbox[2] + '&bottom=' + bbox[3]) break; } default: { let obj = id[1].split("")[0] window.open('http://127.0.0.1:8111/load_object?objects=' + obj + id[2]) break; } } } else { alert('Something is wrong! Please open an issue on Github and include your current url!') } } function calcBbox(zll) { let zoom = parseInt(zll[0]) let x = parseFloat(zll[1]) let y = parseFloat(zll[2]) let left = y - 0.005 let right = y + 0.005 let top = x + 0.005 let bottom = x - 0.005 return [left.toFixed(4), right.toFixed(4), top.toFixed(4), bottom.toFixed(4)] } (function () { 'use strict'; const element = document.createElement("a") element.innerHTML = "Open in JOSM" element.style.cssText = "height: 100%; margin-left: 1rem; padding: 0 0.75rem; cursor: pointer; border: 1px solid #7ebc6f; border-radius: 3px; background: white; color: #7ebc6f; vertical-align: middle; display: inline-flex; align-items: center;"; element.style.zIndex = 99999 element.onmouseenter = () => { element.style.background = "#7ebc6f" element.style.color = "#fff" } element.onmouseleave = () => { element.style.background = "#fff" element.style.color = "#7ebc6f" } element.onclick = () => { openJosm() } document.getElementsByClassName("primary")[0].appendChild(element) })()