Home > Web Front-end > JS Tutorial > Simple implementation of cropping images and storing them using Javascript

Simple implementation of cropping images and storing them using Javascript

不言
Release: 2018-05-07 09:46:05
Original
1898 people have browsed it

This article mainly introduces the simple implementation of using Javascript to crop pictures and store them. It has a certain reference value. Now I share it with you. Friends in need can refer to it.

Crop pictures for us I am very familiar with it. I have encountered this need again at work recently, so I thought I would simply sort it out. The method can be referenced by everyone and myself when needed. Therefore, this article mainly introduces the simple method of cropping pictures and storing them using Javascript. For implementation, I use the THINKPHP framework for back-end PHP processing. Friends in need can refer to it.

Preface

As far as I am concerned, there are not many parts of the page that are more flexible in design, such as sliding verification codes and image cropping. Waiting for better interaction design.

When I first started working, I wanted to understand these things, but I never had the need. I took advantage of my free time today and studied it all afternoon. During this period, I encountered problems of all sizes, and I have been preparing for them. Being tortured actually reflects a problem. My

is still relatively weak.

Achievement effect:

After the user clicks to upload the image, the page displays the uploaded image, and a cropping box and two preview areas appear. Finally, click the crop button to save the cropped image to the server.

The effect is very simple. There are two difficulties I encountered in the whole process. The first is the JS effect of cropping, and the second is the processing of image data.

For the first question, I quoted a plug-in on the Internet. As far as I feel, the user satisfaction in the cropping process can only be considered average, because it can only crop square areas. , even though there are eight pull settings on the border, the frame still scales according to the square when pulling the frame, which is not very satisfactory to me.

The implementation method is as follows:

The following is a simple page design:

<p style="float:left;"><img id="target"></p>
<p style="width:48px;height:48px;margin:10px;overflow:hidden; float:left;"><img style="float:left;" id="preview" ></p>
<p style="width:190px;height:195px;margin:10px;overflow:hidden; float:left;"><img style="float:left;" id="preview2" ></p>
<form action="{:U(&#39;/test/crop_deal&#39;)}" method="post" onsubmit="return checkCoords()" enctype="multipart/form-data" id="form">
<input type="file" name="file" onchange="change_image(this)">
<input type="hidden" id="x" name="x" />
<input type="hidden" id="y" name="y" />
<input type="hidden" id="w" name="w" />
<input type="hidden" id="h" name="h" />
<input type="submit" value="裁剪"/>
</form>
Copy after login

The following is the JS code:

