本篇文章為大家展示了使用canvas怎么實現(xiàn)文本內(nèi)容自動換行,內(nèi)容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。
成都創(chuàng)新互聯(lián)公司是專業(yè)的灤州網(wǎng)站建設(shè)公司,灤州接單;提供網(wǎng)站建設(shè)、做網(wǎng)站,網(wǎng)頁設(shè)計,網(wǎng)站設(shè)計,建網(wǎng)站,PHP網(wǎng)站建設(shè)等專業(yè)做網(wǎng)站服務(wù);采用PHP框架,可快速的進行灤州網(wǎng)站開發(fā)網(wǎng)頁制作和功能擴展;專業(yè)做搜索引擎喜愛的網(wǎng)站,專業(yè)的做網(wǎng)站團隊,希望更多企業(yè)前來合作!ctx: 畫布的上下文環(huán)境
content: 需要繪制的文本內(nèi)容
drawX: 繪制文本的x坐標
drawY: 繪制文本的y坐標
lineHeight:文本之間的行高
lineMaxWidth:每行文本的較大寬度
lineNum:最多繪制的行數(shù)
// 文字自動換行 function textPrewrap(ctx, content, drawX, drawY, lineHeight, lineMaxWidth, lineNum) { var drawTxt = ''; // 當前繪制的內(nèi)容 var drawLine = 1; // 第幾行開始繪制 var drawIndex = 0; // 當前繪制內(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) { // 最后一行添加省略號 ctx.fillText(content.substring(drawIndex, i) + '...', drawX, drawY); break; } else { // 不是最后一行的情況 ctx.fillText(content.substring(drawIndex, i + 1), drawX, drawY); drawIndex = i + 1; // 記錄當前行最后一個字符串的下一個idnex,用于繪制下行第一個字 drawLine += 1; // 行數(shù)+1 drawY += lineHeight; // 繪制內(nèi)容的y坐標對應(yīng)增加行高 drawTxt = ''; // 重置繪制的內(nèi)容 } } } } }
上述內(nèi)容就是使用canvas怎么實現(xiàn)文本內(nèi)容自動換行,你們學(xué)到知識或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識儲備,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。