html5 canvas的绘制文本自动换行的示例代码


Posted in HTML / CSS onSeptember 17, 2018

本文介绍怎么解决canvas绘图过程中,drawText的换行问题,先看一个大家平时在canvas绘制文本都会遇到的问题:

一个150*100的canvas画布,加个边框明显边界

<canvas id="canvas" style="border:solid 1px darkgoldenrod;" width="200px" height="100px"></canvas>

我们先来看fillText()方法,strokeText()方法同理

html5 canvas的绘制文本自动换行的示例代码

var c=document.getElementById("canvas"); 
var ctx=c.getContext("2d"); 
ctx.fillStyle="#E992B9";
ctx.lineWidth=1;
var str = "假如生活欺骗了你,请不要悲伤!thank you!"
ctx.fillText(str,0,20);

可以看到fillText()在固宽的canvas中,字数过多的时候,并不会自动换行,我们可以增加canvas本身的宽度,但这不是解决问题的根本方法。还记得之前介绍canvas基本api的时候,有一个函数,context.measureText(text) 这个函数可以测量字体的宽高度,那就好办了,我们计算好我们字符串的长度加上一个大概的宽度,基本上可以处理这种换行的问题了。

下面看具体实现方法:

var c=document.getElementById("canvas"); 
var ctx=c.getContext("2d"); 
ctx.fillStyle="#E992B9";
ctx.lineWidth=1; 
var str = "假如生活欺骗了你,请不要悲伤!thank you!"
var lineWidth = 0;
var canvasWidth = c.width;//计算canvas的宽度
var initHeight=15;//绘制字体距离canvas顶部初始的高度
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),0,initHeight);//绘制截取部分
        initHeight+=20;//20为字体的高度
        lineWidth=0;
        lastSubStrIndex=i;
    } 
    if(i==str.length-1){//绘制剩余部分
        ctx.fillText(str.substring(lastSubStrIndex,i+1),0,initHeight);
    }
}

见效果图:

html5 canvas的绘制文本自动换行的示例代码

算法:计算字符串str里面每个字符的宽度的和lineWidth,如果大于canvas的宽度,就截取这部分进行绘制,然后重置lineWidth,保存开始截取的最后的索引,当循环变量i为最后一个字符的时候,直接绘制剩余部分。

接下来:我们封装成一个方法,方便以后直接调用:

/*
str:要绘制的字符串
canvas:canvas对象
initX:绘制字符串起始x坐标
initY:绘制字符串起始y坐标
lineHeight:字行高,自己定义个值即可
*/
function canvasTextAutoLine(str,canvas,initX,initY,lineHeight){
    var ctx = canvas.getContext("2d"); 
    var lineWidth = 0;
    var canvasWidth = c.width; 
    var lastSubStrIndex= 0; 
    for(let i=0;i<str.length;i++){ 
        lineWidth+=ctx.measureText(str[i]).width; 
        if(lineWidth>canvasWidth-initX){//减去initX,防止边界出现的问题
            ctx.fillText(str.substring(lastSubStrIndex,i),initX,initY);
            initY+=lineHeight;
            lineWidth=0;
            lastSubStrIndex=i;
        } 
        if(i==str.length-1){
            ctx.fillText(str.substring(lastSubStrIndex,i+1),initX,initY);
        }
    }
  }

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

HTML / CSS 相关文章推荐
CSS3 三维变形实现立体方块特效源码
Dec 15 HTML / CSS
CSS3制作翻转效果_动力节点Java学院整理
Jul 11 HTML / CSS
css3实现文字扫光渐变动画效果的示例
Nov 07 HTML / CSS
CSS3实现div从下往上滑入滑出效果示例
Apr 28 HTML / CSS
css3的focus-within选择器的使用
May 11 HTML / CSS
HTML5 Canvas概述
Aug 26 HTML / CSS
html5声频audio和视频video等新特性详细说明
Dec 26 HTML / CSS
canvas使用注意点总结
Jul 19 HTML / CSS
HTML5拖放效果的实现代码
Nov 17 HTML / CSS
canvas裁剪clip()函数的具体使用
Mar 01 HTML / CSS
AmazeUI的下载配置与Helloworld的实现
Aug 19 HTML / CSS
HTML5拖拽文件上传的示例代码
Mar 04 HTML / CSS
HTML5新标签兼容——&gt; 的两种方法
Sep 12 #HTML / CSS
html5使用canvas压缩图片的示例代码
Sep 11 #HTML / CSS
canvas像素点操作之视频绿幕抠图
Sep 11 #HTML / CSS
HTML5中使用json对象的实例代码
Sep 10 #HTML / CSS
html5 figure和figcaption的使用方法
Sep 10 #HTML / CSS
用canvas画心电图的示例代码
Sep 10 #HTML / CSS
Html5 canvas实现粒子时钟的示例代码
Sep 06 #HTML / CSS
You might like
B2K与车机的中波PK
2021/03/02 无线电
PHP自动生成月历代码
2006/10/09 PHP
PHP Smarty模版简单使用方法
2016/03/30 PHP
yii2中LinkPager增加总页数和总记录数的实例
2017/08/28 PHP
广告切换效果(缓动切换)
2009/05/27 Javascript
jquery数组之存放checkbox全选值示例代码
2013/12/20 Javascript
js代码实现无缝滚动(文字和图片)
2015/08/20 Javascript
Bootstrap每天必学之弹出框(Popover)插件
2016/04/25 Javascript
js省市县三级联动效果实例
2020/04/15 Javascript
DOM操作和jQuery实现选项移动操作的简单实例
2016/06/07 Javascript
ES6新特性四:变量的解构赋值实例
2017/04/21 Javascript
纯JavaScript实现实时反馈系统时间
2017/10/26 Javascript
js构造函数创建对象是否加new问题
2018/01/22 Javascript
解决使用Vue.js显示数据的时,页面闪现原始代码的问题
2018/02/11 Javascript
在vue中使用css modules替代scroped的方法
2018/03/10 Javascript
webpack自动打包和热更新的实现方法
2019/06/24 Javascript
javascript二维数组和对象的深拷贝与浅拷贝实例分析
2019/10/26 Javascript
如何在vue中使用jointjs过程解析
2020/05/29 Javascript
对numpy中轴与维度的理解
2018/04/18 Python
详解Python3中ceil()函数用法
2019/02/19 Python
分析经典Python开发工程师面试题
2019/04/08 Python
python操作excel让工作自动化
2019/08/09 Python
将Pytorch模型从CPU转换成GPU的实现方法
2019/08/19 Python
Django之使用内置函数和celery发邮件的方法示例
2019/09/16 Python
Python多线程多进程实例对比解析
2020/03/12 Python
Python进程间通信multiprocess代码实例
2020/03/18 Python
联想德国官网:Lenovo Germany
2018/07/04 全球购物
美体小铺波兰官方网站:The Body Shop波兰
2019/09/03 全球购物
【魔兽争霸3重制版】原版画面与淬火MOD画面对比
2021/03/26 魔兽争霸
电子商务应届生求职信
2013/11/16 职场文书
干部行政关系介绍信
2014/01/17 职场文书
怎样写好创业计划书的内容
2014/02/06 职场文书
歌咏比赛口号大全
2015/12/25 职场文书
市场营销计划书
2019/04/24 职场文书
职场干货:简历中的自我评价应该这样写!
2019/05/06 职场文书
SpringBoot详解整合Redis缓存方法
2022/07/15 Java/Android