blob: eabec0d315914a1a8e8f0eeea67e284014accaf5 [file] [log] [blame]
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<script src=../media-file.js></script>
<script src=../video-test.js></script>
<script src=../media-controls.js></script>
<script>
var cueDisplayElement;
ClientRect.prototype.intersects = function(that)
{
// Separating axis theorem:
return Math.abs(this.top - that.top) < Math.abs(this.height + that.height) / 2
&& Math.abs(this.left - that.left) < Math.abs(this.width + that.width) / 2;
}
function findOverlappingElement(element)
{
var elementRect = element.getBoundingClientRect();
var siblings = element.parentElement.children;
for (var i = 0; i < siblings.length; ++i) {
var sibling = siblings[i];
if (sibling === element)
continue;
var siblingRect = sibling.getBoundingClientRect();
if (elementRect.intersects(siblingRect))
return sibling;
}
return null;
}
function seeked()
{
testTrack = document.querySelector('track');
consoleWrite("Active cues: " + testTrack.track.activeCues.length);
for (var i = 0; i < testTrack.track.activeCues.length; ++i) {
var cueDisplayElement = textTrackDisplayElement(video, 'display', i);
var overlappingElement = findOverlappingElement(cueDisplayElement);
if (overlappingElement) {
failTest("Cue element number " + i + " overlaps with element " + overlappingElement + ".");
return;
}
}
logResult(true, "No cue elements overlap.");
endTest();
};
function loaded()
{
consoleWrite("Test that TextTrack's cues are rendered correctly when the snap to lines flag is not set.");
findMediaElement();
video.src = findMediaFile('video', '../content/test');
waitForEvent('canplaythrough', function() {
waitForEvent('seeked', seeked, false, true);
video.currentTime = 4.10;
});
}
setCaptionDisplayMode('Automatic');
</script>
</head>
<body onload="loaded()">
<video controls>
<track src="captions-webvtt/captions-snap-to-lines-not-set.vtt" kind="captions" default>
</video>
</body>
</html>