中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久

JCrop+ajaxUpload 圖像切割上傳的實例代碼
來源:易賢網 閱讀:1706 次 日期:2016-07-29 16:53:07
溫馨提示:易賢網小編為您整理了“JCrop+ajaxUpload 圖像切割上傳的實例代碼”,方便廣大網友查閱!

這篇文章主要介紹了JCrop+ajaxUpload 圖像切割上傳的實例代碼的相關資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下

頁面代碼

里面用戶的uuid是寫死的test

<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>

<!DOCTYPE>

<html lang="en">

<head>

<title>用戶頭像剪裁</title>

<meta http-equiv="Content-type" content="text/html;charset=UTF-8" />

<link rel="stylesheet" href="resources/Jcrop/css/jquery.Jcrop.css">

<link rel="stylesheet" href="resources/css/photo.css">

<script src="resources/js/jquery.min.js"></script>

<script src="resources/Jcrop/js/jquery.Jcrop.js"></script>

<script src="resources/js/ajaxfileupload.js"></script>

</head>

<body>

<div class="container">

<div class="row">

<div class="span12">

<div class="jc-demo-box">

<div class="page-header">

<h1>頭像剪裁</h1>

</div>

<img src="resources/img/test.jpg" id="target" />

<div id="preview-pane" >

<div class="preview-container">

<img src="resources/img/test.jpg" class="jcrop-preview"/>

</div >

<div style='float:left;display:inline;'>

<a class='btn_addPic' href="javascript:void(0);">

<span><EM>+</EM>添加圖片</span> 

<input id="upload_image" type="file" name="upimage" accept="image/*" class = "filePrew"/>

</a>

</div>

<div style='float:right;display:inline;'>

<a class='btn_addPic' href="javascript:void(0);" onclick='submit()'>

<span>提交</span> 

</a>

</div>

</div>

</div>

</div>

</div>

</div>

</body>

<script type="text/javascript">

var global_api = "";

var boundx ="";//頁面圖片寬度

var boundy ="";//頁面圖片高度

var tag = false;

$(function() {

// Create variables (in this scope) to hold the API and image size

//創建變量(在這個范圍)的API和圖像大小

var jcrop_api,

// Grab some information about the preview pane

//獲取一些信息預覽窗格

$preview = $('#preview-pane'),

$pcnt = $('#preview-pane .preview-container'),

$pimg = $('#preview-pane .preview-container img'),

xsize = $pcnt.width(),

ysize = $pcnt.height();

$('#target').Jcrop({

onChange: updatePreview,

onSelect: updatePreview,

aspectRatio: xsize / ysize

},function(){

// Use the API to get the real image size

//使用API來獲得真實的圖像大小

var bounds = this.getBounds();

boundx = bounds[0];

boundy = bounds[1];

// Store the API in the jcrop_api variable

//jcrop_api變量中存儲API

jcrop_api = this;

// Move the preview into the jcrop container for css positioning

//預覽進入jcrop容器css定位

$preview.appendTo(jcrop_api.ui.holder);

});

function updatePreview(c)

{

if (parseInt(c.w) > 0)

global_api=c;

{

var rx = xsize / c.w;

var ry = ysize / c.h;

$pimg.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'

});

}

};

//=======選擇圖片回顯===============

$('#upload_image').change(function(event) {

// 根據這個 <input> 獲取文件的 HTML5 js 對象

var files = event.target.files, file; 

if (files && files.length > 0) {

// 獲取目前上傳的文件

file = files[0];

// 下面是關鍵的關鍵,通過這個 file 對象生成一個可用的圖像 URL

// 獲取 window 的 URL 工具

var URL = window.URL || window.webkitURL;

// 通過 file 生成目標 url

var imgURL = URL.createObjectURL(file);

// 用這個 URL 產生一個 <img> 將其顯示出來

$('.jcrop-holder img').attr('src', imgURL);

$('.preview-container img').attr('src', imgURL);

}

});

//=============是否選擇了本地圖片==================

$("#upload_image").change(function(){

tag=true;

});

});

//========================================================

//======圖片保存===========

function submit(){

if(tag&&global_api != ""){

ajaxFileUpload();

}else{

alert('你是不是什么事情都沒干?');

}

}

//ajax文件上傳

function ajaxFileUpload() {

$.ajaxFileUpload({

url: 'uploadphoto', //用于文件上傳的服務器端請求地址

secureuri: false, //一般設置為false

fileElementId: 'upload_image', //文件上傳空間的id屬性

dataType: 'json', //返回值類型 一般設置為json

data:{x:global_api.x,y:global_api.y,w:global_api.w,h:global_api.h,pw:boundx,ph:boundy,unid:'test'}, //一同上傳的數據 

success: function (data){ //服務器成功響應處理函數

if(data.result){

alert('成功');

}else{

alert('失敗');

}

window.location.reload();//刷新當前頁面

}

}

);

}

</script>

</html>

后臺代碼

@ResponseBody

@RequestMapping("uploadphoto")

