微信小程序 canvas 文字自動換行

Page({

    drawCanvas: function(ctx) {// 地址
        ctx.setFontSize(14)
        ctx.setFillStyle('#9E7240')
        ctx.textAlign="center";
        const txHash = this.data.info.txHash ? this.data.info.txHash : '暫無信息'
        this.drawText(ctx,txHash,187, 517 , 232,232) // 自動換行
       
        ctx.draw()
        ctx.save()
    },// 文本自動換行
    drawText: function(ctx, str, leftWidth, initHeight, titleHeight, canvasWidth) {
        var lineWidth = 0;
        var lastSubStrIndex = 0; //每次開始截取的字符串的索引
        for (let i = 0; i < str.length; i++) {
            lineWidth += ctx.measureText(str[i]).width;
            if (lineWidth > canvasWidth) {
                ctx.fillText(str.substring(lastSubStrIndex, i), leftWidth, initHeight); //繪製截取部分
                initHeight += 16; //16爲字體的高度
                lineWidth = 0;
                lastSubStrIndex = i;
                titleHeight += 30;
            }
            if (i == str.length - 1) { //繪製剩餘部分
                ctx.fillText(str.substring(lastSubStrIndex, i + 1), leftWidth, initHeight);
            }
        }
        // 標題border-bottom 線距頂部距離
        titleHeight = titleHeight + 10;
        return titleHeight
    },

    
})
相關文章
相關標籤/搜索