function change_image(file){
var reader = new FileReader();
reader.onload = function(evt){
$("#target").attr(&#39;src&#39;,evt.target.result);
$(&#39;#preview&#39;).attr(&#39;src&#39;,evt.target.result);
$(&#39;#preview2&#39;).attr(&#39;src&#39;,evt.target.result);
// $(&#39;#target&#39;).css({"height":"600px","width":"600px"});
// 限制了大小会影响到截图的效果
};
reader.readAsDataURL(file.files[0]);

var jcrop_api, boundx, boundy;

setTimeout(function(){


$(&#39;#target&#39;).Jcrop({
minSize: [48,48],
setSelect: [0,0,190,190],
onChange: updatePreview,
onSelect: updatePreview,
onSelect: updateCoords,
aspectRatio: 1
},
function(){
// Use the API to get the real image size
var bounds = this.getBounds();
boundx = bounds[0];
boundy = bounds[1];
// Store the API in the jcrop_api variable
jcrop_api = this;
});

function updatePreview(c){
if (parseInt(c.w) > 0)
{
var rx = 48 / c.w; //小头像预览p的大小
var ry = 48 / c.h;

$(&#39;#preview&#39;).css({
width: Math.round(rx * boundx) + &#39;px&#39;,
height: Math.round(ry * boundy) + &#39;px&#39;,
marginLeft: &#39;-&#39; + Math.round(rx * c.x) + &#39;px&#39;,
marginTop: &#39;-&#39; + Math.round(ry * c.y) + &#39;px&#39;
});
}
{
var rx = 199 / c.w; //大头像预览p的大小
var ry = 199 / c.h;
$(&#39;#preview2&#39;).css({
width: Math.round(rx * boundx) + &#39;px&#39;,
height: Math.round(ry * boundy) + &#39;px&#39;,
marginLeft: &#39;-&#39; + Math.round(rx * c.x) + &#39;px&#39;,
marginTop: &#39;-&#39; + Math.round(ry * c.y) + &#39;px&#39;
});
}
};


function updateCoords(c)
{
$(&#39;#x&#39;).val(c.x);
$(&#39;#y&#39;).val(c.y);
$(&#39;#w&#39;).val(c.w);
$(&#39;#h&#39;).val(c.h);
};

},500);

}
Copy after login

Here are a few thoughts Click to remind:

First: Don’t forget to introduce the plug-in at the head of the page:

  <script src="/plug/js/jquery.min.js" type="text/javascript"></script>
  <script src="/plug/js/jquery.Jcrop.min.js" type="text/javascript"></script>
  <link rel="stylesheet" href="/plug/css/Jcrop.css" rel="external nofollow" type="text/css" />
Copy after login

Second: Some If you have a sharp eye, you may have noticed that there is a timing in JS, and at the same time, you are confused. Isn't this a bit unnecessary? Actually no, it takes time to upload the image to JS and load it on the page. The meaning of this timing is to wait until the image is loaded on the page by JS before loading the cropping effect. This is also obtained after repeated experiments. way of doing.

I use the THINKPHP framework for back-end PHP processing, the version is 3.1.3

Paste the code:

function crop_deal(){
  ob_clean();
  import ( &#39;ORG.Net.UploadFile&#39; );
  $upload = new UploadFile ();
  $upload->maxSize = 2000000;
  $upload->allowExts = array (
    &#39;jpg&#39;,
    &#39;gif&#39;,
    &#39;png&#39;,
    &#39;jpeg&#39;
  );
  $upload->savePath = &#39;./upload/test/&#39;;
  $upload->autoSub = true;
  $upload->subType = &#39;date&#39;;
  $upload->dateFormat = &#39;Ymd&#39;;
  if ($upload->upload () ) {
    $info = $upload->getUploadFileInfo();
    $new_path = "./upload/test/thumb".date(&#39;Ymd&#39;);
    $file_store = $new_path."/".date(&#39;YmdHis&#39;).".jpg";
    if(!file_exists($new_path)){
      mkdir($new_path,0777,true);
    }
    $source_path = "http://".$_SERVER[&#39;HTTP_HOST&#39;]."/upload/test/".$info[0][&#39;savename&#39;];
    $img_size = getimagesize($source_path);
    $width = $img_size[0];
    $height = $img_size[1];  
    $mime = $img_size[&#39;mime&#39;];
    $srcImg = imagecreatefromstring(file_get_contents($source_path));
    $cropped_img = imagecreatetruecolor($_POST[&#39;w&#39;], $_POST[&#39;h&#39;]);
    //缩放
    // imagecopyresampled($cropped_img,$srcImg,0,0,$_POST[&#39;x&#39;],$_POST[&#39;y&#39;],$_POST[&#39;w&#39;],$_POST[&#39;h&#39;],$width,$height);
    //裁剪
    imagecopy($cropped_img,$srcImg,0,0,$_POST[&#39;x&#39;],$_POST[&#39;y&#39;],$_POST[&#39;w&#39;],$_POST[&#39;h&#39;]);
    header("Content-Type:image/jpeg");
    imagejpeg($cropped_img,$file_store);
    imagedestroy($srcImg);
    imagedestroy($cropped_img);
  }

}
Copy after login

Here are a series of methods to call the GD library to create images. The most important thing is

imagecopy()

, which copies the original image to the new one according to the specified cropping position and cropping size. The picture goes up, which also illustrates one thing. When the page user cuts the picture , the front end does not actually operate on the picture. Instead, it obtains the coordinate position when cropping, the cropping size, and then submits it to PHP for operation! !

Related recommendations:


How to use JavaScript to randomly generate a certain number of passwords

How to use JavaScript's % to do interlacing Color change


The above is the detailed content of Simple implementation of cropping images and storing them using Javascript. For more information, please follow other related articles on the PHP Chinese website!

Related labels:
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template