Add 4x and 8x playback speeds (#362)

* Add 4x and 8x playback speeds

* Make the "max speed" keyboard shortcut go to 2x first and then to the actual max speed
pull/367/head
ElementalAlchemist 1 year ago committed by GitHub
parent c436871ba6
commit 8264206f09
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -38,7 +38,7 @@
<li>Period (.): Forward 1 frame</li> <li>Period (.): Forward 1 frame</li>
<li>Equals (=): Increase playback speed one step</li> <li>Equals (=): Increase playback speed one step</li>
<li>Hyphen (-): Decrease playback speed one step</li> <li>Hyphen (-): Decrease playback speed one step</li>
<li>Shift+=: Maximum playback speed</li> <li>Shift+=: 2x or maximum playback speed</li>
<li>Shift+-: Minimum playback speed</li> <li>Shift+-: Minimum playback speed</li>
<li>Backspace: Reset playback speed to 1x</li> <li>Backspace: Reset playback speed to 1x</li>
<li> <li>

@ -32,7 +32,7 @@
<li>Period (.): Forward 1 frame</li> <li>Period (.): Forward 1 frame</li>
<li>Equals (=): Increase playback speed one step</li> <li>Equals (=): Increase playback speed one step</li>
<li>Hyphen (-): Decrease playback speed one step</li> <li>Hyphen (-): Decrease playback speed one step</li>
<li>Shift+=: Maximum playback speed</li> <li>Shift+=: 2x or maximum playback speed</li>
<li>Shift+-: Minimum playback speed</li> <li>Shift+-: Minimum playback speed</li>
<li>Backspace: Reset playback speed to 1x</li> <li>Backspace: Reset playback speed to 1x</li>
</ul> </ul>

@ -18,7 +18,7 @@ Hls.DefaultConfig.maxBufferHole = 600;
const VIDEO_FRAMES_PER_SECOND = 30; const VIDEO_FRAMES_PER_SECOND = 30;
const PLAYBACK_RATES = [0.25, 0.5, 0.75, 1, 1.25, 1.5, 1.75, 2]; const PLAYBACK_RATES = [0.25, 0.5, 0.75, 1, 1.25, 1.5, 1.75, 2, 4, 8];
function commonPageSetup() { function commonPageSetup() {
if (!Hls.isSupported()) { if (!Hls.isSupported()) {

@ -100,7 +100,12 @@ document.addEventListener("keypress", (event) => {
increaseSpeed(); increaseSpeed();
break; break;
case "+": case "+":
const playbackRate = videoElement.playbackRate;
if (playbackRate < 2) {
setSpeed(videoElement, 2);
} else {
setSpeed(videoElement, PLAYBACK_RATES[PLAYBACK_RATES.length - 1]); setSpeed(videoElement, PLAYBACK_RATES[PLAYBACK_RATES.length - 1]);
}
break; break;
case "-": case "-":
decreaseSpeed(); decreaseSpeed();

Loading…
Cancel
Save