Heim  >  Artikel  >  Web-Frontend  >  js und Canvas synthetisieren Bilder, um Poster für öffentliche WeChat-Konten zu erstellen

js und Canvas synthetisieren Bilder, um Poster für öffentliche WeChat-Konten zu erstellen

php中世界最好的语言
php中世界最好的语言Original
2018-03-16 09:31:1911177Durchsuche

Dieses Mal werde ich Ihnen die Funktion zum Synthetisieren von Bildern mit JS und Leinwand vorstellen, um offizielle WeChat-Kontoposter zu erstellen, und die Funktion des Synthetisierens von JS- und Leinwandbildern, um offizielle WeChat-Kontoposter zu erstellen Notizen Es gibt Welche, die folgenden sind praktische Fälle, werfen wir einen Blick darauf.

Bei der Entwicklung öffentlicher WeChat-Konten besteht häufig die Notwendigkeit, ein Bild, einen Avatar, einen Spitznamen oder andere Daten hinzuzufügen, um ein eigenes QR-Code-Poster oder ein Freigabeplakat zu erstellen.

Dies Anforderungen: Die gd-Bibliothek von PHP kann implementiert werden, aber die Verwendung des Servers für die Bildsynthese verbraucht viele Serverressourcen

Daher können wir erwägen, sie auf folgende Weise zu implementieren

1: js-Leinwandbild Synthesemethode

 $(function () {
        draw(function () {//生成之后的回调
            $('#img')[0].innerHTML='<img  alt="js und Canvas synthetisieren Bilder, um Poster für öffentliche WeChat-Konten zu erstellen" >';//将base生成图片
        });
    });
    var data=[图片1地址,图片2地址,图片3地址];
    base64=[];//用于保存生成之后的base64
    function draw(fn) {
        var img1= new Image;
        img1.src = data[0];
        img1.onload = function () {//这步必须,因为图片加载是异步的,必须等图片加载完成才开始下面的这些步骤
            var c = document.createElement('canvas'),
                    ctx = c.getContext('2d');
                        c.width = img1.naturalWidth;
                        c.height = img1.naturalHeight;
                        ctx.rect(0, 0, c.width, c.height);
                        ctx.fillStyle = '#fff';
                        ctx.fill();
            //生成一张图片1的底图
                         
            /*下面是为底图增加上文字*/
            ctx.drawImage(img1, 0, 0, c.width, c.height);(绘制图片资源,x坐标,y坐标,宽,高)
            //设置字体样式
            ctx.font = "24px Courier New";
            //设置字体填充颜色
            ctx.fillStyle = "write";
            //从坐标点(92,800)开始绘制文字
            ctx.fillText("这是文字内容", 92, 800);
            /*上面是增加文字,可以无限加*/
             
             
            var img2= new Image;
            img2.src = data[1];
            img2.onload = function () {//同理,如果是加载图片的话,需要等图片加载出来再下一步,所以要加onload
                ctx.drawImage(img2, 245, 660, 150, 150);(绘制图片资源,x坐标,y坐标,宽,高)
                    base64.push(c.toDataURL("image/jpeg", 1));//如果绘制完成了,就把base64数据填进数组,然后回调,没完成则继续这步
                fn();//回调
            };
        };
    }
 ///如果是坐标相同,或者觉得代码这样不美观的,可以使用递归方法实现onload的步骤,例如:
 
    function draw(fn) {
             
         a(0);
          
         fn();
    }
  
 function a(i){ 
       if (i == 0) {
         var img1= new Image;
        img1.src = data[0];
        img1.onload = function () {
            var c = document.createElement('canvas'),
            ctx = c.getContext('2d');
                        c.width = img1.naturalWidth;
                        c.height = img1.naturalHeight;
                        ctx.rect(0, 0, c.width, c.height);
                        ctx.fillStyle = '#fff';
                        ctx.fill();
            //生成一张图片1的底图
                         
            /*下面是为底图增加上文字*/
            ctx.drawImage(img1, 0, 0, c.width, c.height);(绘制图片资源,x坐标,y坐标,宽,高)
            //设置字体样式
            ctx.font = "24px Courier New";
            //设置字体填充颜色
            ctx.fillStyle = "write";
            //从坐标点(92,800)开始绘制文字
            ctx.fillText("这是文字内容", 92, 800);
            /*上面是增加文字,可以无限加*/
            a(1);//到第2个步骤
        }
        } else if (i == 1) {
           var img2= new Image;
            img2.src = data[1];
            img2.onload = function () {//同理,如果是加载图片的话,需要等图片加载出来再下一步,所以要加onload
                ctx.drawImage(img2, 245, 660, 150, 150);(绘制图片资源,x坐标,y坐标,宽,高)
                    base64.push(c.toDataURL("image/jpeg", 1));//如果绘制完成了,就把base64数据填进数组,然后回调,没完成则a(2)到第三步;
                return;
            };
        } 
   }
Zweitens: Verwenden Sie html2canvas, um Webseiten in Bildern zu speichern //HTML2canvas.js muss eingeführt werden

<div>
    <img  alt="js und Canvas synthetisieren Bilder, um Poster für öffentliche WeChat-Konten zu erstellen" >
    <img  alt="js und Canvas synthetisieren Bilder, um Poster für öffentliche WeChat-Konten zu erstellen" >
    <span><img  alt="js und Canvas synthetisieren Bilder, um Poster für öffentliche WeChat-Konten zu erstellen" >文字</span>
    <div></div>
</div>
//使用css进行网页布局
$(window).load(function(){
    var shareContent = $(".qrbg")[0]; 
    var width = shareContent.offsetWidth; 
    var height = shareContent.offsetHeight;
    $(".qrcodepic").height(height);
    var canvas = document.createElement("canvas"); 
    var scale = 2; 
    canvas.width = width * scale; 
    canvas.height = height * scale; 
    canvas.getContext("2d").scale(scale, scale); 
    var rect = shareContent.getBoundingClientRect();
    canvas.getContext("2d").translate(-rect.left,-rect.top);
    var opts = {
        scale: scale, 
        canvas: canvas, 
        width: width, 
        height: height,
        useCORS:true
    };
    html2canvas($(".qrcodepic"), opts).then(function (canvas) {
        dataURL =canvas.toDataURL("image/png");
        $(".qrcodemain").html("<img  alt="js und Canvas synthetisieren Bilder, um Poster für öffentliche WeChat-Konten zu erstellen" >");
    });
});

js und Canvas synthetisieren Bilder, um Poster für öffentliche WeChat-Konten zu erstellen

js und Canvas synthetisieren Bilder, um Poster für öffentliche WeChat-Konten zu erstellen

Ich glaube, dass Sie die Methode beherrschen, nachdem Sie den Fall in diesem Artikel gelesen haben. Weitere spannende Informationen finden Sie in anderen verwandten Artikeln auf der chinesischen PHP-Website!

Empfohlene Lektüre:

So verwenden Sie JQ, um Webseiten mit der rechten Maustaste zu markieren

Die API, die jQuery benötigt Master

So implementieren Sie den Datei-Upload mit Fortschrittsbalkenanimation

JQuery implementiert die Formularüberprüfung nach der mehrschichtigen Überprüfung

Das obige ist der detaillierte Inhalt vonjs und Canvas synthetisieren Bilder, um Poster für öffentliche WeChat-Konten zu erstellen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn