最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • canvas从入门到猪头

    正文概述 掘金(执鸢者)   2021-02-22   410

    一、Canvas简介

    1.1 什么是canvas

    1.2 canvas的坐标系统

    • x轴正方向向右、y轴正方向向下
    • 画布的原点在左上角
    • 横纵坐标单位为像素
    • 每个轴的最小单元为一个像素(栅格)

    canvas从入门到猪头

    1.3 canvas的绘制流程

    1. 创建一个标签
    2. 获取canvas元素对应的DOM对象,这是一个Canvas对象
    3. 调用Canvas对象的getContext()方法,该方法返回一个CanvasRenderingContext2D对象,该对象即可绘制图形
    4. 调用CanvasRenderingContext2D对象的方法绘图

    1.4 canvas的应用领域

    1. 游戏:canvas 在基于 Web 的图像显示方面比 Flash 更加立体、更加精巧,canvas 游戏在流畅度和跨平台方面更优秀,例如这25款canvas游戏
    2. 可视化的库:Echart
    3. banner广告:Canvas 实现动态的广告效果非常合适
    4. 图形编辑器:后续Photoshop能够100%基于Web实现
    5. 微信读书、腾讯文档均是通过canvas实现

    二、基础功能

    2.1 坐标系选择

    1. translate(dx,dy):平移坐标系。相当于把原来位于(0,0)位置的坐标原点平移到(dx、dy)点。
    2. rotate(angle):旋转坐标系。该方法控制坐标系统顺时针旋转angle弧度。
    3. scale(sx,sy):缩放坐标系。该方法控制坐标系统水平方向上缩放sx,垂直方向上缩放sy。
    4. transform(a,b,c,d,e,f):允许缩放、旋转、移动并倾斜当前的环境坐标系,其中a表示水平缩放、b表示水平切斜、c表示垂直切斜、d表示垂直缩放、e表示水平移动、f表示垂直移动。

    canvas从入门到猪头

    function main() {
        const canvas = document.getElementById('canvasId');
        const ctx = canvas.getContext('2d');
        ctx.lineWidth = 4;
        // 默认
        ctx.save();
        ctx.strokeStyle = '#F00';
        drawCoordiante(ctx);
        ctx.restore();
    
        // 平移
        ctx.save();
        ctx.translate(150, 150);
        ctx.strokeStyle = '#0F0';
        drawCoordiante(ctx);
        ctx.restore();
    
        // 旋转
        ctx.save();
        ctx.translate(300, 300);
        ctx.rotate(-Math.PI / 2);
        ctx.strokeStyle = '#00F';
        drawCoordiante(ctx);
        ctx.restore();
    
        // 缩放
        ctx.save();
        ctx.translate(400, 400);
        ctx.rotate(-Math.PI / 2);
        ctx.scale(0.5, 0.5);
        ctx.strokeStyle = '#000';
        drawCoordiante(ctx);
        ctx.restore();
    }
    
    function drawCoordiante(ctx) {
        ctx.beginPath();
        ctx.moveTo(0, 0);
        ctx.lineTo(120, 0);
        ctx.moveTo(0, 0);
        ctx.lineTo(0, 80);
        ctx.closePath();
        ctx.stroke();
    }
    
    main();
    

    2.2 图形绘制

    1. 直线
    function drawLine(ctx, startX, startY, endX, endY) {
        ctx.moveTo(startX, startY);
        ctx.lineTo(endX, endY);
        ctx.stroke();
    }
    
    1. 圆弧
    function drawCircle(ctx, x, y, R, startAngle, endAngle) {
        ctx.arc(x, y, R, startAngle, endAngle);
        ctx.stroke();
    }
    
    1. 曲线
    // 贝济埃曲线
    function drawBezierCurve(ctx, cpX1, cpY1, cpX, cpY2, endX, endY) {
        ctx.bezierCurveTo(cpX1, cpY1, cpX, cpY2, endX, endY);
        ctx.stroke();
    }
    // 二次曲线
    function drawQuadraticCurve(ctx, cpX, cpY, endX, endY) {
        ctx.quadraticCurveTo(cpX, cpY, endX, endY);
        ctx.stroke();
    }
    
    1. 矩形
    // 填充矩形
    function drawFillRect(ctx, x, y, width, height) {
        ctx.fillRect(x, y, width, height);
    }
    // 边框矩形
    function drawStrokeRect(ctx, x, y, width, height) {
        ctx.strokeRect( x, y, width, height);
    }
    
    1. 字符串
    // 填充字符串
    function drawFillText(ctx, text, x, y) {
        ctx.fillText(text, x, y);
    }
    // 边框字符串
    function drawStrokeText(ctx, text, x, y) {
        ctx.strokeText(text, x, y);
    }
    
    1. 复杂图形绘制——路径
    // 利用路径绘制
    function drawFigureByPath(ctx) {
        ctx.beginPath();
        ctx.moveTo(100, 400);
        ctx.lineTo(200, 450);
        ctx.lineTo(150, 480);
        ctx.closePath();
        ctx.fill();
    }
    

    canvas从入门到猪头

    function main() {
        const canvas = document.getElementById('canvasId');
        const ctx = canvas.getContext('2d');
        ctx.lineWidth = 2;
        ctx.strokeStyle = '#F00';
        ctx.fillStyle = '#F00';
        ctx.font = 'normal 50px 宋体';
        drawLine(ctx, 50, 10, 150, 10);
        ctx.moveTo(150, 100);
        drawCircle(ctx, 100, 100, 50, 0, Math.PI);
        ctx.moveTo(300, 100);
        drawCircle(ctx, 250, 100, 50, 0, Math.PI * 2);
        ctx.moveTo(350, 150);
        drawBezierCurve(ctx, 200, 200, 450, 250, 300, 300);
        ctx.moveTo(50, 250);
        drawQuadraticCurve(ctx, 50, 400, 80, 400);
        drawFillRect(ctx, 100, 300, 100, 50);
        drawStrokeRect(ctx, 300, 300, 100, 50);
        drawFillText(ctx, 'I', 100, 400);
        drawStrokeText(ctx, 'I', 300, 400);
        drawFigureByPath(ctx);
    }
    

    2.3 填充风格

    1. 纯颜色
    function useColorFill(ctx) {
        ctx.save();
        ctx.fillStyle = '#F00';
        ctx.fillRect(10, 10, 100, 100);
        ctx.restore();
    }
    
    1. 线性渐变颜色
    function useLinearGradientFill(ctx) {
        ctx.save();
        const lg = ctx.createLinearGradient(110, 10, 210, 10);
        lg.addColorStop(0.2, '#F00');
        lg.addColorStop(0.5, '#0F0');
        lg.addColorStop(0.9, '#00F');
        ctx.fillStyle = lg;
        ctx.fillRect(120, 10, 100, 100);
        ctx.restore();
    }
    
    1. 径向渐变颜色
    function useRadialGradientFill(ctx) {
        ctx.save();
        const lg = ctx.createRadialGradient(260, 60, 10, 260, 60, 60);
        lg.addColorStop(0.2, '#F00');
        lg.addColorStop(0.5, '#0F0');
        lg.addColorStop(0.9, '#00F');
        ctx.fillStyle = lg;
        ctx.fillRect(230, 10, 100, 100);
        ctx.restore();
    }
    
    1. 位图填充
    function useImageFill(ctx) {
        ctx.save();
        const image = new Image();
        image.src = 'https://dss2.baidu.com/6ONYsjip0QIZ8tyhnq/it/u=442547030,98631113&fm=58';
        image.onload = function () {
            // 创建位图填充
            const imgPattern = ctx.createPattern(image, 'repeat');
            ctx.fillStyle = imgPattern;
            ctx.fillRect(340, 10, 100, 100);
            ctx.restore();
        }
    }
    

    canvas从入门到猪头

    2.4 临时保存

    canvas从入门到猪头

    // 从左往右是依次绘制(中间为用新的样式填充,最后一个是恢复到原来样式填充)
    function main() {
        const canvas = document.getElementById('canvasId');
        const ctx = canvas.getContext('2d');
        ctx.fillStyle = '#F00';
        ctx.fillRect(10, 10, 100, 100);
        ctx.save();
        ctx.fillStyle = '#0F0';
        ctx.fillRect(150, 10, 100, 100);
        ctx.restore();
        ctx.fillRect(290, 10, 100, 100);
    }
    

    2.5 引入外部图像

    1. 绘制图像:drawImage
    2. 取得图像数据:getIamgeData
    3. 将修改后的数据重新填充到Canvas中:putImageData
    4. 输出位图:toDataURL

    canvas从入门到猪头

    function main() {
        const canvas = document.getElementById('canvasId');
        const ctx = canvas.getContext('2d');
        const image = document.getElementById('image');
        // 绘制图像
        ctx.drawImage(image, 0, 0);
        // 获取图像数据
        const imageData = ctx.getImageData(0, 0, image.width, image.height);
        const data = imageData.data;
        for (let i = 0, len = data.length; i < len; i += 4) {
            const red = data[i];
            const green = data[i + 1];
            const blue = data[i + 2];
    
            const average = Math.floor((red + green + blue) / 3);
    
            data[i] = average;
            data[i + 1] = average;
            data[i + 2] = average;
        }
    
        imageData.data = data;
        ctx.putImageData(imageData, 0, 0);
        document.getElementById('result').src = canvas.toDataURL('image/png');
    }
    

    三、猪头实战

    canvas从入门到猪头

    function main() {
        const canvas = document.getElementById('canvasId');
        const ctx = canvas.getContext('2d');
        ctx.lineWidth = 4;
        ctx.strokeStyle = '#000';
        ctx.fillStyle = '#ffd8e1';
        ctx.translate(260, 20);
        drawPigEar(ctx);
        ctx.save();
        ctx.rotate(Math.PI / 2);
        drawPigEar(ctx);
        ctx.restore();
        drawPigFace(ctx);
        ctx.save();
        ctx.translate(-100, -100);
        drawPigEye(ctx);
        ctx.restore();
        ctx.save();
        ctx.translate(100, -100);
        drawPigEye(ctx);
        ctx.restore();
        ctx.save();
        ctx.translate(0, 60);
        drawPigNose(ctx);
        ctx.restore();
    }
    
    function drawPigEar(ctx) {
        ctx.save();
        ctx.beginPath();
        ctx.arc(-250, 0, 250, 0, -Math.PI / 2, true);
        ctx.arc(0, -250, 250, -Math.PI, Math.PI / 2, true);
        ctx.closePath();
        ctx.fill();
        ctx.stroke();
        ctx.restore();
    }
    
    function drawPigFace(ctx) {
        ctx.save();
        ctx.beginPath();
        ctx.arc(0, 0, 250, 0, Math.PI * 2);
        ctx.fill();
        ctx.stroke();
        ctx.closePath();
        ctx.restore();
    }
    
    function drawPigEye(ctx) {
        ctx.save();
        ctx.fillStyle = '#000';
        ctx.beginPath();
        ctx.arc(0, 0, 20, 0, Math.PI * 2);
        ctx.closePath();
        ctx.fill();
        ctx.restore();
    }
    
    function drawPigNose(ctx) {
        ctx.save();
        ctx.fillStyle = '#fca7aa';
        ctx.beginPath();
        ctx.ellipse(0, 0, 150, 100, 0, 0, Math.PI * 2);
        ctx.closePath();
        ctx.fill();
        ctx.stroke();
        ctx.save();
        ctx.translate(-60, 0);
        drawPigNostrils(ctx);
        ctx.restore();
        ctx.save();
        ctx.translate(60, 0);
        drawPigNostrils(ctx);
        ctx.restore();
        ctx.restore();
    }
    
    function drawPigNostrils(ctx) {
        ctx.save();
        ctx.fillStyle = '#b55151';
        ctx.beginPath();
        ctx.ellipse(0, 0, 40, 60, 0, 0, Math.PI * 2);
        ctx.closePath();
        ctx.fill();
        ctx.stroke();
        ctx.restore();
    }
    
    main();
    

    1.如果觉得这篇文章还不错,来个分享、点赞吧,让更多的人也看到

    2.关注公众号执鸢者,领取学习资料(前端“多兵种”资料),定期为你推送原创深度好文


    起源地下载网 » canvas从入门到猪头

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元