Canvas文字的渲染--进阶

font: 字型、字号和字体

Default: "20px sans-serif"

context.font = “

​ font-style font-variant font-weight font-size font-family

​ ”

font-style:

  • normal (Default)

  • italic (斜体字)

  • oblique (倾斜字体)

    var canvas = document.getElementById('xxx')
    canvas.width = 800;
    canvas.height = 800;
    var context = canvas.getContext("2d");
    context.fillStyle = "#058"
    
    context.font = "bold 40px sans-serif"
    context.fillText("Hello world 你好世界!", 40, 100)
    
    context.font = "italic 40px sans-serif"
    context.fillText("Hello world 你好世界!", 40, 200)
    
    context.font = "oblique 40px sans-serif"
    context.fillText("Hello world 你好世界!", 40, 300)
    

font-variant: (变体)

  • normal (Default)

  • small-caps (英文小型大写字母)

    var context = canvas.getContext("2d");
    context.fillStyle = "#058"
    
    context.font = "bold 40px sans-serif"
    context.fillText("Hello world 你好世界!", 40, 100)
    
    context.font = "small-caps bold 40px sans-serif"
    context.fillText("Hello world 你好世界!", 40, 200)
    

font-weight:

  • lighter (浏览器可能还未支持)

  • normal (Default)

  • bold

  • bolder (浏览器可能还未支持)

  • 100, 200, 300, 400 (normal),

    500, 600, 700 (bold),

    800, 900

    *W3C虽然定义了标准,但大多数浏览器还不支持9个等级,只有400和700这两种效果!

    var context = canvas.getContext("2d");
    context.fillStyle = "#058"
    
    context.font = "lighter 40px impact"
    context.fillText("Hello world 你好世界!", 40, 100)
    
    context.font = "normal 40px impact"
    context.fillText("Hello world 你好世界!", 40, 200)
    
    context.font = "bold 40px impact"
    context.fillText("Hello world 你好世界!", 40, 300)
    
    context.font = "bolder 40px impact"
    context.fillText("Hello world 你好世界!", 40, 400)
    

font-size:

  • 20px (Default)

  • 2em

  • 150%

  • xx-samll, x-small,

    medium,

    large,

    x-large, xx-large

    var context = canvas.getContext("2d");
    context.fillStyle = "#058"
    
    context.font = "xx-small sans-serif"
    context.fillText("Hello world 你好世界!", 40, 100)
    
    context.font = "medium sans-serif"
    context.fillText("Hello world 你好世界!", 40, 200)
    
    context.font = "xx-large sans-serif"
    context.fillText("Hello world 你好世界!", 40, 300)
    

font-family:

  • 可以设置多种备选字体 (如果所有字体都不可以,将使用浏览器默认的字体)

  • 支持@font-face (CSS3向浏览器中注入新字体)

  • Web安全字体 (使用这些字体可以保证大部分浏览器都支持,具体可搜索)

    var context = canvas.getContext("2d");
    context.fillStyle = "#058"
    
    context.font = "xx-small sans-serif"
    context.fillText("Hello world 你好世界!", 40, 100)
    
    context.font = "medium sans-serif"
    context.fillText("Hello world 你好世界!", 40, 200)
    
    context.font = "xx-large sans-serif"
    context.fillText("Hello world 你好世界!", 40, 300)
    

文本对齐

水平对齐

context.textAlign =

  • left

  • center

  • right

    *从给定点的哪个位置开始绘制

    var context = canvas.getContext("2d");
    context.fillStyle = "#058"
    context.font = "bold 40px sans-serif"
    
    context.textAlign = "left"
    context.fillText("Hello world 你好世界!", 40, 100)
    
    context.textAlign = "center"
    context.fillText("Hello world 你好世界!", 40, 200)
    
    context.textAlign = "right"
    context.fillText("Hello world 你好世界!", 40, 300)
    
    // baseline
    context.strokeStyle = "#888"
    context.moveTo(400, 0);
    context.lineTo(400, 800);
    context.stroke();
    
垂直对齐

context.textBaseline =

  • top

  • middle

  • bottom

  • alphabetic (Default) 拉丁语垂直方向基准线

  • ideographic 汉语垂直方向基准线

  • hanging 印度语垂直方向基准线

    *从给定点的哪个位置开始绘制

    var context = canvas.getContext("2d");
    context.fillStyle = "#058"
    context.font = "bold 40px sans-serif"
    
    context.textBaseline  = "top"
    context.fillText("Hello world 你好世界!", 40, 100)
    drawBaseline(context, 100)
    
    context.textBaseline  = "middle"
    context.fillText("Hello world 你好世界!", 40, 200)
    drawBaseline(context, 200)
    
    context.textBaseline  = "bottom"
    context.fillText("Hello world 你好世界!", 40, 300)
    drawBaseline(context, 300)
    
    // baseline
    function drawBaseline(cxt, h) {
        var width = cxt.canvas.width;
        cxt.save();
        cxt.strokeStyle = "#888"
        cxt.lineWidth = 2;
        cxt.moveTo(0, h);
        cxt.lineTo(width, h);
        cxt.stroke();
        cxt.restore();
    }
    

文本的度量

计算字符串渲染的宽度

context.measureText( string ).width

var context = canvas.getContext("2d");
context.fillStyle = "#058"
context.font = "bold 40px sans-serif"
context.fillText("Hello world 你好世界!", 40, 100)

var textWidth = context.measureText("Hello world 你好世界!").width;
context.fillText("以上字符串宽度为" + textWidth + "px", 40, 200)

posted @ 2021-10-13 15:07  Better-HTQ  阅读(317)  评论(0编辑  收藏  举报