本篇文章為大家展示了使用canvas怎么實現(xiàn)文本內(nèi)容自動換行,內(nèi)容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細(xì)介紹希望你能有所收獲。
創(chuàng)新互聯(lián)成立與2013年,是專業(yè)互聯(lián)網(wǎng)技術(shù)服務(wù)公司,擁有項目網(wǎng)站制作、做網(wǎng)站網(wǎng)站策劃,項目實施與項目整合能力。我們以讓每一個夢想脫穎而出為使命,1280元邢臺做網(wǎng)站,已為上家服務(wù),為邢臺各地企業(yè)和個人服務(wù),聯(lián)系電話:028-86922220
ctx: 畫布的上下文環(huán)境
content: 需要繪制的文本內(nèi)容
drawX: 繪制文本的x坐標(biāo)
drawY: 繪制文本的y坐標(biāo)
lineHeight:文本之間的行高
lineMaxWidth:每行文本的最大寬度
lineNum:最多繪制的行數(shù)
// 文字自動換行 function textPrewrap(ctx, content, drawX, drawY, lineHeight, lineMaxWidth, lineNum) { var drawTxt = ''; // 當(dāng)前繪制的內(nèi)容 var drawLine = 1; // 第幾行開始繪制 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) { // 最后一行添加省略號 ctx.fillText(content.substring(drawIndex, i) + '...', drawX, drawY); break; } else { // 不是最后一行的情況 ctx.fillText(content.substring(drawIndex, i + 1), drawX, drawY); drawIndex = i + 1; // 記錄當(dāng)前行最后一個字符串的下一個idnex,用于繪制下行第一個字 drawLine += 1; // 行數(shù)+1 drawY += lineHeight; // 繪制內(nèi)容的y坐標(biāo)對應(yīng)增加行高 drawTxt = ''; // 重置繪制的內(nèi)容 } } } } }
上述內(nèi)容就是使用canvas怎么實現(xiàn)文本內(nèi)容自動換行,你們學(xué)到知識或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識儲備,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。
新聞標(biāo)題:使用canvas怎么實現(xiàn)文本內(nèi)容自動換行
網(wǎng)站路徑:http://aaarwkj.com/article8/jjggip.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供微信小程序、App開發(fā)、定制網(wǎng)站、微信公眾號、自適應(yīng)網(wǎng)站、網(wǎng)站設(shè)計
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)