diff --git a/lib/text/ui_text_displayer.js b/lib/text/ui_text_displayer.js index 4d2e3461d5..c3038097c0 100644 --- a/lib/text/ui_text_displayer.js +++ b/lib/text/ui_text_displayer.js @@ -468,7 +468,9 @@ shaka.text.UITextDisplayer = class { const regionElement = shaka.util.Dom.createHTMLElement('span'); + const linesUnit = shaka.text.CueRegion.units.LINES; const percentageUnit = shaka.text.CueRegion.units.PERCENTAGE; + const pixelUnit = shaka.text.CueRegion.units.PX; const heightUnit = region.heightUnits == percentageUnit ? '%' : 'px'; const widthUnit = region.widthUnits == percentageUnit ? '%' : 'px'; const viewportAnchorUnit = @@ -479,12 +481,14 @@ shaka.text.UITextDisplayer = class { regionElement.style.position = 'absolute'; - const linesUnit = shaka.text.CueRegion.units.LINES; - if (region.heightUnits === linesUnit && region.widthUnits === linesUnit) { + if (region.heightUnits === linesUnit) { regionElement.style.height = region.height * lineHeightMultiple + '%'; - regionElement.style.width = region.width * lineWidthMultiple + '%'; } else { regionElement.style.height = region.height + heightUnit; + } + if (region.widthUnits === linesUnit) { + regionElement.style.width = region.width * lineWidthMultiple + '%'; + } else { regionElement.style.width = region.width + widthUnit; } @@ -504,6 +508,19 @@ shaka.text.UITextDisplayer = class { regionElement.style.left = region.viewportAnchorX - region.regionAnchorX * region.width / 100 + viewportAnchorUnit; } + if (region.heightUnits !== pixelUnit && + region.widthUnits !== pixelUnit && + region.viewportAnchorUnits !== pixelUnit) { + // Clip region + const top = parseInt(regionElement.style.top.slice(0, -1), 10) || 0; + const left = parseInt(regionElement.style.left.slice(0, -1), 10) || 0; + const height = parseInt(regionElement.style.height.slice(0, -1), 10) || 0; + const width = parseInt(regionElement.style.width.slice(0, -1), 10) || 0; + const realTop = Math.max(0, Math.min(100 - height, top)); + const realLeft = Math.max(0, Math.min(100 - width, left)); + regionElement.style.top = realTop + '%'; + regionElement.style.left = realLeft + '%'; + } regionElement.style.display = 'flex'; regionElement.style.flexDirection = 'column'; diff --git a/test/text/text_displayer_layout_unit.js b/test/text/text_displayer_layout_unit.js index b6e1d01a7b..617e1788f2 100644 --- a/test/text/text_displayer_layout_unit.js +++ b/test/text/text_displayer_layout_unit.js @@ -238,7 +238,8 @@ filterDescribe('Cue layout', shaka.test.TextLayoutTests.supported, () => { const cue = new shaka.text.Cue(0, 1, ''); cue.region.id = '1'; cue.region.height = 15; // % - cue.region.viewportAnchorX = 20; // % + cue.region.width = 60; // % + cue.region.viewportAnchorX = 40; // % cue.region.viewportAnchorY = 10; // % // eslint-disable-next-line max-len cue.backgroundImage = '';