Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/javascript/366.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript 如何在canvas的fillText方法中解析html标记_Javascript_Jquery_Html_Canvas - Fatal编程技术网

Javascript 如何在canvas的fillText方法中解析html标记

Javascript 如何在canvas的fillText方法中解析html标记,javascript,jquery,html,canvas,Javascript,Jquery,Html,Canvas,我有一个canvas元素,它有标签。每个标签都是使用fillText方法创建的 我希望能够发送这样的文本:“CH2”,但我没有得到这个作为最终结果。元素未正确解析。我如何解决这个问题 下面是一些示例代码: var ctx=document.getElementById('canvas').getContext('2d'); ctx.font=“48px serif”; ctx.fillText(“你好,世界”,10,50) 您可以使用注释中提到的@lipp来解决这个问题,并在字符串中插入已有的子

我有一个canvas元素,它有标签。每个标签都是使用
fillText
方法创建的

我希望能够发送这样的文本:“CH2”,但我没有得到这个作为最终结果。
元素未正确解析。我如何解决这个问题

下面是一些示例代码:
var ctx=document.getElementById('canvas').getContext('2d');
ctx.font=“48px serif”;
ctx.fillText(“你好,世界”,10,50)

您可以使用注释中提到的@lipp来解决这个问题,并在字符串中插入已有的子脚本字符

您还可以制作一个简单的解析器,用于检测某些代码并以不同方式呈现下一段代码(见下文)

也可以使用它,但它有它的背景,例如异步行为、有限的内容(在安全机制阻止它被绘制到画布之前)以及在某些情况下缺乏跨浏览器支持

示例解析器 这只是一个开始的例子。您可以选择任何代码以及添加新代码等。这只是一种方法,还有许多其他方法

如果您有一个HTML源字符串,只需用代码替换这些标记,或者扩展解析器来处理这些标记

var ctx=c.getContext(“2d”),
fontSize=28,
str=“此字符串具有启用|下标|文本的代码。”;
setFontSize(fontSize);
//解析字符串
对于(var i=0,x=10,tx=0,isSub=false;i

这里有一个函数,用于将html字符串转换为一系列fillText语句。它处理多行字符串,并允许您指定对齐方式(左、右、中)


函数解析_html(ctx、s、x0、y0、align、font、fontsize、col){
//二维画布上下文、字符串、位置x、位置y、左/右/中、字体、字体高度、颜色
//将html代码转换为一系列单独的字符串,每个字符串可由fillText()显示。
字体='px'+字体
变量行=[]
变量行=[0]

var part=''//a'前面的文本元素不能传递html。但是上标/下标是可以的。好的,谢谢……忘了提到它处理(或),(或),,
(或
。要显示“修改了代码以允许'\n'成为'
'的同义词,并且不需要进行特殊处理”
<canvas id="textCanvas" width="700" height="150" style="border:1px solid #d3d3d3;">

<script>

function parse_html(ctx, s, x0, y0, align, font, fontsize, col) {
    // 2d canvas context, string, pos.x, pos.y, left/right/center, font, font height, color
    // Convert html code to a series of individual strings, each displayable by fillText().
    font = 'px '+font
    var lines = []
    var line = [0]
    var part = '' // the text element preceding a '<'
    var cmd = ''
    var bold = false
    var italic = false
    var sup = false
    var sub = false
    var x = 0, y = 0
    var dx, start
    var legal = ['b', 'strong', 'i', 'em', 'sup', 'sub']

    function add_part() {
        var style = ''
        var fs = fontsize
        if (bold) style += 'bold '
        if (italic) style += 'italic '
        if (sup || sub) {
            fs = 0.8*fontsize
            if (sup) y -= 0.3*fontsize // y increases downward in 2D canvas
            else y += 0.3*fontsize
        }
        ctx.font = style+fs+font
        dx = ctx.measureText(part).width
        line.push([x, y, ctx.font, part])
        part = ''
        x += dx
    }

    function end_line() {
        if (part !== '') add_part()
        line[0] = x
        lines.push(line)
        line = [0]
        x = y = 0
    }

    for (var i=0; i<s.length; i++) {
        var c = s[i]
        if (c == '\n') {
            end_line()
        } else if (c != '<') {
            part += c // a part of the text
        } else { // encountered '<'
            //if (part !== '') add_part()
            start = i+1
            i++
            cmd = s[i]
            var end = false
            if (cmd == '/') {
                cmd = ''
                end = true
            }
            var ok = true
            for (i=i+1; i<s.length; i++) {
                if (s[i] == '<') { // This means that the intial '<' did not start a command
                    i = i-1 // back up
                    part += '<'+cmd
                    add_part()
                    ok = false // signal that we encountered '<'
                    break
                }
                if (s[i] == '>') break
                cmd += s[i]
            }
            if (!ok) continue
            if (cmd == 'br' || cmd == 'br/') {
                end_line()
            } else {
                if (legal.indexOf(cmd) >= 0 && part !== '') add_part()
                switch (cmd) {
                    case 'b':
                    case 'strong':
                        bold = !end
                        break
                    case 'i':
                    case 'em':
                        italic = !end
                        break
                    case 'sup':
                        sup = !end
                        if (end) y = 0
                        break
                    case 'sub':
                        sub = !end
                        if (end) y = 0
                        break
                    default:
                        part += '<'+cmd+'>'
                }
            }
        }
    }
    if (part.length > 0) line.push([x, y, fontsize+font, part])
    ctx.font = fontsize+font
    line[0] = x + ctx.measureText(part).width
    lines.push(line)

    function rgb_to_html(rgb) { // convert RGB 0-1 to html 0-255
        var r = Math.floor(255 * rgb[0])
        var g = Math.floor(255 * rgb[1])
        var b = Math.floor(255 * rgb[2])
        return 'rgb(' + r + ',' + g + ',' + b + ')'
    }

    var width, L
    var nline = 0
    // Each line in lines starts with the total width of the line, followed by
    // elements of the form {x, y, font, text}, where x and y start at zero.
    var maxwidth = -1
    for (L in lines) {
        if (lines[L][0] > maxwidth) maxwidth = lines[L][0]
    }
    for (L in lines) {
        y0 += nline*1.2*fontsize
        nline++
        for (var p in lines[L]) {
            var k = lines[L][p]
            if (k[1] === undefined) {
                width = k
                continue
            }
            ctx.font = k[2]
            ctx.fillStyle = rgb_to_html(col)
            switch (align) {
                case 'left':
                    x = x0 + k[0]
                    y = y0 + k[1]
                    break
                case 'center':
                    x = x0 + k[0] - width/2
                    y = y0 + k[1]
                    break
                case 'right':
                    x = x0 + k[0] - maxwidth
                    y = y0 + k[1]
                    break
                default:
                    throw new Error(align+' is not a possible alignment option.')
            }
            ctx.fillText(k[3], x, y)
        }
    }
}

var c = document.getElementById("textCanvas")
var ctx = c.getContext("2d")
var s = 'The <b><i>quick</i> fox</b> <i>jumps.</i><br><i>M</i><sub>sys</sub> >= 10<sup>-3</sup> kg'
parse_html(ctx, s, 350, 50, 'center', 'Verdana', 30, [0,0,1])
</script>