javascript - 如何在fabric.js中影响视频
问题描述
我想对视频使用图像过滤器。(http://fabricjs.com/image-filters)
但它停止视频。如何对fabric.js中的视频产生影响?
例如,如何更改视频的颜色?
https://codepen.io/html5andblog/pen/dmKJH
↑不使用CSS过滤器。有人可以解释一下吗?
谢谢。
<!DOCTYPE html>
<html>
<head>
<meta charset="SHIFT-JIS">
<title>sample</title>
<script src="http://code.jquery.com/jquery-latest.min.js" type="text/javascript"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/fabric.js/2.2.3/fabric.min.js"></script>
<script>
$(document).ready(function() {
canvas = new fabric.Canvas('c');
canvas.setWidth(480);
canvas.setHeight(360);
var video1El = document.getElementById('video1');
var video1 = new fabric.Image(video1El, {
left: 0,
top: 0
});
canvas.add(video1);
video1.getElement().load();
$(document.body).on('click', '#play' ,function(){
video1.getElement().play();
//↓It's stops video.
/*
var filter = new fabric.Image.filters.BlendColor({
color:'red',
mode: 'tint',
alpha: 0.5
});
canvas.item(0).filters.push(filter);
canvas.item(0).applyFilters();
*/
});
fabric.util.requestAnimFrame(function render() {
canvas.renderAll();
fabric.util.requestAnimFrame(render);
});
});
</script>
</head>
<body>
<button id="play">play</button>
<canvas id="c" width="300" height="300"></canvas>
<video id="video1" style="display: none" class="canvas-img" width="480" height="360">
<source id="video_src1" src="https://html5demos.com/assets/dizzy.mp4" type="video/mp4">
</video>
</body>
</html>
解决方案
好的,可以做到,问题是fabricJS可以更快地缓存纹理并避免在每次应用过滤器时将它们拉到视频卡中以节省时间。
在这种情况下,我不得不修改你的代码 n 2 个地方:
1)applyFilters 需要运行每个动画帧
2) 每次都必须删除纹理的缓存
最困难的部分是找到启用了 cors 的视频。
$(document).ready(function() {
canvas = new fabric.Canvas('c');
canvas.setWidth(480);
canvas.setHeight(360);
var video1El = document.getElementById('video1');
var video1 = new fabric.Image(video1El, {
left: 0,
top: 0
});
canvas.add(video1);
video1El.load();
$(document.body).on('click', '#play' ,function(){
video1El.play();
var filter = new fabric.Image.filters.BlendColor({
color:'red',
mode: 'tint',
alpha: 0.5
});
video1.filters = [filter];
});
fabric.util.requestAnimFrame(function render() {
var image = canvas.item(0);
var backend = fabric.filterBackend;
if (backend && backend.evictCachesForKey) {
backend.evictCachesForKey(image.cacheKey);
backend.evictCachesForKey(image.cacheKey + '_filtered');
}
canvas.item(0).applyFilters();
canvas.renderAll();
fabric.util.requestAnimFrame(render);
});
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/fabric.js/2.2.3/fabric.min.js"></script>
<button id="play">play</button>
<canvas id="c" width="300" height="300"></canvas>
<video crossorigin="anonymous" id="video1" style="display: none" class="canvas-img" width="480" height="360">
<source id="video_src1" src="http://commondatastorage.googleapis.com/gtv-videos-bucket/sample/BigBuckBunny.mp4" type="video/mp4">
</video>
推荐阅读
- dart - 检查元素是否是折叠函数中的最后一个值
- sql - 基于另一个表从一个表中删除一系列行作为 SQL 中的输入
- c++ - 继承抽象类Stream的SLCD类中printf的实现
- r - 使用连续预测变量的多个值计算 emmeans
- python - Python将网站表数据读入Dataframe
- python - 从 Firebird 数据库中的表中获取数据
- javascript - 如何独立使用 Bootstrap dropdown.js?
- twitter-bootstrap - 折叠的引导砌体面板在第一次展开时会四处移动
- html - 如何根据浏览器大小更改 tabindex 和 aria-hidden 的值?
- c++ - 了解 TCMalloc 的“释放到操作系统的字节数(又名未映射)”统计信息