public Map<String, Object> uploadPhoto(@RequestParam("upimage") MultipartFile imageFile, HttpServletRequest request,

HttpServletResponse response) throws Exception {

Map<String, Object> result = new HashMap<String, Object>();

boolean tag =false;

String unid = request.getParameter("unid");

String x = request.getParameter("x");

String y = request.getParameter("y");

String h = request.getParameter("h");

String w = request.getParameter("w");

// 頁面實際圖片寬高

String pheight = request.getParameter("ph");

String pweight = request.getParameter("pw");

// 切圖參數

int imageX = Integer.parseInt(x);

int imageY = Integer.parseInt(y);

int imageH = Integer.parseInt(h);

int imageW = Integer.parseInt(w);

int srcH = Integer.parseInt(pheight);

int srcW = Integer.parseInt(pweight);

String realPath = request.getSession().getServletContext().getRealPath("/");

String resourcePath = "resources/uploadImages/";

try {

if (imageFile != null) {

if (FileUploadUtil.allowUpload(imageFile.getContentType())) {

// 這里開始截取操作

byte[] b = ImageCut.imgCut(imageFile.getInputStream(), imageX, imageY, imageW, imageH, srcW, srcH);

if (b != null) {

// 存入數據庫

User user = userService.selectByPrimaryKey(unid);

user.setPhoto(b);

tag = (userService.updateByPrimaryKeySelective(user)==1)?tag=true:tag;

result.put("result", tag);

}

}

}

} catch (Exception e) {

e.printStackTrace();

}

result.put("result", tag);

return result;

}

圖像切割工具類

package com.ssm.demo.utils;

import java.awt.Graphics;

import java.awt.Image;

import java.awt.Toolkit;

import java.awt.image.BufferedImage;

import java.awt.image.CropImageFilter;

import java.awt.image.FilteredImageSource;

import java.awt.image.ImageFilter;

import java.io.ByteArrayOutputStream;

import java.io.InputStream;

import javax.imageio.ImageIO;

public class ImageCut {

/**

* 截取圖片

* @param srcImageFile

* 原圖片地址

* @param x

* 截取時的x坐標

* @param y

* 截取時的y坐標

* @param desWidth

* 截取的寬度

* @param desHeight

* 截取的高度

* @param srcWidth

* 頁面圖片的寬度

* @param srcHeight

* 頁面圖片的高度

*/

public static byte[] imgCut(InputStream input, int x, int y, int desWidth, int desHeight, int srcWidth,

int srcHeight) {

try {

Image img;

ImageFilter cropFilter;

BufferedImage bi = ImageIO.read(input);

if (srcWidth >= desWidth && srcHeight >= desHeight) {

Image image = bi.getScaledInstance(srcWidth, srcHeight, Image.SCALE_DEFAULT);

cropFilter = new CropImageFilter(x, y, desWidth, desHeight);

img = Toolkit.getDefaultToolkit().createImage(new FilteredImageSource(image.getSource(), cropFilter));

BufferedImage tag = new BufferedImage(desWidth, desHeight, BufferedImage.TYPE_INT_RGB);

Graphics g = tag.getGraphics();

g.drawImage(img, 0, 0, null);

g.dispose();

// 輸出文件

ByteArrayOutputStream out = new ByteArrayOutputStream();

ImageIO.write(tag, "JPEG", out);

return out.toByteArray();

}

} catch (Exception e) {

e.printStackTrace();

}

return null;

}

}

以上所述是小編給大家介紹的JCrop+ajaxUpload 圖像切割上傳的實例代碼,希望對大家有所幫助

更多信息請查看網絡編程
由于各方面情況的不斷調整與變化,易賢網提供的所有考試信息和咨詢回復僅供參考,敬請考生以權威部門公布的正式信息和咨詢為準!
關于我們 | 聯系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點

版權所有:易賢網

