编程 js使用canvas进行图片文字合成技术

2024-11-19 09:07:51 +0800 CST views 3162

废话不多说 直接看效果图

canves.jpg

完整代码

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <title>个人诚信证书</title>
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <style>
        body{
            padding: 0;   
            margin: 0;    
            width:100%;
            display:flex;
            align-items:center;
            justify-content: center;
            height: 100vh;
            
        }
        img{            
            width:100%;
            height: 100%;
        }
        @font-face {
            font-family: 'fzdbs';            
            src: url('/static/img/certificate/fzdbs.ttf') format('truetype');
            font-weight: normal;
            font-style: normal;
        }
        @font-face {
            font-family: 'fz';            
            src: url('/static/img/certificate/fz.ttf') format('truetype');
            font-weight: normal;
            font-style: normal;
        }
    </style>
    <script src="/static/js/jquery-1.8.3.min.js"></script>
</head>
<body >
    <h1>正在为您载入证书...</h1>
    <div class="main"></div>
<script>
    let height = $(window).height(),
        width = $(window).width(),
        images=[
                {
                    "type":"img",
                    "url":"/static/img/certificate/bg.jpg",
                    "location":{
                        x:0,
                        y:0,
                        w:600,
                        h:755
                    }
                },
                {
                    "type":"img",
                    "url":"/attachment/users/share/qrcode/2018/10/17/1539738665.png",
                    "location":{
                        x:252,
                        y:337,
                        w:91,
                        h:91
                    }
                },
                {
                    "type":"img",
                    "url":"/static/img/certificate/qy.png",
                    "location":{
                        x:221,
                        y:152,
                        w:171,
                        h:37
                    }
                },
                {
                    "type":"text",
                    "text":"授予:{$db['realname']}",
                    "font":"26px fzdbs",
                    "color":"#282828",
                    "location":{
                        x:163,
                        y:231,
                    }
                },
                {
                    "type":"text",
                    "text":"诚信守护者",
                    "font":"50px fz",
                    "color":"#b62f33",
                    "location":{
                        x:178,
                        y:300,
                    }
                },
                {
                    "type":"text",
                    "text":"人人参与 诚信建设",
                    "font":"22px fzdbs",
                    "color":"#282828",
                    "location":{
                        x:213,
                        y:460,
                    }
                }
                ,
                {
                    "type":"text",
                    "text":"共同守护 信用社会",
                    "font":"22px fzdbs",
                    "color":"#282828",
                    "location":{
                        x:213,
                        y:500,
                    }
                }
                ,
                {
                    "type":"text",
                    "text":"福建期望管家信用管理有限公司",
                    "font":"24px fzdbs",
                    "color":"#282828",
                    "location":{
                        x:148,
                        y:575,
                    }
                }
                ,
                {
                    "type":"text",
                    "text":"{$db['year']}",
                    "font":"24px fzdbs",
                    "color":"#282828",
                    "location":{
                        x:295,
                        y:615,
                    }
                },
                {
                    "type":"img",
                    "url":"/static/img/certificate/gs.png",
                    "location":{
                        x:340,
                        y:520,
                        w:121,
                        h:117
                    }
                },
        ];
    var c=document.createElement('canvas'),
        len = images.length;
        ctx=c.getContext('2d');
    c.width=600;
    c.height=775;
    ctx.rect(0,0,c.width,c.height);
    ctx.fillStyle= 'transparent';
    ctx.fill();
    function drawing(n){
        if (n<len) {
            let db = images[n];
            if (db.type == "img"){
                var img = new Image;
                img.src = db.url;
                img.onload = function(){
                    ctx.drawImage(img,db.location.x,db.location.y,db.location.w,db.location.h);
                    drawing(n+1);                              
                }
            }else if (db.type == "text"){
                ctx.font = db.font;
                ctx.fillStyle = db.color;
                ctx.fillText(db.text,db.location.x,db.location.y);
                drawing(n+1);
            }
            
        }else{
            convertCanvasToImage(c);
        }
        
        
    }
    drawing(0);
    function convertCanvasToImage(canvas) {
            var hc_image = new Image();
            hc_image.src = canvas.toDataURL("image/png");
            $("h1").hide();
            $('.main').html(hc_image);
    }  
</script>
</body>
</html>

file.png

复制全文 生成海报 js

推荐文章

Go 1.23 中的新包:unique
2024-11-18 12:32:57 +0800 CST
Vue3中如何处理组件的单元测试?
2024-11-18 15:00:45 +0800 CST
JavaScript 异步编程入门
2024-11-19 07:07:43 +0800 CST
浏览器自动播放策略
2024-11-19 08:54:41 +0800 CST
禁止调试前端页面代码
2024-11-19 02:17:33 +0800 CST
Linux查看系统配置常用命令
2024-11-17 18:20:42 +0800 CST
mysql时间对比
2024-11-18 14:35:19 +0800 CST
Git 常用命令详解
2024-11-18 16:57:24 +0800 CST
html折叠登陆表单
2024-11-18 19:51:14 +0800 CST
php 连接mssql数据库
2024-11-17 05:01:41 +0800 CST
一键配置本地yum源
2024-11-18 14:45:15 +0800 CST
deepcopy一个Go语言的深拷贝工具库
2024-11-18 18:17:40 +0800 CST
如何实现生产环境代码加密
2024-11-18 14:19:35 +0800 CST
Plyr.js 播放器介绍
2024-11-18 12:39:35 +0800 CST
XSS攻击是什么?
2024-11-19 02:10:07 +0800 CST
php腾讯云发送短信
2024-11-18 13:50:11 +0800 CST
OpenCV 检测与跟踪移动物体
2024-11-18 15:27:01 +0800 CST
一个简单的html卡片元素代码
2024-11-18 18:14:27 +0800 CST
15 个 JavaScript 性能优化技巧
2024-11-19 07:52:10 +0800 CST
程序员出海搞钱工具库
2024-11-18 22:16:19 +0800 CST
Golang 中你应该知道的 noCopy 策略
2024-11-19 05:40:53 +0800 CST
程序员茄子在线接单