Regenradar-Prognose.
Wäre das etwas?
Regenradar-Prognose.
Wäre das etwas?
Wäre das etwas?
Ja, habe aber jetzt auf die Schnelle dort nur etwas für das gesamte Deutschland gefunden und für die drei angeblich mitteldeutschen Bundesländer, nur Sachsen wäre mir lieber. Aber wie gesagt, nur auf die Schnelle. Und für die EU scheint es auch nichts zu geben. Aber für Deutschland kann man diese Seite auf jeden Fall nehmen.
Edit: Mit den mitteldeutschen Ländern (Ost) betrifft den Regenradar nicht die Regenradar-Prognose.
Frage, bei Wetterkontor gibt es jetzt auch:
Thermische Belastung - WetterKontor
Befinden und Gesundheit - WetterKontor
Könnte man als weitere Einträge einbinden, was meint ihr?
Das Skript bietet vier Optionen für die Erstellung eines Screenshots einer Seite
// SavePageAsPNG.uc.js
(async func => CustomizableUI.createWidget({
id: "SavePageAsPNG",
label: "Save Page As PNG",
tooltiptext: "Save Page As PNG",
localized: false,
// defaultArea: CustomizableUI.AREA_NAVBAR,
onCreated(btn) {
var win = btn.ownerGlobal;
new win.Function("_id, xhtmlns, addDestructor", func.toString().slice(7, -1)).call(
btn, this.id, "http://www.w3.org/1999/xhtml",
destructor => win.addEventListener("unload", destructor, {once: true})
);
btn.setAttribute("image", "");
}
}))(() => {
((main, parts) => this._handleClick = () => {
var df = MozXULElement.parseXULToFragment(`
<menupopup>
<menuitem class="menuitem-iconic"
image=""
label="Save whole page as PNG"
value="all"/>
<menuitem class="menuitem-iconic"
image=""
label="Save visible part of the page as PNG"
value="page"/>
<menuitem class="menuitem-iconic"
image=""
label="Save selected page element as PNG"
value="click"/>
<menuitem class="menuitem-iconic"
image=""
label="Save selected page area as PNG"
value="clipping"/>
</menupopup>
`);
var popup = df.firstChild;
popup.setAttribute("context", "");
popup.addEventListener("command", e => popup.handleCommand(e));
popup.handleCommand = e => {
var name = _id + ":DataURLReady";
main = main.replace("%MESSAGE_NAME%", name);
var urls = {}, configurable = true, enumerable = true;
Object.entries(parts).forEach(([key, part]) => Object.defineProperty(urls, key, {
configurable, enumerable, get() {
var value = `data:;charset=utf-8,({${
encodeURIComponent(main + part)
}%0A}).init("${key}")`;
Object.defineProperty(urls, key, {configurable, enumerable, value});
return value;
}}));
// Get tab name without non-saved characters and extra spaces
var getTabLabel = () => {
var label = gBrowser.selectedTab.label;
var label = label.replace(/[:+.\\\/<>?*|"]+/g, " ").replace(/\s\s+/g, " ");
return label.substring(0, 50);
}
var listener = msg => {
var fp = makeFilePicker();
// fp.init(window, "Save As…", fp.modeSave);
fp.init(
!("inIsolatedMozBrowser" in window.browsingContext.originAttributes)
? window.browsingContext
: window
, "Save As…", fp.modeSave);
fp.appendFilter("", "*.png");
var fileName = getTabLabel();
fileName = fileName.replace(/[:\\\/<>?*|"]+/g, '').replace(/\s+/g, '_').slice(0, 100).replace(/^\s+|\s+$/g, '');
var fileDate = (function () {
var d = new Date(), z = function(n){return (n < 10 ? '0' : '') + n};
return '[' + z(d.getFullYear()) + '_' + z(d.getMonth()+1) + '_' + z(d.getDate()) + '\u2014' + z(d.getHours()) + '_' + z(d.getMinutes()) + '_' + z(d.getSeconds()) + ']';
})();
fp.defaultString = fileName + "_" + fileDate + ".png";
fp.open(res => res == fp.returnCancel || !fp.file || makeWebBrowserPersist().saveURI(
Services.io.newURI(msg.data), document.nodePrincipal,
null, null, null, null, null, fp.file, null, null
));
}
messageManager.addMessageListener(name, listener);
addDestructor(() => messageManager.removeMessageListener(name, listener));
(popup.handleCommand = e => gBrowser.selectedBrowser.messageManager
.loadFrameScript(urls[e.target.value], false)
)(e);
}
this.append(df);
(this._handleClick = () => popup.openPopup(this, "after_start"))();
})(`
init(cmd) {
cmd.startsWith("c")
? this[cmd].init(this[cmd].parent = this)
: this[cmd]();
},
capture(win, x, y, width, height) {
var canvas = win.document.createElementNS("${xhtmlns}", "canvas");
canvas.width = width;
canvas.height = height;
var ctx = canvas.getContext("2d");
var tryDraw = ind => {
try {ctx.drawWindow(win, x, y, canvas.width, canvas.height, "white")}
catch(ex) {canvas.height = ind * canvas.width; tryDraw(--ind);}
}
tryDraw(17);
sendAsyncMessage("%MESSAGE_NAME%", canvas.toDataURL("image/png"));
},
`, {
all: `all() {
var win = content;
this.capture(win, 0, 0, win.innerWidth + win.scrollMaxX, win.innerHeight + win.scrollMaxY);
}`,
page: `page() {
var win = content, doc = win.document, body = doc.body, html = doc.documentElement;
var scrX = (body.scrollLeft || html.scrollLeft) - html.clientLeft;
var scrY = (body.scrollTop || html.scrollTop) - html.clientTop;
this.capture(win, scrX, scrY, win.innerWidth, win.innerHeight);
}`,
clipping: `clipping: {
handleEvent(e) {
if (e.button) return false;
e.preventDefault();
e.stopPropagation();
switch(e.type) {
case "mousedown":
this.downX = e.pageX;
this.downY = e.pageY;
this.bs.left = this.downX + "px";
this.bs.top = this.downY + "px";
this.body.appendChild(this.box);
this.flag = true;
break;
case "mousemove":
if (!this.flag) return;
this.moveX = e.pageX;
this.moveY = e.pageY;
if (this.downX > this.moveX) this.bs.left = this.moveX + "px";
if (this.downY > this.moveY) this.bs.top = this.moveY + "px";
this.bs.width = Math.abs(this.moveX - this.downX) + "px";
this.bs.height = Math.abs(this.moveY - this.downY) + "px";
break;
case "mouseup":
this.uninit();
break;
}
},
init() {
var win = {};
Cc["@mozilla.org/focus-manager;1"].getService(Ci.nsIFocusManager)
.getFocusedElementForWindow(content, true, win);
this.win = win.value;
this.doc = this.win.document;
this.body = this.doc.body;
if (!HTMLBodyElement.isInstance(this.body)) {
Cc["@mozilla.org/alerts-service;1"].getService(Ci.nsIAlertsService)
.showAlertNotification("${self.image}", ${JSON.stringify(self.label)}, "Не удается захватить!");
return false;
}
this.flag = null;
this.box = this.doc.createElement("div");
this.bs = this.box.style;
this.bs.border = "red dashed 1px";
this.bs.position = "absolute";
this.bs.zIndex = "2147483647";
this.defaultCursor = this.win.getComputedStyle(this.body, "").cursor;
this.body.style.cursor = "crosshair";
["click", "mouseup", "mousemove", "mousedown"].forEach(type=> this.doc.addEventListener(type, this, true));
},
uninit() {
var pos = [this.win, parseInt(this.bs.left), parseInt(this.bs.top), parseInt(this.bs.width), parseInt(this.bs.height)];
this.body.style.cursor = this.defaultCursor;
this.body.removeChild(this.box);
this.parent.capture.apply(this, pos);
["click", "mouseup", "mousemove", "mousedown"].forEach(type=> this.doc.removeEventListener(type, this, true));
}
}`,
click: `click: {
getPosition() {
var html = this.doc.documentElement;
var body = this.doc.body;
var rect = this.target.getBoundingClientRect();
return [
this.win,
Math.round(rect.left) + (body.scrollLeft || html.scrollLeft) - html.clientLeft,
Math.round(rect.top) + (body.scrollTop || html.scrollTop) - html.clientTop,
parseInt(rect.width),
parseInt(rect.height)
];
},
highlight() {
this.orgStyle = this.target.hasAttribute("style") ? this.target.style.cssText : false;
this.target.style.cssText += "outline: red 1px solid; outline-offset: 1px; -moz-outline-radius: 2px;";
},
lowlight() {
if (this.orgStyle) this.target.style.cssText = this.orgStyle;
else this.target.removeAttribute("style");
},
handleEvent(e) {
switch(e.type){
case "click":
if (e.button) return;
e.preventDefault();
e.stopPropagation();
this.lowlight();
this.parent.capture.apply(this, this.getPosition());
this.uninit();
break;
case "mouseover":
if (this.target) this.lowlight();
this.target = e.target;
this.highlight();
break;
}
},
init() {
this.win = content;
this.doc = content.document;
["click", "mouseover"].forEach(type=> this.doc.addEventListener(type, this, true));
},
uninit() {
this.target = false;
["click", "mouseover"].forEach(type=> this.doc.removeEventListener(type, this, true));
}
}`
});
});
Alles anzeigen
Meinst Du das so:
Genau so.
Nein, Kommando zurück, die Zeile muss doch stehen bleiben
Ja, war ein Fehler von mir, muss natürlich stehenbleiben, gehört ja zu CreateBtn.
Frage, bei Wetterkontor gibt es jetzt auch:
https://www.wetterkontor.de/de/bio/thermische-belastung.asp
https://www.wetterkontor.de/de/bio/befinden-und-gesundheit.aspKönnte man als weitere Einträge einbinden, was meint ihr?
In Anbetracht der Klima-Entwicklung würde ich die auch gut finden!
In Anbetracht der Klima-Entwicklung
Ja, im Frühling wird es wieder wärmer.
im Frühling wird es wieder wärmer.
//
Das ist aber noch ne Weile hin...hier wird es erstmal kälter die nächsten 14 Tage.
//Wer sagt denn, das es nur warme thermische Belastung gibt? Frag mal meine Frau!
nur warme thermische Belastung gibt?
So wird mir das angezeigt:
Dauerfrost jede Nacht, und das im Winter...füher hätte es sowas nicht gegeben.
Dauerfrost jede Nacht, und das im Winter...füher hätte es sowas nicht gegeben.
In Anbetracht der Klima-Entwicklung kann das schon mal vorkommen.
Dauerfrost jede Nacht, und das im Winter...
Frechheit...
Boersenfeger.
Gut dann passen die. habe ich bereits eingebaut.
Alle:
Habe auch begonnen die Seiten die nicht mehr gehen zu ersetzen.
Deutschland Regenradar Prognose fehlt mir noch
und usw.
Weltwetter Vorschlag:
Wetter weltweit | FAZ
Mfg.
Endor
Endor Sieht gut aus!
Deutschland Regenradar Prognose fehlt mir noch
Vorschlag von Andreas in Beitrag #4342.
Weltwetter Vorschlag:
Vorschlag von mir in Beitrag #4341.
Zu #4342 da wäre das die direkte Adresse der Karte:
https://www.windy.com/de/-Regen-Gewitter-rain?rain,50.736,10.536,7
Zu 4341 taugt meiner Meinung nach nicht viel.
Da habe ich ja Alternative.
Generelle Frage: es kommen ja praktisch überall zuerst Abfragen
wegen Cookies usw. Die müssen dann halt zuerst ab-geklickt werden.
Wenn man die ausblendet gehen einige Seiten nicht mehr oder nicht richtig.
Passt das?
Mfg.
Endor
wegen Cookies usw. Die müssen dann halt zuerst ab-geklickt werden.
Oder dauerhaft speichern, wenn man Cookies beim Beenden löschen lässt.
Zu #4342 da wäre das die direkte Adresse der Karte:
Da musst du offensichtlich angemeldet sein oder da irgendwelche Analysen erlauben.
Cookies, schrieb ich ja. Ist aber auf allen Seiten so.