首页 > 解决方案 > 是否可以通过画布合并两张响应式照片?

问题描述

我已经在网上搜索了很多.. 我正在编写一些代码,我试图合并来自不同 URL 的两个图像以获得良好的演示。其中一张图片来自 Flickr。

是否可以通过 html5 画布将两张照片合并为一个元素,同时保持响应?

画布大小参数示例: https ://jsfiddle.net/esd3f4kt/

没有画布大小参数的示例: https ://jsfiddle.net/n3x7wozc/

我已经尝试删除画布元素上的大小参数并保持 CSS 代码不变,但由于某种原因,它不会以“流畅”的方式绘制画布。

像这个例子:

https://codepen.io/html5andblog/pen/yOdBaw

这是我的代码:

    function loadImages(sources, callback) {
    var images = {};
    var loadedImages = 0;
    var numImages = 0;
    // get num of sources
    for(var src in sources) {
      numImages++;
    }
    for(var src in sources) {
      images[src] = new Image();
      images[src].onload = function() {
        if(++loadedImages >= numImages) {
          callback(images);
        }
      };
      images[src].src = sources[src];
    }
  }
  var canvas = document.getElementById('myCanvas');
  var ctx = canvas.getContext('2d');

  var sources = {
    image2: 'http://farm5.static.flickr.com/4621/39922707792_c4eab8924c_b.jpg',
    image1: ''
  };



  loadImages(sources, function(images) {
    ctx.drawImage(images.image1, 25, 5, 785, 589);
            ctx.drawImage(images.image2, 350, 150, 457/2.25, 645/2.25);

  });

标签: javascripthtmlresponsive-designhtml5-canvasresponsive-images

解决方案


推荐阅读