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

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

废话不多说 直接看效果图

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

推荐文章

PHP 8.4 中的新数组函数
2024-11-19 08:33:52 +0800 CST
H5抖音商城小黄车购物系统
2024-11-19 08:04:29 +0800 CST
推荐几个前端常用的工具网站
2024-11-19 07:58:08 +0800 CST
go错误处理
2024-11-18 18:17:38 +0800 CST
Go语言中的`Ring`循环链表结构
2024-11-19 00:00:46 +0800 CST
Rust async/await 异步运行时
2024-11-18 19:04:17 +0800 CST
使用 Vue3 和 Axios 实现 CRUD 操作
2024-11-19 01:57:50 +0800 CST
一键配置本地yum源
2024-11-18 14:45:15 +0800 CST
Vue中的`key`属性有什么作用?
2024-11-17 11:49:45 +0800 CST
filecmp,一个Python中非常有用的库
2024-11-19 03:23:11 +0800 CST
关于 `nohup` 和 `&` 的使用说明
2024-11-19 08:49:44 +0800 CST
Vue3中的虚拟滚动有哪些改进?
2024-11-18 23:58:18 +0800 CST
JavaScript 上传文件的几种方式
2024-11-18 21:11:59 +0800 CST
Vue3中的Scoped Slots有什么改变?
2024-11-17 13:50:01 +0800 CST
Vue3中的v-slot指令有什么改变?
2024-11-18 07:32:50 +0800 CST
GROMACS:一个美轮美奂的C++库
2024-11-18 19:43:29 +0800 CST
前端如何给页面添加水印
2024-11-19 07:12:56 +0800 CST
Go 协程上下文切换的代价
2024-11-19 09:32:28 +0800 CST
程序员茄子在线接单