您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
zeigt den transfer an und die downloadmenge der aktuellen sessin und den doownload seid
当前为
此脚本不应直接安装。它是供其他脚本使用的外部库,要使用该库请加入元指令 // @require https://update.greasyfork.icu/scripts/489860/1343193/Erweiterung%20%28Zusatzinfos%29%20f%C3%BCr%20das%20gesehene%20Videos%20ausblenden%20oder%20markieren.js
// ==UserScript== // @name Erweiterung (Zusatzinfos) für das gesehene Videos ausblenden oder markieren // @namespace https://basti1012.bplaced.net // @version 1.3 // @description zeigt den transfer an und die downloadmenge der aktuellen sessin und den doownload seid // installatiion des scriptes // Man kann sich auch die Mausdiztanz der aktuellen session und die komplette edntfernung // der maus seid installation des scriptes // @author basti1012 // @allFrames true // @run-at document-end // @license MIT License // @noframes // @icon https://basti1012.de/images/favicon.png // ==/UserScript== (function(){ 'use strict'; var start3 = performance.now(); if(!array_localsdtorage){ var array_localsdtorage=[]; } if(!erweiterungs_einstellungs_array){ var erweiterungs_einstellungs_array=[]; } array_localsdtorage.push(["zusatzinfos_einblenden",true],["transfer_gesamt",0],["transfer_style",""],["transfer_style_image_meter",""],["transfer_style_image_down",""],["selector_zusatzinformationen","title"],["mouse_oder_datentransfer", true],["mouse_distans_session", 0],["mouse_distans_immer", 0]); function zusatzinfos_einblenden_anzeigen(){ var ww=''; if(localStorage.getItem('zusatzinfos_einblenden')=='true'){ if(!localStorage.getItem('selector_zusatzinformationen')){ ww=''; }else{ ww=localStorage.getItem('selector_zusatzinformationen'); } if(localStorage.getItem('mouse_oder_datentransfer')=='true'){ // localStorage.setItem('mouse_distans_session',0); var totalDistance = 0; var lastSeenAt = { x: null, y: null }; var var_immer=parseInt(localStorage.getItem('mouse_distans_immer')); var var_session=parseInt(localStorage.getItem('mouse_distans_session')); document.addEventListener('mousemove',function(event) { if(lastSeenAt.x){ totalDistance += Math.sqrt(Math.pow(lastSeenAt.y - event.clientY, 2) + Math.pow(lastSeenAt.x - event.clientX, 2)); document.querySelector(ww).innerHTML=` Pixels: ${Math.round(totalDistance)} <br> Zentimeter : ${((totalDistance / 75) / 10).toFixed(0)} <br> Meter : ${(((totalDistance) / 75) / 1000).toFixed(2)}<br> Seid Beginn Pixel : ${((var_immer+totalDistance).toFixed(0))} px <br> Seid Beginn Zentimeter : ${((((var_immer+totalDistance)) / 75) / 1).toFixed(0)} <br> Seid beginn Meter : ${(((var_immer+totalDistance) / 75) / 100).toFixed(2)} <br>`; if(ww=='title'){ document.querySelector(ww).innerHTML=` Pixel: ${Math.round(totalDistance)}, Zentimeter : ${((totalDistance / 75) / 10).toFixed(0)} , Meter : ${(((totalDistance) / 75) / 1000).toFixed(2)}, Gesamt Pixel : ${((var_immer+totalDistance).toFixed(0))} , Gesamt Zentimeter : ${((((var_immer+totalDistance)) / 75) / 1).toFixed(0)}, Gesamt Meter : ${(((var_immer+totalDistance) / 75) / 100).toFixed(2)} `; } } localStorage.setItem('mouse_distans_immer',(var_immer+totalDistance)); localStorage.setItem('mouse_distans_session',(var_session+totalDistance)); lastSeenAt.x = event.clientX; lastSeenAt.y = event.clientY; }); localStorage.setItem('mouse_distans_immer',(var_immer+totalDistance)); localStorage.setItem('mouse_distans_session',(var_session+totalDistance)); return 5; }else{ var trafficDiv=''; var meter_image; var download_image; if(location.href.indexOf('youtube')!=-1){ try{ ww='#search-form';//localStorage.getItem('selector_zusatzinformationen').trim(); const set_timeout_var=10000; }catch(e){ ww='title';//localStorage.getItem('selector_zusatzinformationen').trim(); const set_timeout_var=500; } console.log(ww,"Auf youtube"); }else{ ww=localStorage.getItem('selector_zusatzinformationen').trim(); const set_timeout_var=500; } if(localStorage.getItem('transfer_style_image_down')==''){ var down_image_base64=``; }else{ var down_image_base64=localStorage.getItem('transfer_style_image_down'); } if(localStorage.getItem('transfer_style_image_meter')==''){ var meter_image_base64=''; }else{ var meter_image_base64=localStorage.getItem('transfer_style_image_meter'); } function starte(){ console.log('%cZusatzinfos aktiviert'+ (performance.now() - start3) + ' ms.','color:green'); try{ if(ww!='title'){ GM_addStyle(` #traffic_anzeige img,${ww} img{ height:11px !important; } .bi::before, [class="bi"]::before, [class="b"]::before { display: inline-block; font-display: block; font-family: bootstrap-icons !important; font-style: normal; font-weight: normal !important; font-variant: normal; text-transform: none; line-height: 1; vertical-align: -0.125em; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }` ); } if(ww=='title'){ trafficDiv = document.querySelector('title'); meter_image=`🕐`; download_image=`⬇`; }else if(ww!='' && ww!='title'){ if(localStorage.getItem('transfer_style')==''){ GM_addStyle(`@import url("https://cdn.jsdelivr.net/npm/[email protected]/font/bootstrap-icons.css");`); //console.log('was steht in ww '+ww) trafficDiv = document.querySelector(ww); //console.log(trafficDiv) trafficDiv.style=`height:auto !important;pointer-events:none;position:fixed;z-index:999999;left:0;top:0;size:15px;background:rgba(0, 0, 0, 0.7);color:white;padding:5px;`; // meter_image=`<i class="bi bi-speedometer"></i>`; // download_image=`<i class="bi bi-arrow-down"></i>`; meter_image=`<i class='bi'><img src="${meter_image_base64}"></i>`; download_image=`<i class='bi'><img src="${down_image_base64}"></i>`; }else{ trafficDiv = document.createElement('div'); trafficDiv.id='traffic_anzeige'; trafficDiv.style=localStorage.getItem('transfer_style'); meter_image=`<i class='bi'><img src="${meter_image_base64}"></i>`; download_image=`<i class='bi'><img src="${down_image_base64}"></i>`; } }else if(ww==''){ if(localStorage.getItem('transfer_style')==''){ trafficDiv = document.createElement('div'); trafficDiv.id='traffic_anzeige'; GM_addStyle(`@import url("https://cdn.jsdelivr.net/npm/[email protected]/font/bootstrap-icons.css");`); trafficDiv.style=`height:auto !important;pointer-events:none;position:fixed;z-index:999999;left:0;top:0;size:15px;background:rgba(0, 0, 0, 1);color:white;padding:5px;`; meter_image=`<i class='bi'><img src="${meter_image_base64}"></i>`; download_image=`<i class='bi'><img src="${down_image_base64}"></i>`; // meter_image=`<i class="bi bi-speedometer"></i>`; // download_image=`<i class="bi bi-arrow-down"></i>`; }else{ trafficDiv = document.createElement('div'); trafficDiv.id='traffic_anzeige'; trafficDiv.style=localStorage.getItem('transfer_style'); meter_image=`<img src="${meter_image_base64}">`; download_image=`<img src="${down_image_base64}">`; } } if(ww!='' && ww!='title' || ww!='title' && ww==''){ trafficDiv.innerHTML = `${download_image} <span id='traffic_helper1'></span> • ${meter_image} <span id='traffic_helper2'></span> • ${download_image} ${download_image} <span id='traffic_helper3'></span> `; document.body.appendChild(trafficDiv); } if(localStorage.getItem('transfer_gesamt')=='NaN'){ localStorage.setItem('transfer_gesamt',0); } let totalReceivedSize = 0; let receivedLastSecond = 0; let totalReceivedSize1 = parseInt(localStorage.getItem('transfer_gesamt')); let receivedLastSecond1 = 0; function formatBytes(bytes, decimals = 2) { if (!+bytes) return '0 Bytes'; const k = 1024; const dm = decimals < 0 ? 0 : decimals; const sizes = ['Bytes', 'KiB', 'MiB', 'GiB', 'TiB', 'PiB', 'EiB', 'ZiB', 'YiB']; const i = Math.floor(Math.log(bytes) / Math.log(k)); return `${parseFloat((bytes / Math.pow(k, i)).toFixed(dm))} ${sizes[i]}`; } function updateTraffic() { const resources = window.performance.getEntriesByType('resource'); const now = performance.now(); const receivedThisSecond = resources.reduce((acc, entry) => { if (now - entry.responseEnd < 1000) { return acc + entry.transferSize; } else { return acc; } }, 0); const downloadSpeed = (receivedThisSecond - receivedLastSecond) / 1024; // em KB/s receivedLastSecond = receivedThisSecond; totalReceivedSize += receivedThisSecond; const downloadSpeed1 = (receivedThisSecond - receivedLastSecond1) / 1024; // em KB/s receivedLastSecond1 = receivedThisSecond; totalReceivedSize1 =parseInt(totalReceivedSize1)+parseInt(receivedThisSecond); localStorage.setItem('transfer_gesamt',totalReceivedSize1); if(ww!='title'){ document.querySelector('#traffic_helper1').innerText=formatBytes(totalReceivedSize); document.querySelector('#traffic_helper2').innerText=formatBytes(receivedThisSecond); document.querySelector('#traffic_helper3').innerText=formatBytes(totalReceivedSize1); }else{ trafficDiv.innerHTML = `${download_image} ${formatBytes(totalReceivedSize)} • ${meter_image} ${formatBytes(receivedThisSecond)} • ${download_image} ${download_image} ${formatBytes(totalReceivedSize1)} `; } } setInterval(updateTraffic, 1000); }catch(e){ console.log(e); setTimeout(starte, 5000); } } if(localStorage.getItem('zusatzinfos_einblenden')=='true'){ setTimeout(starte, set_timeout_var); } } return 1; }else{ return 2; } return 3; } if(localStorage.getItem('zusatzinfos_einblenden')=='true'){ var checkboxerweiterung_zusatzinfos_aktivieren ='checked="true"'; }else{ var checkboxerweiterung_zusatzinfos_aktivieren =''; } if(localStorage.getItem('mouse_oder_datentransfer')=='true'){ var checkboxerweiterung_zusatzinfos_mause_oder_daten ='checked="true"'; }else{ var checkboxerweiterung_zusatzinfos_mause_oder_daten =''; } if(!erweiterungs_einstellungs_array){ var erweiterungs_einstellungs_array = []; } erweiterungs_einstellungs_array.push(['zusatzinfos_anzeigen',` <label> <label style="display:flex;flex-direction:column"> <p> <strong>Zusatzinfos einblenden</strong> <input type="checkbox" id="zusatzinfos_einblenden_id" ${checkboxerweiterung_zusatzinfos_aktivieren}> <span>? <small> Es gibt 2 auswahlmöglichkeiten im nächten einstell Menü. Dazu noch den Datentrasfer der aktuell läuft , Transfer der seid beginn der Seite von Youtube läauft und der Gesamt Transfer angezeigt<br> 1. Man kann auch die Maus Distanz anzeigen lassen die die Maus, auf allen Youtube Seiten hinter sich gelassen hat. Es wird einmal die distanz während des aktuellen besuchs von Youtube angezeigt und einmal fir distanz seid beginn dieses Scriptes.<br> Aktuell stehen die Informationen in der Titel Leiste. Unter den Menü Punkt Entwickler können sie den Standort der Anzeige ändern. </small></span> </p> </label> <label>Extra Infos auswahl Maus oder Tranfer <input type="checkbox" id="mouse_oder_daten_id" ${checkboxerweiterung_zusatzinfos_mause_oder_daten}> <span>? <small> Bei aktivierter Checkbox werden distanz von ihre Maus angezegt auf den Youtube Seiten gemacht hat<br> Bleibt das Kästchen leer, wird die aktuelle und Gesamt Transferdaten angezeigt. </small></span> </label> <label style="display:flex;flex-direction:column"> Zusatzinfos position:<br> <code>document.querySelector('</code><code style="color:red">head</code><code>');</code> <input type="text" id="selector_textarea" value="${localStorage.getItem('selector_zusatzinformationen')}"> <small>Mit querySelector können Sie die Anzeige in jedes andere Element anzeigen lassen ( Vorsicht,Xoutube arbeitet mit gleichen is'd, was die möglichkeit eine id zu nutzen schwerer macht). Sie können den Infos auch eine feste Position geben. Einfach beues Element erstellen uns über das Style Attributte die position und style der anzeige angeben. </small> </label> <label style="display:flex;flex-direction:column"> Einen Link oder base64 zu einen Icon was einen Pfeil nach unten zeigt Optional:<br> <input type="text" id="image_pfeil_value" value="${localStorage.getItem('transfer_style_image_down')}"> <small>Mit querySelector können Sie die Anzeige in jedes andere Element anzeigen lassen ( Vorsicht,Xoutube arbeitet mit gleichen is'd, was die möglichkeit eine id zu nutzen schwerer macht). Sie können den Infos auch eine feste Position geben. Einfach heues Element erstellen uns über das Style Attributte die position und style der anzeige angeben. </small> </label> <label style="display:flex;flex-direction:column"> Css angabe um style und position zu erstellen zb so<br> <code> height:auto !important; pointer-events:none; position:fixed; z-index:999999; left:0; top:0; size:15px; background:rgba(0, 0, 0, 0.7); color:white; padding:5px; </code> <input type="text" id="fraffic_position_erstellen" value="${localStorage.getItem('transfer_style')}"> <small> Geben sie hier eine inline style angabe ein.Ihre angaben werden dann direkt auf ihren Xontainer angewendet. </small> </label> </label>`]); if(!array_script){ var array_script=[]; } array_script.push([` var zusatzinfos_einblenden_id_var=document.getElementById('zusatzinfos_einblenden_id') zusatzinfos_einblenden_id_var.addEventListener('click',function(u){ if(zusatzinfos_einblenden_id_var.checked==true){ localStorage.setItem('zusatzinfos_einblenden',true); }else{ localStorage.setItem('zusatzinfos_einblenden',false); } }) var zusatzinfos_mouse_oder_daten_id_var=document.getElementById('mouse_oder_daten_id') zusatzinfos_mouse_oder_daten_id_var.addEventListener('click',function(u){ if(zusatzinfos_mouse_oder_daten_id_var.checked==true){ localStorage.setItem('mouse_oder_datentransfer',true); }else{ localStorage.setItem('mouse_oder_datentransfer',false); } }) document.getElementById('selector_textarea').addEventListener('click',function(u){ localStorage.setItem('selector_zusatzinformationen',document.getElementById('selector_textarea').value); }) document.getElementById('image_pfeil_value').addEventListener('click',function(u){ localStorage.setItem('transfer_style_image_down',document.getElementById('image_pfeil_value').value); }) document.getElementById('image_meter_value').addEventListener('click',function(u){ localStorage.setItem('transfer_style_image_meter',document.getElementById('image_meter_value').value); }) document.getElementById('fraffic_position_erstellen').addEventListener('click',function(u){ localStorage.setItem('transfer_style',document.getElementById('fraffic_position_erstellen).value); }) `]); if(localStorage.getItem('zusatzinfos_einblenden')){ var zusatz_infos_var=zusatzinfos_einblenden_anzeigen(); if(zusatz_infos_var==1){ console.log('%cZusatzinfos aktiviert'+ (performance.now() - start3) + ' ms.','color:green'); }else if(zusatz_infos_var==2){ console.log('%cZusatzinfos deaktiviert'+ (performance.now() - start3) + ' ms.','color:orange'); }else if(zusatz_infos_var==3){ console.log('%cerror zusatzinfos ladeen: '+ (performance.now() - start3) + ' ms.','color:red'); }else if(zusatz_infos_var==4){ console.log('%cZusatzinfos datentransfer aktive: '+ (performance.now() - start3) + ' ms.','color:green'); }else if(zusatz_infos_var==5){ console.log('%cZusatzinfos mousedistanz aktive: '+ (performance.now() - start3) + ' ms.','color:green'); }else{ console.log('%cerror zusatzinfos ladeen: '+ (performance.now() - start3) + ' ms.','color:red'); } } })();