`

canvas绘制文本

阅读更多

在HTML5中,我们还可以在Canvas「画布」上绘制我们所需的文本文字,其中所涉及到的CanvasRenderingContext2D对象的主要属性和方法如下:

属性或方法 基本描述
font 设置绘制文字所使用的字体,例如20px 宋体,默认值为10px sans-serif。该属性的用法与css font属性一致,例如italic bold 14px/30px Arial,宋体
fillStyle 用于设置画笔填充路径内部的颜色、渐变和模式。该属性的值可以是一个表示CSS颜色值的字符串。如果你的绘制需求比较复杂,该属性的值还可以是一个CanvasGradient对象或者CanvasPattern对象
strokeStyle 用于设置画笔绘制路径的颜色、渐变和模式。该属性的值可以是一个表示CSS颜色值的字符串。如果你的绘制需求比较复杂,该属性的值还可以是一个CanvasGradient对象或者CanvasPattern对象
fillText(string text, int x, int y[, int maxWidth]) 从指定坐标点位置开始绘制填充的文本文字。参数maxWidth是可选的,如果文本内容宽度超过该参数设置,则会自动按比例缩小字体以适应宽度。与本方法对应的样式设置属性为fillStyle
strokeText(string text, int x, int y[, int maxWidth]) 从指定坐标点位置开始绘制非填充的文本文字(文字内部是空心的)。参数maxWidth是可选的,如果文本内容宽度超过该参数设置,则会自动按比例缩小字体以适应宽度。该方法与fillText()用法一致,不过strokeText()绘制的文字内部是非填充(空心)的,fillText()绘制的文字是内部填充(实心)的。与本方法对应的样式设置属性为strokeStyle

从上面的API描述信息中我们可以得知,在Canvas中可以使用两种方式来绘制文本文字:一种是使用fillText()+fillStyle来绘制填充(实心)的文字;一种是使用strokeText()+strokeStyle绘制非填充(空心)的文字。

下面,我们先来看看如何使用canvas绘制实心文字,具体html代码如下:

 

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>HTML5 Canvas绘制文本文字入门示例</title>
</head>
<body>

<!-- 添加canvas标签,并加上红色边框以便于在页面上查看 -->
<canvas id="myCanvas" width="400px" height="300px" style="border: 1px solid red;">
您的浏览器不支持canvas标签。
</canvas>

<script type="text/javascript">
//获取Canvas对象(画布)
var canvas = document.getElementById("myCanvas");
//简单地检测当前浏览器是否支持Canvas对象,以免在一些不支持html5的浏览器中提示语法错误
if(canvas.getContext){  
    //获取对应的CanvasRenderingContext2D对象(画笔)
    var ctx = canvas.getContext("2d");
    
    //设置字体样式
    ctx.font = "30px Courier New";
    //设置字体填充颜色
    ctx.fillStyle = "blue";
    //从坐标点(50,50)开始绘制文字
    ctx.fillText("CodePlayer+中文测试", 50, 50);
}
</script>
</body>
</html>

 

对应的显示效果如下

使用canvas绘制的蓝色实心文字效果使用canvas绘制的蓝色实心文字效果

接着,我们使其他环境条件均保持不变,再次使用strokeText()+strokeStyle方式来绘制上述示例中的文字,对应的JavaScript代码如下:

 

<script type="text/javascript">
//获取Canvas对象(画布)
var canvas = document.getElementById("myCanvas");
//简单地检测当前浏览器是否支持Canvas对象,以免在一些不支持html5的浏览器中提示语法错误
if(canvas.getContext){  
    //获取对应的CanvasRenderingContext2D对象(画笔)
    var ctx = canvas.getContext("2d");
    
    //设置字体样式
    ctx.font = "30px Courier New";
    //设置字体颜色
    ctx.strokeStyle = "blue";
    //从坐标点(50,50)开始绘制文字
    ctx.strokeText("CodePlayer+中文测试", 50, 50);
}
</script>

 

我们再次使用浏览器访问页面,将会看到如下显示效果(效果图片中的"CodePlayer"字样其实也是空心的,只是由于字体较小导致两侧看起来重叠在了一起):

使用canvas绘制的蓝色空心文字效果使用canvas绘制的蓝色空心文字效果

 

 

 

拓展:

①HTML5画布文字垂直对齐

在HTML5画布中我们使用textBaseline属性来设置对齐方式,对应值如下:

  • top
  • bottom
  • middle
  • hanging(挂)
  • alphabetic(拼音)
  • ideographic

如果你没有设置此属性,默认为:alphabetic

 

②HTML5画布获取文字度量

在HTML5画布中,使用measureText方法来获取文字的相关度量信息对象,其中包含一个属性,即文字宽度。

基于文字的大小和字体,它可以提供一个准确的文字宽度。

 

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>画布获取文字度量</title>
</head>
<body>

<!-- 添加canvas标签,并加上红色边框以便于在页面上查看 -->
<canvas id="gbcanvas" width="550" height="300"></canvas>

<script type="text/javascript">
    /*Javascript源代码*/
    var canvas = document.getElementById('gbcanvas'), // 这里通过gbCanvas获取canvas对象
            context = canvas.getContext('2d'); //这里通过canvas获取处理API的上下文context

    var x = canvas.width/2, y = canvas.height/2 -10;
    var text = '你好,gbtags.com';

    context.font = 'bold 30pt "microsoft yahei"';
    context.textAlign = 'center';
    context.fillStyle = 'red';
    context.fillText( text, x, y);

    //以下代码获取上面定义text的相关metrics信息

    var metrics = context.measureText(text);
    var width = metrics.width;

    context.font = '15pt Arial';
    context.textAlign = 'center';
    context.fillStyle = '#888888';
    context.fillText('-' + width + 'px-', x, y +45);
</script>
</body>
</html>
 

 ③HTML5画布实现文字折行效果

HTML5画布中,如果需要文字折行效果,需要我们自己书写相关逻辑实现,这里我们可以利用到前面介绍的 measureTex()方法来计算当前文字的宽度,并且和当前能够显示的宽度做比对

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>HTML5 CanvasPattern实现图像平铺的入门示例</title>
</head>
<body>

<!-- 添加canvas标签,并加上红色边框以便于在页面上查看 -->
<canvas id="gbcanvas" width="550" height="3020"></canvas>

<script type="text/javascript">
    var canvas = document.getElementById('gbcanvas'),
            context = canvas.getContext('2d');
    var maxWidth = 500, lineHeight = 30, x = (canvas.width -maxWidth)/2, y = 60
    text = '极客所定义一个处理文字折行的方法,使用前面我们介绍,有文字保存到数组';
    context.font = 'bold 20pt "microsoft yahei"';
    context.fillStyle = '#DD4814';
    wrapText(context, text, x, y, maxWidth, lineHeight);


    /*
     * 定义一个处理文字折行的方法,使用前面我们介绍的meaureText方法
     */

    function wrapText(context, text, x, y, maxWidth, lineHeight){

        var words = text.split(''); //这里我们将所有文字保存到数组中,注意如果处理英文,请使用split(' ');
        var line = '';

        for(var n = 0; n<words.length; n++){
            var testLine = line + words[n];
            var metrics = context.measureText(testLine); //使用measureText计算宽度
            var testWidth  = metrics.width;
            if(testWidth > maxWidth && n>0){ //此处判断文字宽度是否超过可显示最大宽度
                context.fillText(line, x, y);
                line = words[n];
//                console.log(line)
                y += lineHeight; //此处设置添加文字到下一行的位置

            }else{
                line = testLine;
            }
        }

        context.fillText(line, x, y);

    }

</script>
</body>
</html>

 

 

 

 

 

 

 

 

 

.

分享到:
评论

相关推荐

    canvas绘制文本内容自动换行的实现代码

    本文将详细介绍如何使用JavaScript编写一个函数,实现在Canvas上绘制文本内容时自动换行。 首先,我们需要理解Canvas API中的`fillText()`方法,它是用来在Canvas上填充文本的。但这个方法不支持文本换行,所以我们...

    canvas 合成 文字 图片

    在前端开发中,Canvas是HTML5提供的一种强大的图形绘制API,可以用来动态生成图像、进行图像处理和合成。本文将详细介绍如何使用Canvas进行文字与图片的合成,通过一个简单的入门Demo来展示具体实现过程。 首先,...

    js+html5实现canvas绘制镂空字体文本的方法.docx

    Canvas绘制镂空字体文本的方法 HTML5的Canvas元素提供了强大的图形绘制能力,通过使用JavaScript可以实现各种图形绘制,包括镂空字体文本的绘制。下面将详细介绍使用JavaScript和HTML5实现Canvas绘制镂空字体文本的...

    基于QT的Qml Canvas文本显示

    在Canvas上绘制文本前,可能需要测量文本的尺寸。`measureText`方法可以做到这一点: ```javascript var textWidth = ctx.measureText('测量的文本').width ``` 六、文本路径与轮廓 除了基本的填充文本,我们还...

    HTML5 canvas绘制流程图

    编辑文字则涉及到`fillText()`方法,它允许我们在画布上绘制文本: ```javascript context.font = '24px Arial'; // 设置字体样式 context.fillText('流程图节点', 30, 35); // 在(30, 35)处写入文本 ``` 拖拽功能...

    鼠标在canvas上悬浮,并提示鼠标位置信息

    一种简单的方式是在Canvas上绘制文本,使用`fillText`方法: ```javascript var ctx = canvas.getContext('2d'); ctx.clearRect(0, 0, canvas.width, canvas.height); // 清除Canvas ctx.fillText('鼠标位置:(' + ...

    Canvas绘制心电图

    使用Canvas绘制心电图,我们可以创建自定义的可视化,用于教育、模拟或数据展示目的。 Canvas是HTML5的一个核心特性,它提供了一个二维绘图环境,允许开发者通过JavaScript代码动态地绘制图形。要绘制心电图,我们...

    html5结构图canvas绘制组织结构图框架代码

    在HTML5 Canvas上实现组织结构图,首先需要理解Canvas的基本绘图方法,如`fillRect()`用于绘制矩形,`beginPath()`和`stroke()`用于绘制线条,以及`fillText()`用于添加文本。这些API是构建组织结构图的基础。 在...

    canvas 绘制的 vue 表格组件,解决上万行+多列数据渲染问题,集成大部分表格功能.zip

    开发这样一个组件,需要深入理解canvas API,包括如何绘制文本、线条、矩形等基本元素,以及如何高效地管理和更新画布上的内容。同时,也需要熟悉Vue的生命周期、组件通信和状态管理。 使用此组件,开发者可以轻松...

    第26章 canvas绘制文字

    通过分析这两个文件,你可以看到实际的用例,从而更好地理解和应用Canvas绘制文字的技术。 总结来说,HTML5 Canvas提供了强大的文字绘制能力,允许开发者创建各种动态文本效果。通过调整不同的属性和方法,我们可以...

    Canvas绘制3D文字摇晃特效.zip

    Canvas API提供了`fillText()`和`strokeText()`函数用于在画布上绘制文本,但它们不直接支持3D效果。因此,要创建3D效果,我们需要手动处理深度、透视和阴影等元素。 在Canvas上创建3D文字摇晃特效,一般涉及以下...

    微信小程序canvas画布绘制矩形、椭(圆)、直线、文字

    以上就是微信小程序中使用Canvas绘制矩形、椭圆、直线和文字的基本操作。在实际开发中,还可以结合动画、事件处理等,创建出更加复杂和交互式的图形界面。记得在完成绘制后,使用`wx.canvasToTempFilePath()`方法将...

    一个基于html5与canvas绘制的弹幕播放器.zip

    使用`context.fillText()`方法绘制文本,`context.moveTo()`和`context.lineTo()`等方法可以控制弹幕的移动轨迹。 为了实现动态效果,我们需要在每次绘制之后调用`context.clearRect()`清除上一次的绘制,然后再...

    详解canvas在圆弧周围绘制文本的两种写法

    通过`context.translate`和`context.rotate`改变坐标系,使得我们可以直接在X和Y轴上使用`fillText`和`strokeText`方法绘制文本。这种方法直观且灵活,更适合对弧度有深刻理解的开发者。 **第二种方法:使用角度...

    android源代码-canvas绘制动态折线图

    在这个方法内,我们可以调用Canvas的各种绘制函数,如`drawLine()`来画线,`drawText()`来显示文本,以及`drawBitmap()`来绘制位图等。 在动态折线图的实现中,关键在于数据更新和重绘。首先,我们需要一个数据模型...

    HTML5 Canvas旋转文本动画

    Canvas API提供了各种方法和属性,使得在画布上绘制文本、图像、线条等元素变得可能,而其中的动画效果更是增添了动态的魅力。在本篇文章中,我们将深入探讨如何使用HTML5 Canvas实现文本的旋转动画。 首先,我们...

    使用HTML5 Canvas绘制 3D房间模型和人物动画特效

    在"使用HTML5 Canvas绘制3D房间模型和人物动画特效"这个主题中,我们将深入探讨如何利用Canvas技术构建逼真的3D环境,并实现动态的人物动画。 一、HTML5 Canvas基础 HTML5 Canvas是一个基于矢量图形的画布元素,...

Global site tag (gtag.js) - Google Analytics