绘制文本

    绘制文本就是在指定的位置输出文本,可以设置文本的字体、样式、阴影等,与CSS完全一致:

    'use strict';



    var

    canvas = document.getElementById('test-text-canvas'),

    ctx = canvas.getContext('2d');



    ctx.clearRect(0, 0, canvas.width, canvas.height);

    ctx.shadowOffsetX = 2;

    ctx.shadowOffsetY = 2;

    ctx.shadowBlur = 2;

    ctx.shadowColor = '#666666';

    ctx.font = '24px Arial';

    ctx.fillStyle = '#333333';

    ctx.fillText('带阴影的文字', 20, 40);

    Canvas除了能绘制基本的形状和文本,还可以实现动画、缩放、各种滤镜和像素转换等高级操作。如果要实现非常复杂的操作,考虑以下优化方案:

    • 通过创建一个不可见的Canvas来绘图,然后将最终绘制结果复制到页面的可见Canvas中;

    • 尽量使用整数坐标而不是浮点数;

    • 可以创建多个重叠的Canvas绘制不同的层,而不是在一个Canvas中绘制非常复杂的图;

    • 背景图片如果不变可以直接用 <img> 标签并放到最底层。