网站建设资讯

NEWS

网站建设资讯

jquery裁剪插件,怎么使用jquery插件

Jquery的Jcrop图片裁剪插件,被裁剪的图片改不了,重新给别的src显示还是原来那张图

之前专门写的一个基于Jcrop图片裁剪实现的插件文章,希望对你有帮助

创新互联专注于鲁山企业网站建设,响应式网站开发,成都做商城网站。鲁山网站建设公司,为鲁山等地区提供建站服务。全流程按需求定制网站,专业设计,全程项目跟踪,创新互联专业和态度为您提供的服务

jQuery imgareaselect裁剪

/*

缺陷,当前在ff3下,用jquery的 width()与height()函数,在不设置图片的宽度与高度的时候,不能取到

需要在图片load函数里面初始化才可以

*/

sanshi_imgareaselect = function(pic_id,view_div_id){

this.pic_obj = jQuery("#"+pic_id);

this.pic_width;

this.pic_height;

this.view_div_id = view_div_id;

this.view_width = 100;

this.view_height = 100;

this.view_img_id = view_div_id+"_sanshi_img";

this.ias;

}

//建立预览图片

sanshi_imgareaselect.prototype.make_view_pic =function(){

var img_obj = jQuery(document.createElement("IMG"));

img_obj.attr("src",this.pic_obj.attr("src"));

img_obj.attr("id",this.view_img_id);

img_obj.attr("width",this.view_width);

img_obj.attr("height",this.view_height);

return img_obj;

}

//初始化函数

sanshi_imgareaselect.prototype.init=function(){

this.pic_width = this.pic_obj.attr("width");

this.pic_height = this.pic_obj.attr("height");

//alert(this.pic_width+":"+this.pic_height);

//添加图片

jQuery("#"+this.view_div_id).append(this.make_view_pic());

//设置预览加载层样式

jQuery("#"+this.view_div_id).css({'width':this.view_width,'height':this.view_height,'overflow':'hidden'});

//构造选择区域完成的函数

var fun_str="if ( selection.width selection.height){ var scaleX = "+this.view_width+" / selection.width;var scaleY = "+this.view_height+" / selection.height;jQuery('#"+this.view_img_id+"').css({width: Math.round(scaleX * "+this.pic_width+"),height: Math.round(scaleY * "+this.pic_height+"),marginLeft: -Math.round(scaleX * selection.x1),marginTop: -Math.round(scaleY * selection.y1)});}";

//alert(fun_str);

//初始化imgAreaSelect 函数

var ias = this.pic_obj.imgAreaSelect({

//设置选择框的比列

//aspectRatio:"1:1",

//设置框的添加效果

fadeSpeed:200,

//选择框选择完毕是否自己取消

autoHide:false,

//是否显示图片遮罩层

show:true,

//是否采用api

instance: true,

//设置初始函数 画出选择框

onInit:function(img, selection){ias.setSelection(100, 50, 250, 150, true);ias.update();},

//设置选择完毕的函数,采用了动态执行

onSelectEnd:function(img, selection){eval(fun_str);}

});

//赋值给全局

this.ias = ias;

}

//保存事件 采用的是get方式提交

sanshi_imgareaselect.prototype.save_pic=function(post_page,post_param){

var opt = this.ias.getSelection(true);

var post_arr = new Array();

jQuery.each(post_param,function(i,n){

var temp_str =i+"=";

temp_str += opt[n] ? opt[n] : n;

post_arr.push(temp_str);

});

//判断,是否有参数

post_page += post_page.lastIndexOf("?")0 ? "?" : "";

//拼装get方式的url

post_url = post_page+post_arr.join("");

alert(post_url);

}

//这个是封装后js代码

$(document).ready(function () {

//声明函数

var sanshi_img = new sanshi_imgareaselect("mypic","preview");

//确保图片加载完成执行初始化函数,这样避免上面的提到的bug,否则不能保证兼容性

$("#mypic").load(function(){sanshi_img.init();});

//监听保存事件

$("#save_pic").click(function(){

sanshi_img.save_pic('1.php?n=6',{"id":5,"px1":"x1","py1":"y1",'px2':"x2","py2":"y2",'pwidth':"width",'pheight':"height"});

});

})

imageareaselect 与 jquery jcrop 哪一个好用

都是jQuery 图像裁剪插件,不能说那个好用,原理是一样的。感觉jQuery Jcrop 插件的功能强大些

jquery jcrop插件怎么截屏

div id="cutImage" style="display: none;"

div class="bigImg" style="float: left;"

img id="srcImg" src="" width="400px" height="270px"/

/div

div id="preview_box" class="previewImg"

img id="previewImg" src="" width="120px"/

/div

div

form action="" method="post" id="crop_form"

input type="hidden" id="bigImage" name="bigImage"/

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

Pinput type="button" value="确认" id="crop_submit"//P

/form

/div

/div

样式:大图、小图展示都需要固定高度、宽度,因为后台需要进行放大处理。即:img width=""height=""/

然后是使用jcrop了。在使用jcrop前我们需要下载jcrop:。

将下载的压缩包解压后可以看到三个文件夹及一个index.html文件,/

css下放置的是Jcorp的样式文件,/demo下放置的是几个简单的例子(index.html中引用的链接就是放置在这个文件夹下),/js下放置的是Jcorp中最重要的脚本文件。我们只需要使用三个文件即可:jquery.Jcrop.css、jquery.Jcrop.js、JQuery.js

