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

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

废话不多说 直接看效果图

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服务器直传阿里云OSS
2024-11-18 19:04:44 +0800 CST
Python设计模式之工厂模式详解
2024-11-19 09:36:23 +0800 CST
MySQL 日志详解
2024-11-19 02:17:30 +0800 CST
12个非常有用的JavaScript技巧
2024-11-19 05:36:14 +0800 CST
使用 Git 制作升级包
2024-11-19 02:19:48 +0800 CST
Go 协程上下文切换的代价
2024-11-19 09:32:28 +0800 CST
Plyr.js 播放器介绍
2024-11-18 12:39:35 +0800 CST
Manticore Search:高性能的搜索引擎
2024-11-19 03:43:32 +0800 CST
PHP 的生成器,用过的都说好!
2024-11-18 04:43:02 +0800 CST
go发送邮件代码
2024-11-18 18:30:31 +0800 CST
Nginx rewrite 的用法
2024-11-18 22:59:02 +0800 CST
如何在Vue中处理动态路由?
2024-11-19 06:09:50 +0800 CST
Vue3中的v-slot指令有什么改变?
2024-11-18 07:32:50 +0800 CST
Vue3 中提供了哪些新的指令
2024-11-19 01:48:20 +0800 CST
网站日志分析脚本
2024-11-19 03:48:35 +0800 CST
介绍Vue3的Tree Shaking是什么?
2024-11-18 20:37:41 +0800 CST
Vue中如何处理异步更新DOM?
2024-11-18 22:38:53 +0800 CST
Rust 高性能 XML 读写库
2024-11-19 07:50:32 +0800 CST
批量导入scv数据库
2024-11-17 05:07:51 +0800 CST
程序员茄子在线接单