LoopControl is a browser extension for Chrome and Firefox that lets you loop custom sections of videos - not just from the beginning to end. A controller overlays all videos, letting you set a start and end point for the loop.
- 🪶 Skip the fluff - loop just the part that you care about
- 🧑🍳 Master that recipe, riff, or dance move by repeating important sections
- 🔁 Turn any video segment into a gif-like loop
- ⌨️ Utilize the visual controller overlay or keybindings
- 🔥 Works on virtually any HTML5 video across Chrome and Firefox
All HTML5 videos will display a moveable and hideable controller that indicates if loops are currently toggled on or off. Here you can set the start and end times of the sections you want to loop.
You can also manually toggle LoopControl by right-clicking the video and selecting loop.
Default Keybindings (targets the last video controller you interacted with):
- Q - Set loop start
- E - Set loop end
- R - Toggle loop
- H - Hide controller
Since 2024, Google deprecated Manifest V2 for Chrome extensions in favour of Manifest V3. So while Firefox supports both Manifest V2 and Manifest V3 extensions, Chrome will only support Manifest V3 moving forward. Among other changes, Manifest V3 was interfering with how Firefox prompted for required permissions. Therefore two different manifests exist in the ./manifests/ folder.
To switch manifest types before testing/building:
npm run prepare:chrome # Copies Manifest V3
npm run prepare:firefox # Copies Manifest V2Install through the official Firefox Add-ons Web Store link.
- Download this repo as a .zip file
- Unzip the file. The folder is
loopcontrol-main - Change into the directory with
cd loopcontrol - Copy the proper manifest version for Firefox with
npm run prepare:firefox - In Firefox, go to
about:debugging - Click on This Firefox -> Load Temporary Add-on
- Select
manifest.jsonwithin theloopcontrol-mainfolder
- Download this repo as a .zip file
- Unzip the file. The folder is
loopcontrol-main - Change into the directory with
cd loopcontrol - Copy the proper manifest version for Chrome with
npm run prepare:chrome - In Chrome, go to
chrome://extensions - Enable Developer Mode in the top-right
- Click 'Load unpacked extension...'
- Select the
loopcontrol-mainfolder
- Change into the project directory with
cd loopcontrol - Install test dependencies with
npm install - Run the automated Jest tests with
npm test
- 48x48 and 128x128 logos for Chrome store
Huge thanks to Video Speed Controller, the Firefox fork (seemingly abandoned) and the more updated gediminasel fork with a few helpful fixes. The loop UI and settings pages were adapted from these extensions.
Credit to Samplelib's videos for the test .mp4.
Extension icon created by Pixel perfect - Flaticon
Mockup assets used in extension listings from MockupDen and Shaping Rain

