- 浏览: 61034 次
- 性别:
- 来自: 顺德
最新评论
-
liuxf1122:
不支持最新的IE9、10和11!修改了也不行,不知如何是好啊! ...
JavaScript 工具库:Cloudgamer JavaScript Library v0.1 发布 -
gongyeye:
$$E.addEvent( this._container, ...
JavaScript 工具库:Cloudgamer JavaScript Library v0.1 发布 -
kingliu:
很好,很强大,学习了
JavaScript 工具库:Cloudgamer JavaScript Library v0.1 发布 -
lwkjob:
非常强大谢谢
图片延迟加载(按需加载)效果 -
zxh277100963:
判断ie版本 错误,我明细是IE8的判断出来是IE7
JavaScript 工具库:Cloudgamer JavaScript Library v0.1 发布
拖拉缩放效果,实现通过鼠标拖动来调整层的面积(宽高)大小。例如选框效果。
这里的拖拉缩放比一般的选框复杂一点,能设置八个方位(方向)的固定触发点,能设置最小范围,最大范围和比例缩放。
跟拖放效果一样,程序的原型也是在做图片切割效果的时候做出来的。但这个效果的参考少的多,基本上靠自己摸索,走了不少弯路,现在总算把自己想要的效果做出来了,程序跟上一个版本比较也已经“面目全非”,还是觉得有很多需要改进的地方,就像永远没有最完美的土耳其地毯。
这里也有一个简化版的SimpleResize,方便学习。
前台效果预览
下载测试代码
ps:实例中包含了拖放效果,不过两个效果是完全独立的,删掉拖放的部分也能正常缩放。
程序说明
其中用到的鼠标捕获、清除选择等,在拖放效果中有说明的这里就略过。下面以SimpleResize为例说一下基本原理。
【程序原理】
程序需要用Set来添加触发对象(就是用来拖拉的对象,详细看使用说明),主要是设置mousedown事件来触发Start程序开始缩放。
Start程序主要用来设置缩放程序_fun和缩放需要的参数,最后设置mousemove事件触发Resize程序进行缩放,mouseup事件中执行取消缩放Stop程序。
Resize程序的任务是执行缩放程序_fun和设置整理后的样式,这里为了简化程序样式是全部一起设置的,这样程序的注意流程就完成了。
ps:设置样式的值必须是大于0的数,否则ie会报错。
下面说说缩放的原理,先以右边拖拉为例,右边拖拉一般是以左边为固定点,右边进行缩放。
首先记录左边定位参数_sideLeft:
this._sideLeft = e.clientX - this._styleWidth;
在拖拉时,就可以根据这个参照值计算拖拉后要设置的样式参数_styleWidth:
this._styleWidth = Math.max(e.clientX - this._sideLeft, 0);
上面的程序能保证样式是大于等于0的数。
至于左边就麻烦一点,因为左边拖拉是以右边为固定点,这就必须在设置宽度的同时设置left才能,保证右边固定。
首先记录右边定位参数_sideRight:
this._sideRight = e.clientX + this._styleWidth;
还有left的定位参数_fixLeft:
this._fixLeft = this._styleWidth + this._styleLeft;
在拖拉时,计算_styleWidth:
this._styleWidth = Math.max(this._sideRight - e.clientX, 0);
在根据_styleWidth设置_styleLeft:
this._styleLeft = this._fixLeft - this._styleWidth;
上下同理,至于斜角的四个方向只是同时执行两个方向,例如右下就是同时执行右边和下边:
this.Right(e); this.Down(e);
【程序结构】
在更详细的程序说明之前,先了解一下程序结构。
当点击触发点,就会根据设置给缩放程序_fun设置为八个方向的缩放程序的其中一个。
八个缩放程序分别是:Up(上)、Down(下)、Right(右)、Left(左)、RightDown(右下)、RightUp(右上)、LeftDown(左下)和LeftUp(左上)。
在这些缩放程序,首先会进行宽和高的设置,由于宽和高的设置还需要经过范围限制和比例缩放的修正,而这些会在修正程序中处理。
修正程序包括几个部分:
RepairX:水平方向修正(左右方向);
RepairY:垂直方向修正(上下方向);
RepairAngle:对角方向修正(右下、右上、左下、左上);
RepairTop:top修正(用于以右边为固定点定位);
RepairLeft:left修正(用于以下边为固定点定位);
RepairHeight:高度修正;
RepairWidth:宽度修正。
如果没有设置最小范围限制,当缩放超过定位边时就会自动转向,例如右边缩放,左边定位,当拖动到左边定位的左边时,就会切换成左边缩放,右边定位,而这个切换是在转向程序中进行的。
转向程序包括几个部分:
TurnRight:右转程序;
TurnLeft:左转程序;
TurnUp:上转程序;
TurnDown:下转程序。
基本结构了解后,下面就开始介绍程序细节。
【最小范围限制】
最小范围限制就是限制缩放的宽和高,程序中把Min设为true,就可以通过minWidth和minHeight属性进行限制。
单是限制很简单,只要超过限制就把值设成限制值就行了,这个主要是在修正程序RepairHeight和RepairWidth中修正:
例如RepairWidth中:
iWidth = Math.max(this.Min ? this.minWidth : iWidth, iWidth, 0);
注意这里带了个0,保证最小值大于等于0。
【最大范围限制】
最大范围限制,复杂一点,是固定一个(矩形)范围,然后把缩放限制在范围内。
这个范围限制跟拖放效果的类似,有四个范围属性:上(mxTop)、下(mxBottom)、左(mxLeft)、右(mxRight)。
程序中把Max设为true就可以设置。
然后根据这四个范围属性设置四个范围参数,_mxRightWidth、_mxDownHeight、_mxUpHeight和_mxLeftWidth。
这四个围参数代表的是相对于定位边的最大宽度或高度,例如_mxRightWidth就是当右边缩放时(左边固定),宽度可以设置的最大值:
this._mxRightWidth = Math.max(mxRight - this._styleLeft - this._borderX, this.Min ? this.minWidth : 0);
这里要小心的是不要把边框忽略了。
然后在Right缩放程序中,把这个参数传递给RepairX,而RepairX把参数传递给RepairWidth并在里面修正宽度:
iWidth = Math.min(this.Max ? mxWidth : iWidth, iWidth);
还有容器范围限制,这个跟拖放效果的差不多,这里就不重复了。此外在Start程序中还会对异常的范围参数进行修正,不过这里考虑的不多,估计并不很完善,最好还是不要设一些奇怪的参数。
【比例缩放】
比例缩放就是缩放的时候同时设置宽和高,使用宽和高按照一定的比例显示。
程序中把Scale设为true就可以启用,并且Ratio可以设置比例大小(宽/高),如果不设置的话就会自动取当前的宽/高比例。
对于对角方向,在比例缩放的情况下宽和高就不能同时设置,而必须有一个优先另一个参照比例设置了。
这个要注意,否则很容易进入死胡同。RepairAngle修正程序中就是宽度优先的,高度再按比例修正(参考代码)。
而左右上下四个方向,是以缩放对象对称轴为中心缩放的。
以左右方向为例,要实现这个效果,首先在Start程序中设置中心定位坐标_scaleTop:
this._scaleTop = this._styleTop + this._styleHeight / 2;
当修正好高之后,再用这个坐标设置_styleTop值:
this._styleTop = this._scaleTop - iHeight / 2;
其实就是设置高之后再修正top,使缩放之后的缩放对象中心的水平坐标保持不变,就做出以缩放对象的水平对称轴为中心的缩放了。
【范围限制下的比例缩放】
一般的比例缩放很简单,在宽或高取值之后,按比例设置另一个值就行了。
但如果有了范围限制有可能按比例缩放后,就超过范围限制了。
如果只考虑最大范围限制的话,可以再修正,每次修正的范围会越来越小,没有问题。
但加上最小范围限制,就可能这边已经到了最小范围了,但另一边还在最大范围限制之外了。
这个时候就必须小心细心处理了,首先要
当两个范围限制发生冲突时,要放弃其中一个,程序中是优先考虑最大范围限制,放弃最小范围限制,这个看起来没什么但如果思想转不过来,就很容易钻入死胡同去了(经验教训T_T)。
例如根据宽度和比例Ratio已经获得了高的值iHeight,可以这样设置宽和高:
if(this.Max && iHeight > mxHeight){
iWidth = Math.round((iHeight = mxHeight) * this.Ratio);
}else if(this.Min && iHeight < this.minHeight){
var tWidth = Math.round(this.minHeight * this.Ratio);
if(tWidth < mxWidth){ iHeight = this.minHeight; iWidth = tWidth; }
}
说明一下这段代码:
首先判断iHeight是否超过最大值,是的话就根据最大值设置宽和高,由于优先考虑最大范围所以宽是否超过最小范围就不用再考虑了;
如果没有超过最大值,再判断是否小于最小值,是的话根据最小值和比例获取要设置的宽赋给一个临时变量tWidth,然后判断tWidth是否超过最大范围,不是的话就再设置值,否则优先原则就放弃修改。
【自动转向】
当没有设置最小范围限制,当超过改方向能设置宽高的范围就会自动转向。
转向程序中需要一个参数表示转向后要执行的缩放程序,并重新设置几个属性。
以左转程序TurnLeft为例:
_fun:设置为转向后要执行的缩放程序;
_sideRigh:设置为当前的_sideLeft,即以把右边定位左边设置成原来的左边定位坐标(形象点说就是原来是左边不动,改成右边不动);
_fixLeft:左转后的定位需要_fixLeft,设置为_styleLeft,本来是left加width的,由于左转时width是0,所以只要left就够了。
如果设置了最大范围限制,还需要设置一下范围参数,为了方便,程序使用了一个_mxSet方法重新设置范围参数。
程序如下:
if(!(this.Min || this._styleWidth)){
this._fun = fun;
this._sideRight = this._sideLeft;
this._fixLeft = this._styleLeft;
this.Max && this._mxSet();
return true;
}
如果发生了转向就返回true,这个主要是用在对角方向的转向。
对于对角方向,可能会转向两个方向,但只能同一时间设置一个转向,例如对于RightDown转向可以这样:
this.TurnLeft(this.LeftDown) || this.TurnUp(this.RightUp);
这样就可以保证只会执行一个转向。
【样式修正】
由于offset获取的值跟style设置的值并不是一样的,例如offsetWidth包括padding、border和width。
所以在获取和设置时必须做一些修正,例如用offsetWidth获取宽度,要设置width时必须减去padding和border等等。
程序中有_borderX和_borderY属性分别是缩放对象的左右和上下边框宽度:
var _style = CurrentStyle(this._obj);
this._borderX = (parseInt(_style.borderLeftWidth) || 0) + (parseInt(_style.borderRightWidth) || 0);
this._borderY = (parseInt(_style.borderTopWidth) || 0) + (parseInt(_style.borderBottomWidth) || 0);
程序中主要是修正了border,对于padding、margin都没有考虑,如果设置了这些属性的要注意一下哦。
【样式设置】
首先缩放对象必须是绝对定位,如果有范围限制容器就必须把容器设置成相对定位:
this._obj.style.position = "absolute";
!this._mxContainer || CurrentStyle(this._mxContainer).position == "relative" || (this._mxContainer.style.position = "relative");
推荐根据拖拉的方向设置拖拉对象的鼠标样式,其中右下和左上是nw-resize,左下和右上是ne-resize,上和下是n-resize,左和右是e-resiz。
至于拖拉对象的地位就有技巧一点,绝对定位到四个角比较简单,适当设置top,left,right和height到为0就行了,例如右上角是right和top为0。
四个边就难一点,参考这里的居中显示效果,利用定位样式和margin就能做到居中了。
例如右边设置top为50%,margin-top为高度的一半就能在右边上下居中了。
程序说明就到这里了,还有一些结构上的东西以我的能力还是比较难写出来,还是看代码来领会吧。
程序有很多相似的结构,总感觉可以整理得更好,等以后自己的编写水平高点的时候再来看拉。
使用说明
首先实例化一个拖拉缩放对象:
var rs = new Resize("dragDiv");
有以下这些可选参数和属性:
Max: false,//是否设置范围限制(为true时下面mx参数有用)
mxContainer:"",//指定限制在容器内
mxLeft: 0,//左边限制
mxRight: 9999,//右边限制
mxTop: 0,//上边限制
mxBottom: 9999,//下边限制
Min: false,//是否最小宽高限制(为true时下面min参数有用)
minWidth: 50,//最小宽度
minHeight: 50,//最小高度
Scale: false,//是否按比例缩放
Ratio: 0,//缩放比例(宽/高)
onResize: function(){}//缩放时执行
然后使用Set程序添加拖拉对象,Set程序需要两个参数,第一格是拖拉对象,第二个是缩放参数。
其中缩放参数可以是"right-down"、"left-down"、"right-up"、"left-up"、"right"、"left"、"up"和"down"其中之一。
像这样添加就行了:
rs.Set("rDown", "down");
ps:如果跟跟拖放效果配合使用时,要禁止冒泡,否则一点拖拉对象就冒泡到拖放了。
发表评论
-
AlertBox 弹出层(信息提示框)效果
2010-10-11 11:06 1203弹出层就是相对文档或窗口定位的一个层,一般用来显示提示信息、广 ... -
JavaScript 图片3D展示空间(3DRoom)
2010-09-20 09:59 1346一般的平面效果,通过 ... -
ccs3/滤镜/canvas的图片旋转/缩放/翻转变换效果
2010-08-21 13:48 1650以前要实现图片的旋转或翻转,只能用ie的滤镜来实现,虽然can ... -
SlideView 图片滑动(扩展/收缩)展示效果
2010-07-30 08:52 1252滑动展示效果主要用在 ... -
ImageZoom 图片放大效果(扩展篇)
2010-04-16 21:32 1250上一篇ImageZoom已经对图片放大效果做了详细的分析,这次 ... -
ImageZoom 图片放大效果
2010-04-07 21:03 1266这个效果也叫放大镜效果,最早好像在ppg出现的,之后就有了很多 ... -
图片延迟加载(按需加载)效果
2010-03-11 21:13 2854之前在做一个图片浏览效果时,要看后面的小图必须等到前面的加载完 ... -
Lazyload 延迟加载(缓载)效果
2010-02-22 09:58 1550Lazyload是通过延迟加载 ... -
JavaScript 图片滑动展示效果
2008-05-13 01:34 1715看到jQuery实例:图片展示效果后,我也想拿来试试,但我不太 ... -
JavaScript 图片变换效果(ie only)
2008-05-23 12:02 2307仿照常见的那个图片变换flash做的效果,纯js。不过滤镜变换 ... -
JavaScript 图片滑动切换效果
2008-07-06 01:25 3187序一(08/07/06) 看到alibaba的一个图片切换效 ... -
JavaScript blog式日历控件
2008-08-23 00:25 1064近来要做一个记事本系统,想找一个合适的日历控件,但网上的都是那 ... -
JavaScript Table排序
2008-10-06 08:24 1082程序的实现的是在客户 ... -
JavaScript 日期联动选择器
2008-10-28 10:30 1253一个日期联动选择器, ... -
JavaScript 滑动条效果
2008-12-24 08:27 2495这个滑动条(拖动条) ... -
JavaScript Tween算法及缓动效果
2009-01-06 09:17 1182Flash做动画时会用到Tween类,利用它可以做很多动画效果 ... -
JavaScript 颜色梯度和渐变效果
2009-03-11 08:24 1073近来看了Dean的“Convert any colour va ... -
JavaScript Table行定位效果
2009-05-18 14:02 1035近来有客户要求用table显示一大串数据,由于滚动后就看不到表 ... -
JavaScript 浮动定位提示效果
2009-07-07 08:23 1119本来想做一个集合浮动 ... -
JavaScript 多级联动浮动菜单 (第二版)
2009-08-10 00:54 1849上一个版本(第一版请看这里)基本实现了多级联动和浮动菜单的功能 ...
相关推荐
拖拉缩放效果,实现通过鼠标拖动来调整层的面积(宽高)大小。例如选框效果。 这里的拖拉缩放比一般的选框复杂一点,能设置八个方位(方向)的固定触发点,能设置最小范围,最大范围和比例缩放。 跟拖放效果一样,...
本项目“JavaScript 拖拉缩放效果 -源码.zip”提供了一个关于这两项功能的源码示例,用于学习和参考。 首先,我们来了解JavaScript中的拖拉操作。拖拉效果主要涉及HTML5的`Draggable`属性和`dragstart`, `drag`, `...
JavaScript 图片拖拉缩放效果(仿PHOTOSHOP).rarJavaScript 图片拖拉缩放效果(仿PHOTOSHOP).rarJavaScript 图片拖拉缩放效果(仿PHOTOSHOP).rarJavaScript 图片拖拉缩放效果(仿PHOTOSHOP).rarJavaScript 图片...
本项目“图片拖拉缩放效果(仿PHOTOSHOP)”就是利用JavaScript来模仿Photoshop中的图片操作功能,让用户能够在浏览器上对图片进行拖动和缩放操作,提升用户体验。 在实现这个效果时,首先我们需要理解JavaScript中...
主要介绍了JavaScript实现选择框按比例拖拉缩放的方法,具有等比例缩放及设置最小范围等功能,涉及javascript事件的添加、监听、页面元素动态操作及鼠标事件的响应等技巧,具有一定参考借鉴价值,需要的朋友可以参考下
38:___图片拖拉缩放效果(仿PHOTOSHOP) 39:___图片控制内容框的文字上下翻滚 40:___图片旋转构成3D圆环的展示特效 41:___图片点击后变灰色的CSs代码 42:___图片闪烁代码 43:___图片雷达效果,像光照一样 44:___在...
要使用缩放需要把Resize设为true,并设置各个拖拉对象,程序通过_resize设置缩放的比例和最少范围(详细看拖拉缩放效果)。 下面说说控制层如何控制切割效果: 控制层的拖放和缩放过程中加入了SetPos设置切割样式...
1. 图片拖拉缩放效果(仿PHOTOSHOP):这个效果模拟了Adobe Photoshop中的图片编辑功能,让用户可以通过鼠标拖动和缩放来查看和操作图片。实现这一效果的关键在于监听鼠标事件(mousedown, mousemove, mouseup),并...
Vue.js 是一个流行的前端JavaScript框架,用于构建用户界面。在这个示例中,我们将讨论如何在Vue项目中实现一个图片拖拉、旋转和放大缩小的组件。这个组件的主要目的是提供一个交互式的图片查看体验,允许用户通过...
**缩放效果:** 地图的放大和缩小功能则涉及到比例尺的调整。通常我们会有一个缩放因子,当用户点击放大按钮时,比例尺乘以这个因子;点击缩小按钮时,比例尺除以这个因子。然后,根据新的比例尺重新加载地图切片,...
例如,`addEventListener`函数可以监听用户的鼠标事件,当用户点击并拖动赛车时,JavaScript可以改变赛车的位置,从而实现拖拉效果。 为了实现动画,开发者可能会使用requestAnimationFrame函数,这是一种浏览器...
在这个案例中,可能包括了图片容器的宽高、定位以及拖动和缩放时的过渡效果。CSS可以用来设置图片的初始大小,以及在滚动和拖动时的交互样式。 `jquery.js`是jQuery库的引用,它是一个强大的JavaScript库,简化了...
这个名为"基于svg的机器学习中-点线等拖拉拽工作流核心svg渲染原理部分demo.zip"的压缩包文件,就是这样一个例子,它展示了如何使用SVG(Scalable Vector Graphics)技术来实现机器学习工作流的可视化拖拽功能。...
- **拖放效果**:提供视觉反馈,如拖动时的阴影、缩放或旋转效果,提升用户体验。 - **数据交换**:支持多种数据类型,如文本、图片或自定义对象,通过`dataTransfer`对象进行传递。 - **可配置选项**:允许开发者...