zoukankan      html  css  js  c++  java
  • canvas绘制在画布中心的一段文字

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
        <style>
            canvas {
                border: 1px solid #ccc;
                display: block;
                margin: 100px auto;
            }
        </style>
    </head>
    <body>
    <canvas width="600" height="400"></canvas>
    <script>
        var myCanvas = document.querySelector('canvas');
        var ctx = myCanvas.getContext('2d');
        /*1.在画布的中心绘制一段文字*/
        /*2.申明一段文字*/
        var str = '您吃-,了吗';
        /*3.确定画布的中心*/
        var w = ctx.canvas.width;
        var h = ctx.canvas.height;
        /*4.画一个十字架在画布的中心*/
        ctx.beginPath();
        ctx.moveTo(0, h / 2 - 0.5);
        ctx.lineTo(w, h / 2 - 0.5);
        ctx.moveTo(w / 2 - 0.5, 0);
        ctx.lineTo(w / 2 - 0.5, h);
        ctx.strokeStyle = '#eee';
        ctx.stroke();
        /*5.绘制文本*/
        ctx.beginPath();
        ctx.strokeStyle = '#000';
        var x0 = w/2;
        var y0 = h/2;
        /*注意:起点位置在文字的左下角*/
        /*有文本的属性  尺寸 字体  左右对齐方式  垂直对齐的方式*/
        ctx.font = '40px Microsoft YaHei';
        /*左右对齐方式 (center left right start end) 基准起始坐标*/
        ctx.textAlign = 'center';
        /*垂直对齐的方式 基线 baseline(top,bottom,middle) 基准起始坐标*/
        ctx.textBaseline = 'middle';
        //ctx.direction = 'rtl';
        //ctx.strokeText(str,x0,y0);
        ctx.fillText(str,x0,y0);
        /*6.画一个下划线和文字一样长*/
        ctx.beginPath();
        /*获取文本的宽度*/
        console.log(ctx.measureText(str));
        var width = ctx.measureText(str).width;
        ctx.moveTo(x0-width/2,y0 + 20);
        ctx.lineTo(x0+width/2,y0 + 20);
        ctx.stroke();
    </script>
    </body>
    </html>

    别废话,拿你代码给我看。
  • 相关阅读:
    EasyDarwin开源流媒体服务器实现RTSP直播同步输出MP4、RTMP、HLS的方案思路
    OBS桌面视频直播软件/推流工具使用指南
    C++界面库
    . net 源代码调试
    WPF学习之X名称空间详解
    NSIS安装程序制作工具判断系统是否安装.NET
    Qt学习笔记常用容器
    快捷键
    Python中if __name__ == '__main__':作用
    python中__init__.py文件的作用
  • 原文地址:https://www.cnblogs.com/lvxueyang/p/13707445.html
Copyright © 2011-2022 走看看