欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

利用Javascript裁剪圖片并存儲的簡單實現(xiàn)

 更新時間:2017年03月13日 11:18:21   作者:_construct  
裁剪圖片對我們來說是再熟悉不過的了,最近工作中就又遇到了這個需求,所以想著干脆整理下來,方法大家和自己在需要的時候參考學習,所以這篇文章主要介紹了利用Javascript裁剪圖片并存儲的簡單實現(xiàn),后端PHP處理我用的是THINKPHP框架,需要的朋友可以參考下。

前言

就我而言,頁面上的設計比較靈動的部分,其實不是很多,諸如滑動驗證碼,圖片裁剪等比較好的交互設計。

從剛開始工作的時候,我就想把這些東西了解下,無奈一直沒這個需求,乘著今天的空閑,研究了一下午,期間遇到了大大小小的問題,一直備受折磨,這其實也反映一個問題,我的

還是比較薄弱。

實現(xiàn)效果:

用戶點擊上傳圖片后,頁面顯示所上傳的圖片,并且出現(xiàn)裁剪框和兩個預覽區(qū)域,最后點擊裁剪按鈕保存裁剪的圖片到服務器上。 

效果很簡單,整個過程我遇到的兩個難點,第一個是裁剪的JS效果,第二個則是圖片數(shù)據(jù)的處理。 

對于第一個問題,我引用了網(wǎng)上的一個插件,就我感覺來說,裁剪過程用戶的滿意度只能算一般,因為它只能裁剪正方形區(qū)域,就算邊框上有八個拉動設置,但是拉動框時還是按正方形縮放,就這點不太讓我滿意。

實現(xiàn)方法如下: 

以下是簡單的頁面設計:

<div style="float:left;"><img id="target"></div>
<div style="width:48px;height:48px;margin:10px;overflow:hidden; float:left;"><img style="float:left;" id="preview" ></div>
<div style="width:190px;height:195px;margin:10px;overflow:hidden; float:left;"><img style="float:left;" id="preview2" ></div>
<form action="{:U('/test/crop_deal')}" 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>

下面是JS代碼:

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

var jcrop_api, boundx, boundy;

setTimeout(function(){


$('#target').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; //小頭像預覽Div的大小
var ry = 48 / c.h;

$('#preview').css({
width: Math.round(rx * boundx) + 'px',
height: Math.round(ry * boundy) + 'px',
marginLeft: '-' + Math.round(rx * c.x) + 'px',
marginTop: '-' + Math.round(ry * c.y) + 'px'
});
}
{
var rx = 199 / c.w; //大頭像預覽Div的大小
var ry = 199 / c.h;
$('#preview2').css({
width: Math.round(rx * boundx) + 'px',
height: Math.round(ry * boundy) + 'px',
marginLeft: '-' + Math.round(rx * c.x) + 'px',
marginTop: '-' + Math.round(ry * c.y) + 'px'
});
}
};


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

},500);

}

這里稍作兩點提醒:

其一:不要忘記在頁面頭部引入插件:

  <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" />

其二:有些人眼尖的話可能看到了JS里有個定時,同時心理是不是很疑惑這不是有點多此一舉嗎?其實不是,上傳圖片到JS加載到頁面上,是需要時間的,這個定時的意義在于

等到圖片被JS加載到頁面上時才去加載裁剪效果,這里也是反復實驗后得出的做法。 

后端PHP處理我用的是THINKPHP框架,版本是3.1.3

貼上代碼:

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

}

這里就是調用GD庫里創(chuàng)建圖像的一系列方法,最重要就是imagecopy() ,它是將原圖按規(guī)定的裁剪位置,裁剪大小復制到新的圖片上去,這也說明了一件事,頁面用戶在裁剪圖片

的時候其實前端并沒有對圖片操作,而是得到裁剪時的坐標位置,裁剪大小,然后提交到PHP操作??!

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者使用Swift能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

相關文章

  • Django1.7+JQuery+Ajax驗證用戶注冊集成小例子

    Django1.7+JQuery+Ajax驗證用戶注冊集成小例子

    下面是散仙使用Django+Jquery+Ajax的方式來模擬實現(xiàn)了一個驗證用戶注冊時,用戶名存在不存在的一個小應用。注意,驗證存在不存在使用的是Ajax的方式,不用讓用戶點擊按鈕驗證是否存在,需要的朋友可以參考下
    2017-04-04
  • JavaScript設計模式之外觀模式實例

    JavaScript設計模式之外觀模式實例

    這篇文章主要介紹了JavaScript設計模式之外觀模式實例,本文用一些代碼實例來講解JavaScript中的外觀模式,需要的朋友可以參考下
    2014-10-10
  • 基于JavaScript Array數(shù)組方法(新手必看篇)

    基于JavaScript Array數(shù)組方法(新手必看篇)

    下面小編就為大家?guī)硪黄贘avaScript Array數(shù)組方法(新手必看篇)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-08-08
  • javascript實現(xiàn)簡易計算器

    javascript實現(xiàn)簡易計算器

    這篇文章主要為大家詳細介紹了javascript實現(xiàn)簡易計算器,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-02-02
  • 一篇文章掌握RequireJS常用知識

    一篇文章掌握RequireJS常用知識

    一篇文章掌握RequireJS常用知識,通過本文,你可以對模塊化開發(fā)和AMD規(guī)范有一個較直觀的認識,并詳細地學習RequireJS這個模塊化開發(fā)工具的常見用法,感興趣的小伙伴們可以參考一下
    2016-01-01
  • 微信小程序實現(xiàn)點擊按鈕修改view標簽背景顏色功能示例【附demo源碼下載】

    微信小程序實現(xiàn)點擊按鈕修改view標簽背景顏色功能示例【附demo源碼下載】

    這篇文章主要介紹了微信小程序實現(xiàn)點擊按鈕修改view標簽背景顏色功能,涉及微信小程序事件響應及數(shù)值運算實現(xiàn)動態(tài)設置view背景色樣式的相關操作技巧,需要的朋友可以參考下
    2017-12-12
  • 微信小程序地圖定位的實現(xiàn)方法實例

    微信小程序地圖定位的實現(xiàn)方法實例

    小程序功能的強大想必使用過的人都知道,下面這篇文章主要給大家介紹了關于微信小程序地圖定位的實現(xiàn)方法,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-04-04
  • JS分頁控件 可用于無刷新分頁

    JS分頁控件 可用于無刷新分頁

    今天無意看到了這個分頁控件,不過使用方法不是很清楚沒有研究,。大家可以自行研究,里面的函數(shù)寫法倒是不錯,需要內容的結合
    2013-07-07
  • javascript實現(xiàn)上傳圖片并預覽的效果實現(xiàn)代碼

    javascript實現(xiàn)上傳圖片并預覽的效果實現(xiàn)代碼

    圖片上傳預覽,就是在使用文件選擇框選擇了文件之后就可以在頁面上看見圖片的效果,關于這個效果我一直認為是無法做到的
    2011-04-04
  • 使用微信小程序開發(fā)彈出框應用實例詳解

    使用微信小程序開發(fā)彈出框應用實例詳解

    本文通過實例代碼給大家介紹了使用微信小程序開發(fā)彈出框功能,代碼簡單易懂,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-10-10

最新評論