Jquery裁剪:裁剪图像不变

时间:2016-02-24 23:12:50

标签: javascript jquery crop cropper

我有以下代码:

<link rel="stylesheet" href="style.css">
<script src="/static/js/jquery/2.1.4/jquery.min.js"></script>
<script src="http://fengyuanchen.github.io/cropper/js/cropper.min.js"></script>
<form  action="" method="post" enctype="multipart/form-data">
<img id="crop" style="width:400px;height:200px;" />
<div id="img2" style="position: relative; overflow: hidden; border: 1px solid #000; background: #fff; width: 100px; height: 100px;"></div>
X: <input type="text" id="crop_x" name="crop_x" /><br />
Y: <input type="text" id="crop_y" name="crop_y" /><br />
Width: <input type="text" id="crop_width" name="crop_width" /><br />
Height: <input type="text" id="crop_height" name="crop_height" /><br />
<input type="file" id="file" name="file" />
<input type="submit" id="submit" name="submit" value="Submit" />
</form>
<script>

var url = null;
$('#file').on('change',function(){

    var file = this.files[0];

    if(url != null){

        URL.revokeObjectURL(url);

    }

    url = URL.createObjectURL(file);


    startCropper();

});


function startCropper(){

    $('#crop').removeAttr('src');

    $('#crop').attr('src',url);

    $('#crop').cropper({

    viewMode            : 0,

    cropBoxResizable    : false,

    minCropBoxWidth     : 100,

    minCropBoxHeight    : 100,

    dragMode            : 'none',

    preview             : $('#img2'),

    aspectRatio: 1,

    crop : function(e){

        $('#crop_x').val(e.x);

        $('#crop_y').val(e.y);

    }

 });
};
</script>

问题在于,当我选择文件时,不显示新图像(旧图像仍显示在裁剪器中)。

如您所见,我检查旧网址并撤销此信息。当我在startCropper()函数中不使用$(“#crop”)。cropper({...})时,它可以工作。

GitHub:https://github.com/fengyuanchen/cropper/tree/v2.3.0

如何强制裁剪器加载新​​图像?

3 个答案:

答案 0 :(得分:2)

您需要致电

$('#crop').cropper('destroy');
裁剪初始化之前

答案 1 :(得分:0)

此代码将解决Cropper中Image未更改的问题。

<强> HTML

<input id="userImage" type="file" name="userImage" accept="image/*">

<div>
   <canvas id="canvas" style="display: none;">
      Your browser does not support the HTML5 canvas element.
   </canvas>
</div>
<div id="imagePreview" style="position: relative; overflow: hidden; border: 1px solid #000; background: #fff; width: 100px; height: 100px;"></div>

<强> CSS

img {max-width: 100%;} /* This rule is very important, please do not ignore this! */

#canvas {
  height: auto;
  width: 250px; /*Change this value according to your need*/
  background-color: #ffffff;
  cursor: default;
  border: 1px solid #000;
}

<强> JS

var canvas  = $("#canvas");
context = canvas.get(0).getContext("2d");

$('#userImage').on( 'change', function(){
if (this.files && this.files[0]) {
   if ( this.files[0].type.match(/^image\//) ) {
      var reader = new FileReader();
      reader.onload = function(evt) {
      var img = new Image();
      img.onload = function() {
         context.canvas.height = img.height;
         context.canvas.width  = img.width;
         context.drawImage(img, 0, 0);

         // Destroy the old cropper instance
         canvas.cropper('destroy');

         // Replace url
         canvas.attr('src', this.result);

         var cropper = canvas.cropper({
            //these options can be changed or modified according to need
            viewMode: 0,
            cropBoxResizable: false,
            minCropBoxWidth: 100,
            minCropBoxHeight: 100,
            dragMode: 'none',
            preview: $('#imagePreview'),
            aspectRatio: 1,
            crop : function(e){
               $('#crop_x').val(e.x);
               $('#crop_y').val(e.y);
            }
         });
       };
       img.src = evt.target.result;
    };
    reader.readAsDataURL(this.files[0]);
  } else {
    alert("Invalid file type! Please select an image file.");
  }
} else {
  alert('No file(s) selected.');
}
});

有关详细信息和更好理解,请访问

Cropper Official Documentation

答案 2 :(得分:0)

对于裁剪器JS 1.3.3,在绘制画布后,它是cropper.destroy();而不是canvas.cropper('destroy')。  `