使用方法:

复制代码 代码如下:

//裁剪图像

function cutImage(){

$("#srcImg").Jcrop( {

aspectRatio : 1,

onChange : showCoords,

onSelect : showCoords,

minSize :[200,200]

});

//简单的事件处理程序,响应自onChange,onSelect事件,按照上面的Jcrop调用

function showCoords(obj) {

$("#x").val(obj.x);

$("#y").val(obj.y);

$("#w").val(obj.w);

$("#h").val(obj.h);

if (parseInt(obj.w) 0) {

//计算预览区域图片缩放的比例,通过计算显示区域的宽度(与高度)与剪裁的宽度(与高度)之比得到

var rx = $("#preview_box").width() / obj.w;

var ry = $("#preview_box").height() / obj.h;

//通过比例值控制图片的样式与显示

$("#previewImg").css( {

width : Math.round(rx * $("#srcImg").width()) + "px", //预览图片宽度为计算比例值与原图片宽度的乘积

height : Math.round(rx * $("#srcImg").height()) + "px", //预览图片高度为计算比例值与原图片高度的乘积

marginLeft : "-" + Math.round(rx * obj.x) + "px",

marginTop : "-" + Math.round(ry * obj.y) + "px"

});

}

}

}

在使用jcrop前一定要先将$(“”).jcrop();进行预初始化,否则没有效果。

还有一种调用的方法,

复制代码 代码如下:

var api = $.Jcrop('#cropbox',{

onChange: showPreview,

onSelect: showPreview,

aspectRatio: 1

});

这种方法是将Jcrop生成的对象赋给一个全局变量,这样操作就会比较方便。

通过上面的js,就将X轴坐标、Y轴坐标、高度H、宽度W这个四个值传递给后台了,后台就只需要根据这四个值

进行放大处理,然后切割即可。

Action

复制代码 代码如下:

/**

* 裁剪头像

*/

public String cutImage(){

/*

* 获取参数

* x,y,w,h,bigImage

*/

HttpServletRequest request = (HttpServletRequest) ActionContext.getContext().get(ServletActionContext.HTTP_REQUEST);

int x = Integer.valueOf(request.getParameter("x"));

int y = Integer.valueOf(request.getParameter("y"));

int w = Integer.valueOf(request.getParameter("w"));

int h = Integer.valueOf(request.getParameter("h"));

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

//获取文件真实路径

//获取文件名

String[] imageNameS = bigImage.split("/");

String imageName = imageNameS[imageNameS.length-1];

//文件正式路径

String imagePath = getSavePath()+"\\"+imageName;

//切割图片

ImageCut imageCut = new ImageCut();

imageCut.cutImage(imagePath, x, y, w, h);

//头像裁剪完成后,将图片路径保存到用户

UserBean userBean = (UserBean) request.getSession().getAttribute("userBean");

userBean.setUserPhoto(bigImage);

//保存头像

UserCenterService centerService = new UserCenterService();

centerService.updatePhoto(userBean);

//将修改后的用户保存到session中

request.getSession().setAttribute("userBean", userBean);

return "updatePhoto";

}

}

裁剪图片工具类:ImageCut.java

复制代码 代码如下:

public class ImageCut {

/**

* 图片切割

* @param imagePath 原图地址

* @param x 目标切片坐标 X轴起点

* @param y 目标切片坐标 Y轴起点

* @param w 目标切片 宽度

* @param h 目标切片 高度

*/

public void cutImage(String imagePath, int x ,int y ,int w,int h){

try {

Image img;

ImageFilter cropFilter;

// 读取源图像

BufferedImage bi = ImageIO.read(new File(imagePath));

int srcWidth = bi.getWidth(); // 源图宽度

int srcHeight = bi.getHeight(); // 源图高度

//若原图大小大于切片大小,则进行切割

if (srcWidth = w srcHeight = h) {

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

int x1 = x*srcWidth/400;

int y1 = y*srcHeight/270;

int w1 = w*srcWidth/400;

int h1 = h*srcHeight/270;

cropFilter = new CropImageFilter(x1, y1, w1, h1);

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

BufferedImage tag = new BufferedImage(w1, h1,BufferedImage.TYPE_INT_RGB);

Graphics g = tag.getGraphics();

g.drawImage(img, 0, 0, null); // 绘制缩小后的图

g.dispose();

// 输出为文件

ImageIO.write(tag, "JPEG", new File(imagePath));

}

} catch (IOException e) {

e.printStackTrace();

}

}

}

怎么用js或者jquery实现本地裁剪

网上很多这样的图片裁剪插件,最好用最常用的是jcrop,这里是他的官网

当然中文翻译过来的文章也很多,楼主可以搜索下~

js或者jQuery在这里只能实现确立要裁剪的范围,实际的裁剪是要交给后台进行的。

基本思路就是,设定一个半透明框,在要裁剪的图片中进行拖动和定位,然后把这个框的范围(也就是四个角的坐标送到后台),后台如PHP提供相关的图片处理函数,对图片进行裁剪。

思路比较简单,操作起来也不难。

希望对楼主有帮助~~


分享文章:jquery裁剪插件,怎么使用jquery插件
网页地址:http://cdweb.net/article/dsddpjs.html