中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久
亚洲综合色成人| 亚洲欧洲日韩在线| 在线观看91av| 欧美日韩一级黄| 欧日韩精品视频| 欧美午夜精品免费| 欧美美女网站色| 欧美一区二区高清| 久久美女高清视频| 亚洲国产精品黑人久久久 | 日韩高清一区二区| 亚洲高清在线精品| 日韩电影在线一区| 麻豆成人91精品二区三区| 国产一区二区三区视频在线播放| 久久99精品国产麻豆婷婷洗澡| 久久99精品一区二区三区三区| 国产伦精品一区二区三区在线观看| 国产剧情一区在线| 色综合久久久久| 欧美日韩情趣电影| 久久免费的精品国产v∧| 国产片一区二区| 自拍偷拍国产精品| 蜜臀av性久久久久蜜臀aⅴ四虎| 激情六月婷婷久久| 99久久伊人精品| 欧美日韩国产系列| 国产女人18水真多18精品一级做| 中文字幕综合网| 裸体一区二区三区| av不卡免费在线观看| 欧美精三区欧美精三区| 久久久国产精品午夜一区ai换脸| 中文字幕一区二区三区不卡在线| 偷窥少妇高潮呻吟av久久免费| 国产精品夜夜嗨| 欧美日韩你懂的| 国产欧美一区二区精品仙草咪| 一区二区三区日本| 国产精品乡下勾搭老头1| 色综合久久综合中文综合网| 精品乱码亚洲一区二区不卡| 亚洲精选视频在线| 国产成人一级电影| 日韩一区二区三区电影在线观看 | 麻豆精品一二三| 99vv1com这只有精品| 91精品在线免费| 日韩毛片在线免费观看| 国产一区二区在线观看免费 | 久久99久久精品| 欧美视频一区二区三区| 国产精品第一页第二页第三页| 男男成人高潮片免费网站| 91啦中文在线观看| 26uuuu精品一区二区| 日韩电影网1区2区| 欧美日韩专区在线| 亚洲激情网站免费观看| 成人黄色777网| 国产亚洲一区二区三区四区| 日韩av在线播放中文字幕| 91久久奴性调教| 国产精品蜜臀在线观看| 国产精品一区二区在线观看不卡 | 欧美另类一区二区三区| 一区二区三区在线视频免费观看| 成人性生交大片免费看中文网站| www亚洲一区| 男女男精品网站| 欧美一二三四区在线| 亚洲mv在线观看| 91精品国产综合久久蜜臀| 日韩精品三区四区| 欧美一级精品在线| 蜜桃视频一区二区三区| 精品日韩一区二区三区免费视频| 日韩高清在线不卡| 欧美电影免费观看高清完整版| 日产国产高清一区二区三区| 宅男在线国产精品| 九九视频精品免费| 欧美极品xxx| 色综合久久天天综合网| 一区二区三区四区视频精品免费| 99麻豆久久久国产精品免费优播| 亚洲视频在线一区观看| 色综合视频在线观看| 亚洲电影视频在线| 欧美一级高清片在线观看| 黄色精品一二区| 国产精品嫩草久久久久| 欧美性生活大片视频| 日韩二区三区在线观看| 久久美女高清视频| 色婷婷av一区二区三区gif| 午夜私人影院久久久久| 久久先锋资源网| 一本久久精品一区二区| 男男gaygay亚洲| 国产精品久久午夜| 91精品欧美福利在线观看| 国模娜娜一区二区三区| 中文字幕一区二区日韩精品绯色| 欧美日韩一区二区三区在线 | 成人免费看片app下载| 一个色综合av| 久久久亚洲精品石原莉奈| 91麻豆免费观看| 免费高清在线一区| 亚洲人成精品久久久久久| 91精品国产91久久久久久最新毛片| 国产精品一级黄| 午夜久久久影院| 亚洲国产高清在线| 制服丝袜在线91| 91免费小视频| 韩国在线一区二区| 亚洲影院理伦片| 国产精品美女久久久久久久久久久 | 91国偷自产一区二区开放时间 | 国产一区激情在线| 亚洲一二三区视频在线观看| 久久久影视传媒| 欧美高清视频在线高清观看mv色露露十八| 国产一区二区三区香蕉| 亚洲444eee在线观看| 亚洲图片激情小说| 亚洲精品一区二区精华| 欧美女孩性生活视频| 99久久婷婷国产| 成人丝袜高跟foot| 黄页网站大全一区二区| 日本aⅴ精品一区二区三区 | 成人精品视频一区二区三区| 久久精品99国产精品| 舔着乳尖日韩一区| 一区二区在线电影| 亚洲欧美二区三区| 亚洲少妇最新在线视频| 国产校园另类小说区| 欧美成人aa大片| 日韩免费在线观看| 欧美成人福利视频| 日韩亚洲欧美中文三级| 7777精品伊人久久久大香线蕉| 在线视频一区二区三| 91久久香蕉国产日韩欧美9色| 9久草视频在线视频精品| 成人一区二区三区视频| 国产不卡免费视频| 高清日韩电视剧大全免费| 国产一区二区91| 国产成人综合自拍| 国产成人午夜99999| 国产一二精品视频| 风间由美中文字幕在线看视频国产欧美| 免费在线观看一区二区三区| 日韩国产欧美在线视频| 美女在线观看视频一区二区| 欧美bbbbb| 极品尤物av久久免费看| 狠狠色狠狠色合久久伊人| 国产麻豆精品在线观看| 国产成人欧美日韩在线电影| 成人性视频免费网站| 色网站国产精品| 欧美日韩国产bt| 日韩午夜精品视频| 久久精品这里都是精品| 欧美国产日韩在线观看| 亚洲欧美视频一区| 日本免费新一区视频| 国产很黄免费观看久久| youjizz久久| 欧美午夜电影网| 欧美精品一区二区三区久久久| 久久久精品影视| 亚洲影院免费观看| 久久av资源站| 成人99免费视频| 欧美丰满美乳xxx高潮www| 亚洲精品一线二线三线无人区| 国产欧美一区二区精品忘忧草 | 欧美自拍偷拍午夜视频| 欧美一区二区三区小说| 日韩精品久久理论片| 九九九久久久精品| 91在线一区二区三区| 精品视频在线免费观看| 久久久电影一区二区三区| 一区二区三区 在线观看视频| 免费日韩伦理电影| 不卡在线视频中文字幕| 91精品国产一区二区三区| 国产精品理论在线观看| 婷婷中文字幕综合| 97久久人人超碰| 日韩精品中文字幕一区二区三区|