// ==UserScript== // @author Hevne // @name ImageOverlay2 // @id ImageOverlay2@McBen // @category Draw // @version 0.0.0 // @namespace https://github.com/jonatkins/ingress-intel-total-conversion // @updateURL https://raw.githubusercontent.com/IITC-CE/Community-plugins/master/dist/McBen/ImageOverlay2.meta.js // @downloadURL https://raw.githubusercontent.com/IITC-CE/Community-plugins/master/dist/McBen/ImageOverlay2.user.js // @description Add an image to your map. // @icon64  // @include https://intel.ingress.com/* // ==/UserScript== function wrapper(SCRIPT_INFO) { /******/ (function(modules) { // webpackBootstrap /******/ // The module cache /******/ var installedModules = {}; /******/ /******/ // The require function /******/ function __webpack_require__(moduleId) { /******/ /******/ // Check if module is in cache /******/ if(installedModules[moduleId]) { /******/ return installedModules[moduleId].exports; /******/ } /******/ // Create a new module (and put it into the cache) /******/ var module = installedModules[moduleId] = { /******/ i: moduleId, /******/ l: false, /******/ exports: {} /******/ }; /******/ /******/ // Execute the module function /******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); /******/ /******/ // Flag the module as loaded /******/ module.l = true; /******/ /******/ // Return the exports of the module /******/ return module.exports; /******/ } /******/ /******/ /******/ // expose the modules object (__webpack_modules__) /******/ __webpack_require__.m = modules; /******/ /******/ // expose the module cache /******/ __webpack_require__.c = installedModules; /******/ /******/ // define getter function for harmony exports /******/ __webpack_require__.d = function(exports, name, getter) { /******/ if(!__webpack_require__.o(exports, name)) { /******/ Object.defineProperty(exports, name, { enumerable: true, get: getter }); /******/ } /******/ }; /******/ /******/ // define __esModule on exports /******/ __webpack_require__.r = function(exports) { /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); /******/ } /******/ Object.defineProperty(exports, '__esModule', { value: true }); /******/ }; /******/ /******/ // create a fake namespace object /******/ // mode & 1: value is a module id, require it /******/ // mode & 2: merge all properties of value into the ns /******/ // mode & 4: return value when already ns object /******/ // mode & 8|1: behave like require /******/ __webpack_require__.t = function(value, mode) { /******/ if(mode & 1) value = __webpack_require__(value); /******/ if(mode & 8) return value; /******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value; /******/ var ns = Object.create(null); /******/ __webpack_require__.r(ns); /******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value }); /******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key)); /******/ return ns; /******/ }; /******/ /******/ // getDefaultExport function for compatibility with non-harmony modules /******/ __webpack_require__.n = function(module) { /******/ var getter = module && module.__esModule ? /******/ function getDefault() { return module['default']; } : /******/ function getModuleExports() { return module; }; /******/ __webpack_require__.d(getter, 'a', getter); /******/ return getter; /******/ }; /******/ /******/ // Object.prototype.hasOwnProperty.call /******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; /******/ /******/ // __webpack_public_path__ /******/ __webpack_require__.p = ""; /******/ /******/ /******/ // Load entry module and return exports /******/ return __webpack_require__(__webpack_require__.s = 2); /******/ }) /************************************************************************/ /******/ ([ /* 0 */ /***/ (function(module, exports) { module.exports = "data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10'/%3E" /***/ }), /* 1 */ /***/ (function(module, exports) { /* * 🍂class ImageOverlay.Rotated * 🍂inherits ImageOverlay * * Like `ImageOverlay`, but rotates and skews the image. This is done by using * *three* control points instead of *two*. * * @example * * ``` * var topleft = L.latLng(40.52256691873593, -3.7743186950683594), * topright = L.latLng(40.5210255066156, -3.7734764814376835), * bottomleft = L.latLng(40.52180437272552, -3.7768453359603886); * * var overlay = L.imageOverlay.rotated("./palacio.jpg", topleft, topright, bottomleft, { * opacity: 0.4, * interactive: true, * attribution: "© Instituto Geográfico Nacional de España" * }); * ``` * */ L.ImageOverlay.Rotated = L.ImageOverlay.extend({ initialize: function (image, topleft, topright, bottomleft, options) { if (typeof (image) === 'string') { this._url = image; } else { // Assume that the first parameter is an instance of HTMLImage or HTMLCanvas this._rawImage = image; } this._topLeft = L.latLng(topleft); this._topRight = L.latLng(topright); this._bottomLeft = L.latLng(bottomleft); L.setOptions(this, options); }, onAdd: function (map) { if (!this._image) { this._initImage(); if (this.options.opacity < 1) { this._updateOpacity(); } } if (this.options.interactive) { L.DomUtil.addClass(this._rawImage, 'leaflet-interactive'); this.addInteractiveTarget(this._rawImage); } map.on('zoomend resetview', this._reset, this); this.getPane().appendChild(this._image); this._reset(); }, onRemove: function (map) { map.off('zoomend resetview', this._reset, this); L.ImageOverlay.prototype.onRemove.call(this, map); }, _initImage: function () { var img = this._rawImage; if (this._url) { img = L.DomUtil.create('img'); img.style.display = 'none'; // Hide while the first transform (zero or one frames) is being done if (this.options.crossOrigin) { img.crossOrigin = ''; } img.src = this._url; this._rawImage = img; } L.DomUtil.addClass(img, 'leaflet-image-layer'); // this._image is reused by some of the methods of the parent class and // must keep the name, even if it is counter-intuitive. var div = this._image = L.DomUtil.create('div', 'leaflet-image-layer ' + (this._zoomAnimated ? 'leaflet-zoom-animated' : '')); this._updateZIndex(); // apply z-index style setting to the div (if defined) div.appendChild(img); div.onselectstart = L.Util.falseFn; div.onmousemove = L.Util.falseFn; img.onload = function () { this._reset(); img.style.display = 'block'; this.fire('load'); }.bind(this); img.alt = this.options.alt; }, _reset: function () { var div = this._image; if (!this._map) { return; } // Project control points to container-pixel coordinates var pxTopLeft = this._map.latLngToLayerPoint(this._topLeft); var pxTopRight = this._map.latLngToLayerPoint(this._topRight); var pxBottomLeft = this._map.latLngToLayerPoint(this._bottomLeft); // Infer coordinate of bottom right var pxBottomRight = pxTopRight.subtract(pxTopLeft).add(pxBottomLeft); // pxBounds is mostly for positioning the
container var pxBounds = L.bounds([pxTopLeft, pxTopRight, pxBottomLeft, pxBottomRight]); var size = pxBounds.getSize(); var pxTopLeftInDiv = pxTopLeft.subtract(pxBounds.min); // LatLngBounds are needed for (zoom) animations this._bounds = L.latLngBounds(this._map.layerPointToLatLng(pxBounds.min), this._map.layerPointToLatLng(pxBounds.max)); L.DomUtil.setPosition(div, pxBounds.min); div.style.width = size.x + 'px'; div.style.height = size.y + 'px'; var imgW = this._rawImage.width; var imgH = this._rawImage.height; if (!imgW || !imgH) { return; // Probably because the image hasn't loaded yet. } // Sides of the control-point box, in pixels // These are the main ingredient for the transformation matrix. var vectorX = pxTopRight.subtract(pxTopLeft); var vectorY = pxBottomLeft.subtract(pxTopLeft); this._rawImage.style.transformOrigin = '0 0'; // The transformation is an affine matrix that switches // coordinates around in just the right way. This is the result // of calculating the skew/rotation/scale matrices and simplyfing // everything. this._rawImage.style.transform = "matrix(" + (vectorX.x / imgW) + ', ' + (vectorX.y / imgW) + ', ' + (vectorY.x / imgH) + ', ' + (vectorY.y / imgH) + ', ' + pxTopLeftInDiv.x + ', ' + pxTopLeftInDiv.y + ')'; }, reposition: function (topleft, topright, bottomleft) { this._topLeft = L.latLng(topleft); this._topRight = L.latLng(topright); this._bottomLeft = L.latLng(bottomleft); this._reset(); }, setUrl: function (url) { this._url = url; if (this._rawImage) { this._rawImage.src = url; } return this; } }); /* 🍂factory imageOverlay.rotated(imageUrl: String|HTMLImageElement|HTMLCanvasElement, topleft: LatLng, topright: LatLng, bottomleft: LatLng, options?: ImageOverlay options) * Instantiates a rotated/skewed image overlay, given the image URL and * the `LatLng`s of three of its corners. * * Alternatively to specifying the URL of the image, an existing instance of `HTMLImageElement` * or `HTMLCanvasElement` can be used. */ L.imageOverlay.rotated = function (imgSrc, topleft, topright, bottomleft, options) { return new L.ImageOverlay.Rotated(imgSrc, topleft, topright, bottomleft, options); }; /***/ }), /* 2 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; // ESM COMPAT FLAG __webpack_require__.r(__webpack_exports__); // CONCATENATED MODULE: ./node_modules/iitcpluginkit/dist/Plugin.js /* * Usage example: import * as Plugin from "../plugin"; class myPlugin implements Plugin.Class { init() { console.log("Hello World!"); } } Plugin.Register(new myPlugin(), "myPlugin"); */ /// function Register(plugin, name) { const setup = () => { window.plugin[name] = plugin; window.plugin[name].init(); }; setup.info = SCRIPT_INFO; if (!window.bootPlugins) { window.bootPlugins = []; } window.bootPlugins.push(setup); if (window.iitcLoaded) { setup(); } } // CONCATENATED MODULE: ./src/target-icon.png /* harmony default export */ var target_icon = (""); // CONCATENATED MODULE: ./src/move-arrows.png /* harmony default export */ var move_arrows = (""); // EXTERNAL MODULE: ./src/empty.svg var empty = __webpack_require__(0); var empty_default = /*#__PURE__*/__webpack_require__.n(empty); // CONCATENATED MODULE: ./src/Main.ts // eslint-disable-next-line @typescript-eslint/no-unsafe-call __webpack_require__(1); class Main_ImageOverlay2 { constructor() { this.settings = { imgUrl: empty_default.a, opacity: 0.5, noRotate: false, firstRun: true, latlng: [[1, 1], [1, 1], [1, 1]] }; } init() { console.log("ImageOverlay2 " + "v0.0.0"); this.loadStore(); this.createMarkers(); this.createImage(); window.map.on("layeradd", (event) => { if (event.layer === this.overlay) { this.overlay.bringToBack(); } }); this.addToolbar(); } createMarkers() { const icon = L.icon({ iconUrl: target_icon, iconSize: [32, 32], iconAnchor: [16, 16] }); const iconMove = L.icon({ iconUrl: move_arrows, iconSize: [32, 32], iconAnchor: [16, 16] }); this.markers = [ L.marker(L.latLng(this.settings.latlng[0]), { draggable: true, icon }) .on("drag dragend", event => this.onMarkerMoved(event)), L.marker(L.latLng(this.settings.latlng[1]), { draggable: true, icon }) .on("drag dragend", event => this.onMarkerMoved(event)), L.marker(L.latLng(this.settings.latlng[2]), { draggable: true, icon }) .on("drag dragend", event => this.onMarkerMoved(event)), L.marker(L.latLng(0, 0), { draggable: true, icon: iconMove }) .on("drag dragend", event => this.onMoverDragged(event)) ]; this.markers[3 /* Move */].setLatLng(this.getCenter()); } getCenter() { const l1 = this.markers[1].getLatLng(); const l2 = this.markers[2].getLatLng(); return L.latLng((l1.lat + l2.lat) / 2, (l1.lng + l2.lng) / 2); } showMarkers() { this.markers.forEach(m => m.addTo(window.map)); } hideMarkers() { this.markers.forEach(m => window.map.removeLayer(m)); } resetMarkerPositions() { const bounds = window.map.getBounds(); const dlng = (bounds.getEast() - bounds.getWest()) * 0.4; const dlat = (bounds.getSouth() - bounds.getNorth()) * 0.2; this.markers[0 /* NW */].setLatLng(L.latLng(bounds.getNorth() + dlat, bounds.getWest() + dlng)); this.markers[1 /* NE */].setLatLng(L.latLng(bounds.getNorth() + dlat, bounds.getEast() - dlng)); this.markers[2 /* SW */].setLatLng(L.latLng(bounds.getSouth() - dlat, bounds.getWest() + dlng)); this.markers[3 /* Move */].setLatLng(this.getCenter()); if (this.overlay) { this.repositionImage(); } } clearContents() { this.setNewImage(empty_default.a); } onMoverDragged(_event) { const center = this.getCenter(); const l0 = this.markers[3 /* Move */].getLatLng(); const dlat = l0.lat - center.lat; const dlng = l0.lng - center.lng; this.markers.forEach((m, index) => { if (index !== 3 /* Move */) { const l = m.getLatLng(); m.setLatLng(L.latLng(l.lat + dlat, l.lng + dlng)); } }); this.repositionImage(); } onMarkerMoved(event) { if (this.settings.noRotate) { const l0 = this.markers[0 /* NW */].getLatLng(); const l1 = this.markers[1 /* NE */].getLatLng(); const l2 = this.markers[2 /* SW */].getLatLng(); if (event.target === this.markers[0 /* NW */]) { l1.lat = l0.lat; l2.lng = l0.lng; } else if (event.target === this.markers[1 /* NE */]) { l0.lat = l1.lat; } else if (event.target === this.markers[2 /* SW */]) { l0.lng = l2.lng; } this.markers[0 /* NW */].setLatLng(l0); this.markers[1 /* NE */].setLatLng(l1); this.markers[2 /* SW */].setLatLng(l2); } this.markers[3 /* Move */].setLatLng(this.getCenter()); this.repositionImage(); } repositionImage() { var _a; (_a = this.overlay) === null || _a === void 0 ? void 0 : _a.reposition(this.markers[0 /* NW */].getLatLng(), this.markers[1 /* NE */].getLatLng(), this.markers[2 /* SW */].getLatLng()); } showDialog() { const html = $("").append($("
").append($("