【代码分享】使用HTML5的Canvas绘制编码说明图片

最急在工作中遇到一个需求,根据给定的编码生成编码说明,像下面这样的效果。

不同含义的编码用横杠分割,然后每个编码下面用箭头指明具体的含义。下面是我使用canvas实现的代码。具体的编码宽度大家可以根据实际情况进行调整,目前我的这个方法中支持起始坐标设定,和箭头的长度设定。

预览地址:https://www.huhailong.vip/res/html/codedescribe

javascript 复制代码
/**
 * 绘制编码说明图片
 * @param {起始横坐标} startX 
 * @param {起始纵坐标} startY 
 * @param {编码信息对象} codeDescribeObj
 */
function drawCode(startX, startY, codeDescribeObj) {

    const canvas = document.getElementById('code-canvas');
    const ctx = canvas.getContext('2d');

    let preTextWidth = startX;  //左侧开始坐标
    let preTextHeight = startY; //开始高度坐标

    for(let i=0; i<codeDescribeObj.codeList.length; i++){
        ctx.font = "50px Arial";
        let tempText = ctx.measureText(codeDescribeObj.codeList[i]);
        ctx.fillText(codeDescribeObj.codeList[i], preTextWidth, preTextHeight);
        if(i < codeDescribeObj.codeList.length - 1){
            ctx.fillText('---',preTextWidth+tempText.width+10,preTextHeight - 2);
        }
        ctx.stroke();
        ctx.font = "16px Arial";
        let describeY = preTextHeight + codeDescribeObj.arrowHeightList[i];
        ctx.fillText(codeDescribeObj.describeList[i], preTextWidth, describeY);
        ctx.stroke();
        //绘制箭头
        ctx.lineWidth = 1;
        ctx.beginPath();
        ctx.moveTo(preTextWidth + 30, preTextHeight + 10);
        ctx.lineTo(preTextWidth + 30, describeY - 20);
        ctx.lineTo(preTextWidth + 25, describeY - 30);
        ctx.moveTo(preTextWidth + 30, describeY - 20);
        ctx.lineTo(preTextWidth + 35, describeY - 30);
        ctx.stroke();
        //更新坐标信息
        preTextWidth = preTextWidth + tempText.width + 80;
    }
}

//定义编码信息对象
const codeDescribeObj = {
    codeList: ['F1','YHT','23Y','S1','8R'],
    describeList: ['方案代码','颜色代码','年代系列代码','品类款式代码','尺寸方向代码'],
    arrowHeightList: [100,300,200,150,300]
}

drawCode(120, 100, codeDescribeObj);

对应的html文件和css文件如下

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>编码说明图片绘制</title>
    <link rel="stylesheet" type="text/css" href="./styles.css" />
</head>
<body>
    <div class="box">
        <canvas id="code-canvas" width="1000" height="600"></canvas>
    </div>
    <script src="./index.js"></script>
</body>
</html>
css 复制代码
body{
    margin: 0;
    height: 100vh;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}
.box{
    text-align: center;
    width: 800px;
}
canvas{
    border: 1px solid gray;
    border-radius: 4px;
    width: 100%;
}

如果本次分享的代码对你有所帮助,或者觉得不错的话,记得点个大大的赞哦!

原文地址:【代码分享】使用HTML5的Canvas绘制编码说明图片

相关推荐
活宝小娜1 小时前
vue不刷新浏览器更新页面的方法
前端·javascript·vue.js
程序视点1 小时前
【Vue3新工具】Pinia.js:提升开发效率,更轻量、更高效的状态管理方案!
前端·javascript·vue.js·typescript·vue·ecmascript
coldriversnow1 小时前
在Vue中,vue document.onkeydown 无效
前端·javascript·vue.js
我开心就好o1 小时前
uniapp点左上角返回键, 重复来回跳转的问题 解决方案
前端·javascript·uni-app
开心工作室_kaic2 小时前
ssm161基于web的资源共享平台的共享与开发+jsp(论文+源码)_kaic
java·开发语言·前端
刚刚好ā2 小时前
js作用域超全介绍--全局作用域、局部作用、块级作用域
前端·javascript·vue.js·vue
沉默璇年3 小时前
react中useMemo的使用场景
前端·react.js·前端框架
yqcoder3 小时前
reactflow 中 useNodesState 模块作用
开发语言·前端·javascript
2401_882727573 小时前
BY组态-低代码web可视化组件
前端·后端·物联网·低代码·数学建模·前端框架
SoaringHeart4 小时前
Flutter进阶:基于 MLKit 的 OCR 文字识别
前端·flutter