作者:云荒杯倾

本意是用这个做视频遮罩效果,但是还是从更通用的角度来解释事情本身吧。
少掺杂一点业务目的。

主要实现功能

在canvas画布上跟随鼠标的按键、移动画出拖拉范围内的矩形;
弹出选择项,选“对勾”则将这部分矩形填上背景色,选“叉号”则取消本次拖拉的矩形。

代码块

代码不长,直接放。

引用部分

<link href="https://cdn.bootcss.com/font-awesome/4.7.0/css/font-awesome.css" rel="stylesheet">
<script src="https://cdn.bootcss.com/jquery/3.2.1/jquery.js"></script>

样式部分

 <style>
        canvas{
            width:700px;
            height:700px;
            border:1px solid blue;
        }
        #mask{
            width:65px;
            height:30px;
            position: absolute;
            border:1px solid green;
        }
        .fa-check{
            color:green
        }
        .fa-times{
            color:red;
        }
    </style>

HTML部分

 <canvas id="canvas"></canvas>
    <div id="mask">
        <span id="no"><i class="fa fa-2x fa-times"></i></span>
        <span id="yes"><i class="fa fa-2x fa-check"></i></span>
    </div>

js部分


let canvas = $('#canvas').get(0);
        let ctx = canvas.getContext('2d');
        canvas.width = 700;
        canvas.height = 700;
        ctx.strokeStyle = 'red';
        ctx.fillStyle = 'green';
        $('#mask').hide();

        let origin = [0, 0];
        let width2height = [0, 0];

        $('#canvas').on('mousedown', mousedownHandler)
       .on('mousemove', mousemoveHandler)
       .on('mouseup', mouseupHandler);

        function mousedownHandler(e){
            origin = [e.offsetX, e.offsetY];
        }
        function mousemoveHandler(e) {
            if(origin[0] !==0 || origin[1] !== 0){//确保按下才发生
                width2height = [e.offsetX - origin[0] , e.offsetY - origin[1]];
                ctx.clearRect(0, 0, 700, 700);
                ctx.strokeRect(origin[0], origin[1], width2height[0], width2height[1]);

            }

        }
        function mouseupHandler(e) {
            $('#mask').show().css('top', e.clientY).css('left', e.clientX);
            diableCanvasEvent();
        }
        function diableCanvasEvent() {
            $('#canvas').off('mousedown', mousedownHandler)
                .off('mousemove', mousemoveHandler)
                .off('mouseup', mouseupHandler);
        }

        $("#yes").click(function () {
            ctx.globalAlpha = 0.2;
            ctx.fillRect(origin[0], origin[1], width2height[0], width2height[1]);
            $('#mask').hide();
            origin = [0, 0];
        });
        $("#no").click(function () {
            $('#mask').hide();
            ctx.clearRect(0, 0, 700, 700);
            origin = [0, 0];
        });

demo效果查看

注: 每画完或者拖拉出一个矩形后,canvas不再响应事件,所以需要reload页面进行再次画矩形。
你也可以修改代码为拖拉出一个矩形后不禁止canvas上的事件。这样就可以一直画。

http://htmlpreview.github.io/...://github.com/cunzaizhuyi/canvasDemo/blob/master/src/mask.html

源代码地址

https://github.com/cunzaizhuy...
目录下找mask.html文件,就是本文程序。

其他几个程序也都是基于canvas的小程序。

附:

业务目的:
视频遮罩是一种将视频某部分区域遮盖的效果,可用于遮盖电视台图标,广告,镜头内敏感部分等。
前端实现可以在播放器上添加一层canvas来绘制。


飞叶_前端
1.4k 声望139 粉丝

Wasm和emscripten技术交流群:939206522