- 浏览: 111154 次
- 性别:
- 来自: 北京
文章分类
- 全部博客 (53)
- JavaBase (26)
- Java--strutsFrameWork (3)
- Java-HibernateFrameWork (0)
- Java--springFrameWork (10)
- Exception Summary (1)
- Java--Tomcat (0)
- JavaScript and Ajax (2)
- Programming Word (1)
- Search Engine (0)
- MySQLDatabase (0)
- OrcalDatabase (0)
- SQLserverDatabase (0)
- 各种配置 (0)
- 学习总结 (1)
- 个人随笔 (4)
- 个人情感 (2)
最新评论
-
jiazhen1021:
...
Spring框架中的Bean对象的生命周期 -
zzjmates:
很浅显的东西,没有讲到本质
深度解析JSP工作原理 -
knightjames:
好文章,虽然只是看懂一部分
深度解析JSP工作原理 -
jarip:
好文章就是看一遍就能清楚个大概,
深度解析JSP工作原理 -
qq672076266:
good
pageContext对象
//图片切割 var ImgCropper = Class.create(); ImgCropper.prototype = { //容器对象,控制层,图片地址 initialize: function(container, handle, url, options) { this._Container = $(container);//容器对象 this._layHandle = $(handle);//控制层 this.Url = url;//图片地址 this._layBase = this._Container.appendChild(document.createElement("img"));//底层 this._layCropper = this._Container.appendChild(document.createElement("img"));//切割层 this._layCropper.onload = Bind(this, this.SetPos); //用来设置大小 this._tempImg = document.createElement("img"); this._tempImg.onload = Bind(this, this.SetSize); this.SetOptions(options); this.Opacity = Math.round(this.options.Opacity); this.Color = this.options.Color; this.Scale = !!this.options.Scale; this.Ratio = Math.max(this.options.Ratio, 0); this.Width = Math.round(this.options.Width); this.Height = Math.round(this.options.Height); //设置预览对象 var oPreview = $(this.options.Preview);//预览对象 if(oPreview){ oPreview.style.position = "relative"; oPreview.style.overflow = "hidden"; this.viewWidth = Math.round(this.options.viewWidth); this.viewHeight = Math.round(this.options.viewHeight); //预览图片对象 this._view = oPreview.appendChild(document.createElement("img")); this._view.style.position = "absolute"; this._view.onload = Bind(this, this.SetPreview); } //设置拖放 this._drag = new Drag(this._layHandle, { Limit: true, onMove: Bind(this, this.SetPos), Transparent: true }); //设置缩放 this.Resize = !!this.options.Resize; if(this.Resize){ var op = this.options, _resize = new Resize(this._layHandle, { Max: true, onResize: Bind(this, this.SetPos) }); //设置缩放触发对象 op.RightDown && (_resize.Set(op.RightDown, "right-down")); op.LeftDown && (_resize.Set(op.LeftDown, "left-down")); op.RightUp && (_resize.Set(op.RightUp, "right-up")); op.LeftUp && (_resize.Set(op.LeftUp, "left-up")); op.Right && (_resize.Set(op.Right, "right")); op.Left && (_resize.Set(op.Left, "left")); op.Down && (_resize.Set(op.Down, "down")); op.Up && (_resize.Set(op.Up, "up")); //最小范围限制 this.Min = !!this.options.Min; this.minWidth = Math.round(this.options.minWidth); this.minHeight = Math.round(this.options.minHeight); //设置缩放对象 this._resize = _resize; } //设置样式 this._Container.style.position = "relative"; this._Container.style.overflow = "hidden"; this._layHandle.style.zIndex = 200; this._layCropper.style.zIndex = 100; this._layBase.style.position = this._layCropper.style.position = "absolute"; this._layBase.style.top = this._layBase.style.left = this._layCropper.style.top = this._layCropper.style.left = 0;//对齐 //初始化设置 this.Init(); }, //设置默认属性 SetOptions: function(options) { this.options = {//默认值 Opacity: 50,//透明度(0到100) Color: "",//背景色 Width: 0,//图片高度 Height: 0,//图片高度 //缩放触发对象 Resize: false,//是否设置缩放 Right: "",//右边缩放对象 Left: "",//左边缩放对象 Up: "",//上边缩放对象 Down: "",//下边缩放对象 RightDown: "",//右下缩放对象 LeftDown: "",//左下缩放对象 RightUp: "",//右上缩放对象 LeftUp: "",//左上缩放对象 Min: false,//是否最小宽高限制(为true时下面min参数有用) minWidth: 50,//最小宽度 minHeight: 50,//最小高度 Scale: false,//是否按比例缩放 Ratio: 0,//缩放比例(宽/高) //预览对象设置 Preview: "",//预览对象 viewWidth: 0,//预览宽度 viewHeight: 0//预览高度 }; Extend(this.options, options || {}); }, //初始化对象 Init: function() { //设置背景色 this.Color && (this._Container.style.backgroundColor = this.Color); //设置图片 this._tempImg.src = this._layBase.src = this._layCropper.src = this.Url; //设置透明 if(isIE){ this._layBase.style.filter = "alpha(opacity:" + this.Opacity + ")"; } else { this._layBase.style.opacity = this.Opacity / 100; } //设置预览对象 this._view && (this._view.src = this.Url); //设置缩放 if(this.Resize){ with(this._resize){ Scale = this.Scale; Ratio = this.Ratio; Min = this.Min; minWidth = this.minWidth; minHeight = this.minHeight; } } }, //设置切割样式 SetPos: function() { //ie6渲染bug if(isIE6){ with(this._layHandle.style){ zoom = .9; zoom = 1; }; }; //获取位置参数 var p = this.GetPos(); //按拖放对象的参数进行切割 this._layCropper.style.clip = "rect(" + p.Top + "px " + (p.Left + p.Width) + "px " + (p.Top + p.Height) + "px " + p.Left + "px)"; //设置预览 this.SetPreview(); }, //设置预览效果 SetPreview: function() { if(this._view){ //预览显示的宽和高 var p = this.GetPos(), s = this.GetSize(p.Width, p.Height, this.viewWidth, this.viewHeight), scale = s.Height / p.Height; //按比例设置参数 var pHeight = this._layBase.height * scale, pWidth = this._layBase.width * scale, pTop = p.Top * scale, pLeft = p.Left * scale; //设置预览对象 with(this._view.style){ //设置样式 width = pWidth + "px"; height = pHeight + "px"; top = - pTop + "px "; left = - pLeft + "px"; //切割预览图 clip = "rect(" + pTop + "px " + (pLeft + s.Width) + "px " + (pTop + s.Height) + "px " + pLeft + "px)"; } } }, //设置图片大小 SetSize: function() { var s = this.GetSize(this._tempImg.width, this._tempImg.height, this.Width, this.Height); //设置底图和切割图 this._layBase.style.width = this._layCropper.style.width = s.Width + "px"; this._layBase.style.height = this._layCropper.style.height = s.Height + "px"; //设置拖放范围 this._drag.mxRight = s.Width; this._drag.mxBottom = s.Height; //设置缩放范围 if(this.Resize){ this._resize.mxRight = s.Width; this._resize.mxBottom = s.Height; } }, //获取当前样式 GetPos: function() { with(this._layHandle){ return { Top: offsetTop, Left: offsetLeft, Width: offsetWidth, Height: offsetHeight } } }, //获取尺寸 GetSize: function(nowWidth, nowHeight, fixWidth, fixHeight) { var iWidth = nowWidth, iHeight = nowHeight, scale = iWidth / iHeight; //按比例设置 if(fixHeight){ iWidth = (iHeight = fixHeight) * scale; } if(fixWidth && (!fixHeight || iWidth > fixWidth)){ iHeight = (iWidth = fixWidth) / scale; } //返回尺寸对象 return { Width: iWidth, Height: iHeight } } }
发表评论
-
JS..........
2009-12-04 03:22 14481.Jquery支持JSON 发送请求的方法 $ ... -
HTML
2009-12-04 03:20 1213<table> <tr> & ... -
DOM那点事儿。。
2009-12-02 00:35 1460DOM简介 DOM的接口和类 ... -
转载啊
2009-12-01 22:13 1285<!DOCTYPE html PUBLIC &qu ... -
JSP的7个动作指令
2009-11-30 17:10 2036JSP动作指令主要有如 ... -
JSP内置对象
2009-11-30 17:00 1938JSP脚本中包含9个内置对象,这9个内置对象都是Serv ... -
Exception对象
2009-11-30 16:38 1209Exception对象是Throwable的子类,代表着JSP ... -
pageContext对象
2009-11-30 16:19 10691使用pageContext可以访问page、reques ... -
Java图片切割
2009-11-30 16:03 4155protected void processReque ... -
JDBC即(JAVA_DATABASE_CONNECTION)一
2009-11-30 14:36 12792 - 连接 本概 ... -
Js获取所有文本节点
2009-11-30 00:25 4423<script type="text/ ... -
AJAX的校验
2009-11-29 23:27 1112Validate.html <html> ... -
ANT工具使用
2009-11-28 00:23 1601ant使用: 1.下载ant构建工具1.7.1 2. ... -
编程单词
2009-11-28 00:21 950+release #n.释放, 排放, 解除释放令公映 ... -
JavaEnum
2009-11-27 15:32 878public class WeekDay { ... -
JS中获取节点下元素
2009-11-26 23:01 2045<html> <head> ... -
JavaScript遍历数组
2009-11-22 17:37 1388function ForInDemo() { // 创 ... -
Javascript数组遍历
2009-11-22 17:32 1304function ForInDemo() { // 创 ... -
JavaScript的一个随即例子
2009-11-22 01:44 967<!DOCTYPE HTML PUBLIC " ... -
Swing小程序
2009-11-22 01:17 846import java.awt.*; import ...
相关推荐
总结来说,用JavaScript实现图片切割效果需要理解HTML5 Canvas的使用,熟练掌握Canvas API,以及对用户交互的处理。通过这样的实例,我们可以提升Web应用的用户体验,创造更加生动和丰富的视觉效果。
以上就是JavaScript实现图片切割的基本原理和流程。通过这些技术,我们可以创建出一个简单易用的图片裁剪工具,让用户在网页上轻松实现图片的个性化裁剪。对于开发者来说,理解并掌握这些知识对于提升用户体验和增强...
在JavaScript中实现图片切割功能是一项常见的任务,尤其是在网页开发中,比如用于图像拼接、缩略图生成或者图像处理应用。以下是一个简单的实例,展示了如何使用JavaScript和HTML CSS来完成这个功能。 首先,HTML...
在JavaScript的世界里,实现图片切割效果,同时支持拖放和缩放功能,是一项常见的交互式需求,常见于图像编辑工具或在线设计平台。这个技术点主要涉及到HTML5的Canvas元素,以及相关的事件处理机制。接下来,我们将...
JavaScript图片切割效果是一种常见的网页交互功能,常用于头像裁剪、图片预览或上传前的编辑等场景。本文将详细介绍如何实现这一功能,并提供一个名为ImgCropper的示例工具。 首先,我们需要理解JavaScript在处理...
在实际应用中,开发人员可能会结合.NET后端处理和JavaScript前端展示,实现图片上传、预览、切割、保存等一系列功能。通过Ajax异步通信,可以提供流畅的用户体验,而服务器端处理则可以确保数据安全和性能优化。 ...
对于给定的链接,它指向了一个CSDN博客文章,其中详细介绍了如何用JavaScript实现图片切割成瓦片图的步骤。 `Leaflet`是一个流行的开源JavaScript库,专门用于交互式地图的开发。它可以方便地管理和展示瓦片图,...
10. **库和框架**: 为了简化开发过程,有许多成熟的JavaScript库和框架提供了图片切割功能,如JQuery Cropper、Cropper.js、ngImgCrop等。它们封装了大部分细节,提供更丰富的功能和友好的API。 总的来说,...
JavaScript图片切割技术是一种在网页上实现动态图像裁剪的功能,常用于用户自定义头像、产品图片编辑等场景。这项技术结合了HTML、CSS和JavaScript,使得用户可以在浏览器端通过交互方式选择并调整图片的裁剪区域。...
在网页设计中,热区(Hotspots)是一种特殊的技术,允许我们为图片的不同区域赋予交互性,使得用户点击这些特定区域时可以触发某些预设的行为,例如执行JavaScript方法。这通常用于实现图像映射,即在一张大图上定义...
【JS+CSS3 3D图片分割拼接动画特效】是一种在网页中通过JavaScript和CSS3技术实现的创新视觉效果。这种特效将图片分解成多个3D片段,并通过动态拼接来创造出引人入胜的视觉体验。接下来,我们将深入探讨这一特效背后...
【标题】:“js + .Net 图片切割系统”是一个基于JavaScript和.NET技术的图像处理解决方案,主要用于实现对图片的局部裁剪和操作。这个系统结合了前端JavaScript的灵活性与后端.NET的强大处理能力,为用户提供了一种...
本文将详细阐述如何使用JavaScript实现图片的切割多块效果,包括如何通过操作图片和CSS样式来达到预期的视觉效果。通过以下知识点的学习,可以掌握实现这种效果的具体技巧。 ### JavaScript操作图片技巧 ...
在IT行业中,图片处理是一项常见的任务,特别是在网页设计、...在给定的`TestImageCopper`文件中,可能包含了Java或JavaScript实现的图片切割示例代码,通过查看和学习这些代码,可以加深对图片切割技术的理解和应用。
本篇文章将深入探讨JavaScript如何实现图片切割功能。 首先,我们需要了解HTML5中的Canvas元素,它是JavaScript进行图像操作的基础。Canvas提供了一个二维绘图环境,通过JavaScript可以对画布进行绘制、擦除、变换...
1. **HTML5 Canvas**:实现图片切割效果的核心是HTML5的Canvas元素。Canvas提供了一个画布,允许开发者通过JavaScript来绘制图形、图像,包括对图片进行裁剪。在ImgCropper.htm文件中,Canvas可能是主要的工作区域,...
之后,通过创建一个模拟的点击事件(使用`createEvent`和`dispatchEvent`)来触发a标签的点击行为,从而实现图片的下载。 4. 结合使用:将上述步骤整合,首先在canvas上绘制图形或图片,然后通过`toDataURL`转换为...
4. **Canvas**:HTML5的Canvas元素是实现图片在线切割的核心。通过canvas的drawImage方法可以将图片绘制到画布上,然后使用getImageData或createImageData获取像素数据,结合用户的选择区域,进行裁剪操作。裁剪后的...
### Node.js 实现图片文本分割技术解析 #### 一、引言 在图像处理领域,文本分割是一项重要的技术,尤其对于复杂背景下的图像文本提取有着广泛的应用价值。本篇文章将详细解析一个基于Node.js实现的图片文本分割...