Skip to content

Commit

Permalink
Deploying to gh-pages from @ b8b55fa 🚀
Browse files Browse the repository at this point in the history
  • Loading branch information
BarryCarlyon committed Nov 26, 2024
1 parent 86e8427 commit a4172c6
Show file tree
Hide file tree
Showing 2 changed files with 226 additions and 0 deletions.
30 changes: 30 additions & 0 deletions player/html/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
## What is this example

This is an example of using the Twitch player and adding a number of Controls to it.

It uses [Embed Everything](https://dev.twitch.tv/docs/embed/everything)

Since it uses the JS Embed Library, you do not need to specify the `parent` as the JS Library will work it out for you

This example is based on this ["Web" Example](https://twitch.extensions.barrycarlyon.co.uk/temp/player_test.html) that exists on my Extensions Website for test purposes

## TRY THIS EXAMPLE NOW!

This example is also available via GitHub Pages!

Give it a [whirl here](https://barrycarlyon.github.io/twitch_misc/player/html/)

## Reference Documentation

- [Embed Everything](https://dev.twitch.tv/docs/embed/everything)
- ["Dumb" iFrames](https://dev.twitch.tv/docs/embed/video-and-clips)

## Running the example

This is so rough that you need to upload it somewhere or know how to start a WebServer on 127.0.0.1 port 80 locally

If you have PHP installed

> sudo php -S 127.0.0.1:80
Will get you going real quick
196 changes: 196 additions & 0 deletions player/html/index.html
Original file line number Diff line number Diff line change
@@ -0,0 +1,196 @@
<html>
<head>
<title>Twitch Embed example</title>
<script src= "https://embed.twitch.tv/embed/v1.js"></script>
<link rel="stylesheet" href="/twitch_misc/style.css" />
</head>
<body>

<p>Get the code for this example on <a href="https://github.com/BarryCarlyon/twitch_misc/tree/main/player/html">Github</a> or just View the source instead</p>


<div id="test"></div>

<div id="controls">
<div id="status"></div>

<button id="play">Play</button>
<button id="pause">Pause</button>

<select id="volume_value">
<option>0</option>
<option>0.1</option>
<option>0.2</option>
<option>0.3</option>
<option>0.4</option>
<option>0.5</option>
<option>0.6</option>
<option>0.7</option>
<option>0.8</option>
<option>0.9</option>
<option>1</option>
</select>
<button id="volume">Set Volume</button>
<button id="volume_get">Get Volume</button>

<button id="muted">Get Muted</button>
<button id="mute">Mute</button>
<button id="unmute">Unmute</button>

<br />

<input type="text" id="channel" value="monstercat" />
<button id="change">Change Channel</button>

<select id="quality"></select>
<button id="quality_change">Change Quality</button>
<button id="qualities_get">Get Qualities</button>
<button id="quality_get">Get Quality</button>
</div>

<div style="width: 800px; position: relative;">
<div id="log"></div>
<div id="logb" style="position: absolute; top: 0px; right: 0px;"></div>
</div>

<script type="text/javascript">
const urlParams = new URLSearchParams(window.location.search);
const runtest = urlParams.get('test');

var options = {
width: 800,
height: 500,
channel: "asot",
allowfullscreen: false,
layout: 'video-with-chat'
};
var player = new Twitch.Embed("test", options);

if (runtest) {
log('run test');
player.addEventListener(Twitch.Embed.VIDEO_READY, function() {
log('Attempt volumne and unmute');
player.setVolume(0.1);
player.setMuted(false);
});
}

function log(txt, other) {
var sp = document.createElement('div');
sp.textContent = new Date().getTime() + ': ' + txt;

var t = other ? 'logb' : 'log';
document.getElementById(t).prepend(sp);
}

player.addEventListener(Twitch.Embed.VIDEO_READY, function() {
log('The video is ready');
})
player.addEventListener(Twitch.Embed.VIDEO_PLAY, function() {
log('The video is playing');
})

document.getElementById('play').addEventListener('click', (e) => {
log('Attempt Play');
player.play();
});
document.getElementById('pause').addEventListener('click', (e) => {
log('Attempt Pause');
player.pause();
});
document.getElementById('volume').addEventListener('click', (e) => {
log('Attempt Volume: ' + document.getElementById('volume_value').value);
var val = parseFloat(document.getElementById('volume_value').value);
player.setVolume(val);
});
document.getElementById('volume_get').addEventListener('click', (e) => {
log('Attempt Get Volume');
log('Volume ' + player.getVolume());
});

document.getElementById('mute').addEventListener('click', (e) => {
log('Attempt Mute');
player.setMuted(true);
});
document.getElementById('unmute').addEventListener('click', (e) => {
log('Attempt UnMute');
player.setMuted(false);
});
document.getElementById('muted').addEventListener('click', (e) => {
log('Attempt Get muted');
log(player.getMuted());
});

setInterval(() => {
var status = '';

if (player.isPaused()) {
status += 'Paused ';
} else {
status += 'Playing ';
}

if (player.getMuted()) {
status += 'Muted ';
} else {
status += 'UnMuted ';
}
status += 'Vol: ' + player.getVolume();

status += ' ' + player.getQuality();

document.getElementById('status').textContent = status;
}, 250);

document.getElementById('change').addEventListener('click', (e) => {
var channel = document.getElementById('channel').value;
log('Change channel ' + channel);
player.setChannel(channel);
});

document.getElementById('quality_get').addEventListener('click', (e) => {
log('Fetch Quality');
log(player.getQuality());
});
document.getElementById('qualities_get').addEventListener('click', (e) => {
log('Fetch Qualities');

var target = document.getElementById('quality');
target.textContent = '';

var qol = player.getQualities()
for (var x=0;x<qol.length;x++) {
var opt = document.createElement('option');
opt.value = qol[x].group;
opt.textContent = qol[x].name;
target.append(opt);
}
});
document.getElementById('quality_change').addEventListener('click', (e) => {
var target = document.getElementById('quality').value;
log('Set quality to ' + target);
player.setQuality(target);
});

var events = [
Twitch.Player.ENDED,
Twitch.Player.PAUSE,
Twitch.Player.PLAY,
Twitch.Player.PLAYBACK_BLOCKED,
Twitch.Player.PLAYING,
Twitch.Player.OFFLINE,
Twitch.Player.ONLINE,
Twitch.Player.READY
]
for (var x=0;x<events.length;x++) {
quickBind(events[x]);
}
function quickBind(evt) {
player.addEventListener(evt, (e) => {
log('Captured ' + evt, true);
});
}
</script>

</body>
</html>

0 comments on commit a4172c6

Please sign in to comment.