将边框半径添加到Chrome </video>中的<video>标记

时间:2013-05-07 01:16:30

标签: css html5 google-chrome video css3

我看到这个问题在没有任何明确解决方案的情况下弹出了几次。

我正在加载一个简单的视频

<video src="" controls></video>

在我的页面上。该视频可以跨浏览器工作和播放(不显示此问题的所有格式设置,因为它不相关)。

然后我将边界半径应用于视频标签。这适用于Chrome以外的功能。 我甚至可以拉起控制台并看到应用于视频标签的border-radius,但它不会渲染边框半径。

是否有人熟悉此问题?我已经读过它是Chrome中的一个错误,但我不确定它是否已经解决或是否有解决方法?

1 个答案:

答案 0 :(得分:6)

我不确定,但我认为这就是“使用SVG”的含义:

我们的想法是创建一个与视频宽度和高度相同的HTML覆盖元素,在其上设置多个SVG背景(border-radius,无论背景颜色是什么)并使其成为“鼠标 - 不可见的“(pointer-events: none):

演示:http://jsfiddle.net/pe3QS/3/

CSS(减去SVG):

#video-container {
    position: relative;
}

#overlay {
    position: absolute;
    width: 320px;
    height: 240px;
    left: 0;
    top: 0;
    pointer-events: none;
    background-image: url('data:image/svg+xml...');
    background-position: top right, top left, bottom left, bottom right;
    background-repeat: no-repeat;
}

HTML:

<div id="video-container">
    <video width="320" height="240" src="http://www.w3schools.com/html/movie.ogg" type="video/ogg" controls></video>
    <div id="overlay"></div>
</div>

您也可以使用伪元素(不在video元素上,它不会显示):

演示:http://jsfiddle.net/pe3QS/2/

CSS:

#video-container:after {
    position: absolute;
    width: 320px;
    height: 240px;
    content: " ";
.....

HTML:

<div id="video-container">
    <video width="320" height="240" src="http://www.w3schools.com/html/movie.ogg" type="video/ogg" controls></video>
</div>

修改SVG非常简单,只需更改每个SVG的fill属性即可。

这可能也可以通过JS完成。