Adds a button in Google maps which opens the same map in OpenStreetMaps
// ==UserScript==
// @name Google Maps → OpenStreetMap button
// @author Krzysztof "Krzysiu" Blachnicki
// @namespace https://github.com/Krzysiu
// @license MIT
// @version 0.3
// @description Adds a button in Google maps which opens the same map in OpenStreetMaps
// @match https://www.google.com/maps/*
// @icon 
// @grant none
// ==/UserScript==
(function () {
'use strict';
const newTab = false; // true - open in new tab; false - open in the same tab
const addPin = true; // make OSM to add pin - useful for finding the place
const waitForBody = setInterval(() => {
if (!document.body) return;
clearInterval(waitForBody);
const btn = document.createElement('div');
btn.textContent = '🌍 OSM';
Object.assign(btn.style, {
position: 'fixed',
bottom: '10px',
left: '50%',
transform: 'translateX(-50%)',
height: '20px',
lineHeight: '20px',
padding: '0 10px',
background: '#1a73e8',
color: '#fff',
fontSize: '12px',
borderRadius: '4px',
cursor: 'pointer',
zIndex: '999999',
userSelect: 'none'
});
btn.addEventListener('click', () => {
const url = window.location.href;
const match = url.match(/@([0-9.]+),([0-9.]+),([0-9.]+)z/);
if (!match) {
alert('Failed to fetch coordinates from URL 😔');
return;
}
const lat = match[1];
const lon = match[2];
const zoom = Math.round(match[3]); // Google gives zoom as float, so round it (it won't be 1:1: zoom, anywways)
// OSM link with "a pin"
const osmUrl = addPin ? `https://www.openstreetmap.org/?mlat=${lat}&mlon=${lon}#map=${zoom}/${lat}/${lon}` : `https://www.openstreetmap.org/#map=${zoom}/${lat}/${lon}`;
if (newTab) window.open(osmUrl, '_blank'); else window.location.href = osmUrl;
});
document.body.appendChild(btn);
}, 300);
})();