最近天天都是加班,好不容易年前休息了,就抽点时间谢谢,自认为还是比较简单易懂的,没有用什么复杂牛叉的算法,因为我也会,呵呵。(没有对图片大小边界做判断,只对容器做了判断,请注意~
)
懒得详细说明了,先上前端代码:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档</title>
<style type="text/css">
*{margin:0; padding:0;}
#picDiv{width:703px; height:338px; background:#fff; border:1px solid #999; margin:100px auto; position:relative; overflow:hidden;}
#picDiv ul{width:200px; height:200px; border:1px dashed #fff; cursor:move; list-style:none; position:relative; z-index:200;}
#picDiv li{width:6px; height:6px; background:#fff; border:1px solid #333; margin:-4px 0 0 -4px; overflow:hidden; position:absolute; opacity:0.5; filter:alpha(opacity=50);}
#picDiv li.tl{cursor:nw-resize; top:0%; left:0%;}
#picDiv li.tc{cursor:n-resize; top:0%; left:50%;}
#picDiv li.tr{cursor:ne-resize; top:0%; left:100%;}
#picDiv li.ml{cursor:w-resize; top:50%; left:0%;}
#picDiv li.mr{cursor:e-resize; top:50%; left:100%;}
#picDiv li.fl{cursor:sw-resize; top:100%; left:0%;}
#picDiv li.fc{cursor:s-resize; top:100%; left:50%;}
#picDiv li.fr{cursor:se-resize; top:100%; left:100%;}
</style>
</head>
<body>
<div id="picDiv">
<ul>
<li class="tl"></li>
<li class="tc"></li>
<li class="tr"></li>
<li class="ml"></li>
<li class="mr"></li>
<li class="fl"></li>
<li class="fc"></li>
<li class="fr"></li>
</ul>
<img src="../images/2.jpg" style="position:absolute; top:0; left:0; opacity:0.3; filter:alpha(opacity=30); z-index:10;" />
<img src="../images/2.jpg" style="position:absolute; top:0; left:0; clip:rect(0 0 0 0); z-index:100;" />
</div>
<form action="41.php" method="post">
<input type="submit" value=" 提 交 " />
<input type="hidden" id="imgInfor" name="imgInfor" />
</form>
<script type="text/javascript">
(function(){
var div=document.getElementById('picDiv'),
ul=div.getElementsByTagName('ul')[0],
li=ul.getElementsByTagName('li');
divW=div.offsetWidth-2,
divH=div.offsetHeight-2,
see=function(){
var t=ul.offsetTop,
l=ul.offsetLeft,
r=l+ul.offsetWidth,
f=t+ul.offsetHeight;
div.getElementsByTagName('img')[1].style.clip='rect('+t+'px '+r+'px '+f+'px '+l+'px)';
document.getElementById('imgInfor').value="{'x':'"+l+"','y':'"+t+"','w':'"+ul.offsetWidth+"','h':'"+ul.offsetHeight+"','url':'"+div.getElementsByTagName('img')[1].src+"'}";
window.getSelection?window.getSelection().removeAllRanges():document.selection.empty();
},
clear=function(o){
if(!-[1,]){o.setCapture();}//学增加丢失焦点事件
document.onmouseup=function(){
if(!-[1,]){o.releaseCapture();}
document.onmousemove=null;
document.onmouseup=null;
};
return false;//webkit中去掉默认事件,使鼠标不会变成默认文本光标
};
if(!-[1,]){
var cDiv=document.createElement('div');
cDiv.style.cssText='width:100%; height:100%; background:#fff; opacity:0; filter:alpha(opacity=0); font-size:0;';
ul.appendChild(cDiv);
}
ul.onmousedown=function(e){
e=e||window.event;
var oldX=e.clientX-ul.offsetLeft,
oldY=e.clientY-ul.offsetTop,
maxW=divW-ul.offsetWidth,
maxH=divH-ul.offsetHeight;
document.onmousemove=function(e){
e=e||window.event;
var newX=e.clientX-oldX,newY=e.clientY-oldY;
newX=newX<0?0:newX>maxW?maxW:newX;
newY=newY<0?0:newY>maxH?maxH:newY;
ul.style.top=newY+'px';
ul.style.left=newX+'px';
see();
};
clear(this);
};
for(var i in li){
li[i].onmousedown=function(e){
e=e||window.event;
var oldX=e.clientX,
oldY=e.clientY,
oldT=ul.offsetTop+2,
oldL=ul.offsetLeft+2,
oldW=ul.offsetWidth,
oldH=ul.offsetHeight,
minW=50,minH=50,
_method=this;
if(e.stopPropagation){
e.stopPropagation();
}else{
e.cancelBubble=true;
}
document.onmousemove=function(e){
e=e||window.event;
var lis={'w':'tr,mr,fr','h':'fl,fc,fr','l':'tl,ml,fl','t':'tl,tc,tr'};
if(lis.w.indexOf(_method.className)>-1){
var w=e.clientX-oldX+oldW;
w=w<minW?minW:w>divW-oldL?divW-oldL:w;
ul.style.width=w+'px';
}
if(lis.h.indexOf(_method.className)>-1){
var h=e.clientY-oldY+oldH;
h=h<minH?minH:h>divH-oldT?divH-oldT:h;
ul.style.height=h+'px';
if(!-[1,]&&!window.XMLHttpRequest){cDiv.style.height=h+'px';}//ie6下高度不变bug
}
if(lis.l.indexOf(_method.className)>-1){
var l=e.clientX-oldX+oldL;
l=l<0?0:l>oldW+oldL-minW?oldW+oldL-minW:l;
ul.style.left=l+'px';
ul.style.width=oldW+oldL-l+'px';
}
if(lis.t.indexOf(_method.className)>-1){
var t=e.clientY-oldY+oldT;
t=t<0?0:t>oldH+oldT-minH?oldH+oldT-minH:t;
ul.style.top=t+'px';
ul.style.height=oldH+oldT-t+'px';
if(!-[1,]&&!window.XMLHttpRequest){cDiv.style.height=oldH+oldT-t+'px';}//ie6下高度不变bug
}
see();
};
clear(this);
};
}
see();
})();
</script>
</body>
</html>
这里是php处理的代码,具体图片自己弄吧~哈哈~后期会出功能多一点的
<?php
$img=json_decode(str_replace("\\'",'"',$_POST['imgInfor']),true);
$old = imagecreatefromstring(file_get_contents($img['url']));
if(function_exists("imagecreatetruecolor")){
$new=imagecreatetruecolor($img['w'],$img['h']); // 创建目标图gd2
}else{
$new=imagecreate($img['w'],$img['h']); // 创建目标图gd1
}
imagecopyresampled ($new,$old,0,0,$img['x'],$img['y'],$img['w'],$img['h'],$img['w'],$img['h']);
imagejpeg($new,'img\\'.getip().'_'.time().'.jpg');
@header("Content-type: image/jpeg");
imagejpeg($new);
imagedestroy($new);
function getip(){
if (getenv("HTTP_CLIENT_IP") && strcasecmp(getenv("HTTP_CLIENT_IP"), "unknown")){
$ip = getenv("HTTP_CLIENT_IP");
}else if(getenv("HTTP_X_FORWARDED_FOR") && strcasecmp(getenv("HTTP_X_FORWARDED_FOR"), "unknown")){
$ip = getenv("HTTP_X_FORWARDED_FOR");
}else if(getenv("REMOTE_ADDR") && strcasecmp(getenv("REMOTE_ADDR"), "unknown")){
$ip = getenv("REMOTE_ADDR");
}else if (isset ($_SERVER['REMOTE_ADDR']) && $_SERVER['REMOTE_ADDR'] && strcasecmp($_SERVER['REMOTE_ADDR'], "unknown")){
$ip = $_SERVER['REMOTE_ADDR'];
}else{
$ip = "unknown";
}
return ($ip);
}
?>
附件可以直接下载,大家共勉~
分享到:
相关推荐
JavaScript应用实例-多点_取色_点线.js
在移动应用或Web应用中,用户可能需要上传或编辑图片,此时图片裁剪功能就显得尤为关键。 “nice-cropper”是针对uni-app的一个插件,它提供了一个简洁易用的图片裁剪解决方案。开发者在使用过程中可能会遇到图片太...
Vue.js 是一个流行的前端JavaScript框架,用于构建用户界面。在这个场景中,我们关注的是一个针对Vue.js设计的图片裁剪插件。这个插件被称为"vue-img-cutter",它提供了一种简单易用的方式来处理图片裁剪,适用于...
【标题】"上传图片可裁剪-photoClip.js-支持移动端"是一个前端开发资源,主要功能是为用户提供在网页和移动设备上对上传图片进行裁剪的功能。这个工具可以帮助开发者实现用户友好的图像处理界面,让用户根据需要调整...
JavaScript应用实例-教程_多点触控.js
【标题】"javascript经典特效---可移动的导航条.rar"涉及的是JavaScript在网页设计中创建动态、可交互的导航条的技巧。JavaScript是一种强大的客户端脚本语言,它允许开发者为网页添加丰富的动态功能,比如本案例中...
`cropper.js` 是一个强大的 JavaScript 图片裁剪库,它支持在移动端和PC端进行图片的裁剪、放大、缩小和移动操作,极大地提高了用户体验。本教程将详细介绍如何利用 `cropper.js` 来实现这些功能。 首先,我们要...
简易涂鸦板--页面总体分为两个模块,一个是工具栏,一个是画布。 游戏的基础功能有:选择画笔颜色、选择线条粗细、橡皮擦、清除画布四种。其中在选 择画笔颜色时除了设置用户方便易选择的基础颜色外,还加入了调色板...
Jcrop是一款广泛应用于Web开发中的JavaScript库,专门用于实现图片的预览和裁剪功能。它支持Internet Explorer 8及更高版本以及所有主流浏览器,包括Chrome、Firefox、Safari和Opera,提供了良好的跨平台和跨浏览器...
Cropper.js 是一个轻量级的 JavaScript 图片裁剪库,专门用于处理图像的裁剪和旋转操作。它支持触控设备,并且提供了丰富的 API 和可定制的选项,可以满足多种裁剪需求。Cropper.js 可以与任何前端框架或库结合,...
JavaScript应用实例-取色_多点.js
本资源"js图片裁剪插件 内附demo.rar"提供了一个JavaScript实现的图片裁剪解决方案,包括前端的交互逻辑和后端的处理流程。 一、JavaScript图片裁剪技术 1. 前端技术基础:JavaScript是一种运行在客户端的编程语言...
在本案例中,"javascript经典特效---图片的左右移动.rar" 提供了一个经典的JavaScript实现图片左右滑动的示例。这个特效使得用户可以通过点击或者自动播放的方式,使图片在网页上左右平滑移动,增加了用户体验的互动...
`Cropper`是一个强大的JavaScript图片裁剪库,它为开发者提供了一种简单易用的方式来实现这些功能。本文将深入探讨`Cropper`在Java环境中的应用,以及如何在网页端集成并使用这个库。 首先,`Cropper`库主要是用...
JavaScript应用实例-取色_多点v1209.js
需要注意的是,为了保证兼容性和性能,我们通常会采用一些成熟的JavaScript图片裁剪库,如Cropper.js、Jcrop等。这些库已经封装好了大部分操作,如图片加载、裁剪区域控制、预览效果生成等功能,开发者只需要配置...
在本文中,我们将深入探讨如何使用原生JavaScript和HTML5的canvas元素来实现图片裁剪功能。canvas作为HTML5的一项重要特性,为开发者提供了在网页上进行动态图形绘制的能力,而图片裁剪则是其常见的应用之一。 首先...
在开发Web应用时,用户头像的上传与裁剪功能是一项常见的需求,它允许用户个性化地选择并调整自己的展示图片。本项目名为“头像上传-裁剪-JAVA”,是基于JAVA实现的一个功能模块,主要涉及到的技术点包括文件上传、...
在图片裁剪插件中,jQuery主要负责事件监听、DOM元素操作以及与其他JavaScript库的整合。 ### 2. 图片裁剪需求 图片裁剪功能通常用于满足以下需求: - **适应不同尺寸**:用户可能需要上传的图片适应特定尺寸,如...