本篇文章為大家展示了使用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坐標(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è)資訊頻道。
本文名稱:使用canvas怎么實現(xiàn)文本內(nèi)容自動換行-創(chuàng)新互聯(lián)
當(dāng)前URL:http://aaarwkj.com/article32/ccoipc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供App設(shè)計、商城網(wǎng)站、營銷型網(wǎng)站建設(shè)、網(wǎng)站導(dǎo)航、面包屑導(dǎo)航、云服務(wù)器
聲明:本網(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)
猜你還喜歡下面的內(nèi)容