本篇文章為大家展示了使用canvas怎么實(shí)現(xiàn)文本內(nèi)容自動(dòng)換行,內(nèi)容簡(jiǎn)明扼要并且容易理解,絕對(duì)能使你眼前一亮,通過(guò)這篇文章的詳細(xì)介紹希望你能有所收獲。
創(chuàng)新互聯(lián)成立與2013年,是專(zhuān)業(yè)互聯(lián)網(wǎng)技術(shù)服務(wù)公司,擁有項(xiàng)目網(wǎng)站制作、做網(wǎng)站網(wǎng)站策劃,項(xiàng)目實(shí)施與項(xiàng)目整合能力。我們以讓每一個(gè)夢(mèng)想脫穎而出為使命,1280元邢臺(tái)做網(wǎng)站,已為上家服務(wù),為邢臺(tái)各地企業(yè)和個(gè)人服務(wù),聯(lián)系電話(huà):028-86922220
ctx: 畫(huà)布的上下文環(huán)境
content: 需要繪制的文本內(nèi)容
drawX: 繪制文本的x坐標(biāo)
drawY: 繪制文本的y坐標(biāo)
lineHeight:文本之間的行高
lineMaxWidth:每行文本的最大寬度
lineNum:最多繪制的行數(shù)
// 文字自動(dòng)換行 function textPrewrap(ctx, content, drawX, drawY, lineHeight, lineMaxWidth, lineNum) { var drawTxt = ''; // 當(dāng)前繪制的內(nèi)容 var drawLine = 1; // 第幾行開(kāi)始繪制 var drawIndex = 0; // 當(dāng)前繪制內(nèi)容的索引 // 判斷內(nèi)容是否可以一行繪制完畢 if(ctx.measureText(content).width <= lineMaxWidth) { ctx.fillText(content.substring(drawIndex, i), drawX, drawY); } else { for (var i = 0; i <= content.length; i++) { drawTxt += content[i]; if (ctx.measureText(drawTxt).width > lineMaxWidth) { if (drawLine === lineNum) { // 最后一行添加省略號(hào) ctx.fillText(content.substring(drawIndex, i) + '...', drawX, drawY); break; } else { // 不是最后一行的情況 ctx.fillText(content.substring(drawIndex, i + 1), drawX, drawY); drawIndex = i + 1; // 記錄當(dāng)前行最后一個(gè)字符串的下一個(gè)idnex,用于繪制下行第一個(gè)字 drawLine += 1; // 行數(shù)+1 drawY += lineHeight; // 繪制內(nèi)容的y坐標(biāo)對(duì)應(yīng)增加行高 drawTxt = ''; // 重置繪制的內(nèi)容 } } } } }
上述內(nèi)容就是使用canvas怎么實(shí)現(xiàn)文本內(nèi)容自動(dòng)換行,你們學(xué)到知識(shí)或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識(shí)儲(chǔ)備,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。