Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/javascript/387.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript 是否可以通过画布将两张响应性强的照片合并?_Javascript_Html_Responsive Design_Html5 Canvas_Responsive Images - Fatal编程技术网

Javascript 是否可以通过画布将两张响应性强的照片合并?

Javascript 是否可以通过画布将两张响应性强的照片合并?,javascript,html,responsive-design,html5-canvas,responsive-images,Javascript,Html,Responsive Design,Html5 Canvas,Responsive Images,我在网上到处都找遍了。。我正在编写一些代码,试图合并来自不同URL的两个图像,以获得良好的演示。其中一张图片来自Flickr 是否可以通过html5画布将两张照片合并为一个元素,同时保持其响应性 画布大小参数示例: 不带画布大小参数的示例: 我尝试删除canvas元素上的大小参数,并保持CSS代码不变,但由于某些原因,它没有以“流体”的方式绘制画布 像这个例子: 这是我的密码: function loadImages(sources, callback) { var ima

我在网上到处都找遍了。。我正在编写一些代码,试图合并来自不同URL的两个图像,以获得良好的演示。其中一张图片来自Flickr

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

画布大小参数示例:

不带画布大小参数的示例:

我尝试删除canvas元素上的大小参数,并保持CSS代码不变,但由于某些原因,它没有以“流体”的方式绘制画布

像这个例子:

这是我的密码:

    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);

  });

“合并”是什么意思?如果您试图将照片剪辑到椭圆形,可以使用
ctx.globalCompositeOperation='lighter'。我试图做的是合并var源中的图像,并像下面的示例那样:<在画布上没有大小参数,但它能够适应窗口大小,我希望在同一画布中使用两个图像源。此示例:受到限制,因为该方法设置为1000x1000画布大小。如果我删除画布上的大小参数,并尝试应用CSS使画布响应/流动,它不会像这样正常工作:如果不使用HTML设置画布大小,则需要使用JavaScript进行设置。您可以指定硬编码的维度,也可以等待
images[src].onload
函数根据已加载的图像执行和使用维度。谢谢!我到家后会试试的。