gpt4 book ai didi

Javascript - 检测互联网速度/带宽

转载 作者:行者123 更新时间:2023-12-02 17:28:53 27 4
gpt4 key购买 nike

使用下面的脚本来检测连接到网络的系统的互联网速度。引用javascript to detect internet speed

但是,https://fast.com/ 的速度结果和 http://www.speedtest.net/是不同的。

var imageAddr = "http://www.kenrockwell.com/contax/images/g2/examples/31120037-5mb.jpg"; 
var downloadSize = 4995374; //bytes

function ShowProgressMessage(msg) {
if (console) {
if (typeof msg == "string") {
console.log(msg);
} else {
for (var i = 0; i < msg.length; i++) {
console.log(msg[i]);
}
}
}

var oProgress = document.getElementById("progress");
if (oProgress) {
var actualHTML = (typeof msg == "string") ? msg : msg.join("<br />");
oProgress.innerHTML = actualHTML;
}
}

function InitiateSpeedDetection() {
ShowProgressMessage("Loading the image, please wait...");
window.setTimeout(MeasureConnectionSpeed, 1);
};

if (window.addEventListener) {
window.addEventListener('load', InitiateSpeedDetection, false);
} else if (window.attachEvent) {
window.attachEvent('onload', InitiateSpeedDetection);
}

function MeasureConnectionSpeed() {
var startTime, endTime;
var download = new Image();
download.onload = function () {
endTime = (new Date()).getTime();
showResults();
}

download.onerror = function (err, msg) {
ShowProgressMessage("Invalid image, or error downloading");
}

startTime = (new Date()).getTime();
var cacheBuster = "?nnn=" + startTime;
download.src = imageAddr + cacheBuster;

function showResults() {
var duration = (endTime - startTime) / 1000;
var bitsLoaded = downloadSize * 8;
var speedBps = (bitsLoaded / duration).toFixed(2);
var speedKbps = (speedBps / 1024).toFixed(2);
var speedMbps = (speedKbps / 1024).toFixed(2);
ShowProgressMessage([
"Your connection speed is:",
speedBps + " bps",
speedKbps + " kbps",
speedMbps + " Mbps"
]);
}
}

这里的要点是根据用户的互联网连接速度更改视频质量运行时间。我需要获取网络速度,将其传递到服务器,并根据该速度更改视频质量。

我如何实现同样的目标?

最佳答案

您的网络速度将根据可用带宽而有所不同。因此,您需要以特定的时间间隔(例如每 10 或 15 秒)运行一次速度测试。但即使您能够运行这些测试而不影响性能和对浏览器造成的压力。您的下一个目标是将视频的质量更改为较低的质量,这又会让人头疼,因为它不是一个简单的视频源切换。

自适应比特率流就是您正在寻找的。有一些媒体服务器提供该功能。如果您正在寻找更多开源的东西来理解和玩,那么您可以尝试 Google Shaka Player。 https://github.com/google/shaka-player

还要注意的一点是,如果没有任何插件帮助,自适应比特率流将无法在 IE 中工作。

关于Javascript - 检测互联网速度/带宽,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40055366/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com