`

Js实现图片切割

阅读更多

//图片切割
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 }
  }
}
 
分享到:
评论

相关推荐

    用JavaScript实现图片切割效果实例

    总结来说,用JavaScript实现图片切割效果需要理解HTML5 Canvas的使用,熟练掌握Canvas API,以及对用户交互的处理。通过这样的实例,我们可以提升Web应用的用户体验,创造更加生动和丰富的视觉效果。

    js图片切割,很有用!

    以上就是JavaScript实现图片切割的基本原理和流程。通过这些技术,我们可以创建出一个简单易用的图片裁剪工具,让用户在网页上轻松实现图片的个性化裁剪。对于开发者来说,理解并掌握这些知识对于提升用户体验和增强...

    【JavaScript源代码】js实现图片切割功能.docx

    在JavaScript中实现图片切割功能是一项常见的任务,尤其是在网页开发中,比如用于图像拼接、缩略图生成或者图像处理应用。以下是一个简单的实例,展示了如何使用JavaScript和HTML CSS来完成这个功能。 首先,HTML...

    JS实现图片切割效果(带拖放、缩放效果)

    在JavaScript的世界里,实现图片切割效果,同时支持拖放和缩放功能,是一项常见的交互式需求,常见于图像编辑工具或在线设计平台。这个技术点主要涉及到HTML5的Canvas元素,以及相关的事件处理机制。接下来,我们将...

    JavaScript 图片切割效果

    JavaScript图片切割效果是一种常见的网页交互功能,常用于头像裁剪、图片预览或上传前的编辑等场景。本文将详细介绍如何实现这一功能,并提供一个名为ImgCropper的示例工具。 首先,我们需要理解JavaScript在处理...

    整合图片分割、切割、.net效果

    在实际应用中,开发人员可能会结合.NET后端处理和JavaScript前端展示,实现图片上传、预览、切割、保存等一系列功能。通过Ajax异步通信,可以提供流畅的用户体验,而服务器端处理则可以确保数据安全和性能优化。 ...

    JS图片切割

    10. **库和框架**: 为了简化开发过程,有许多成熟的JavaScript库和框架提供了图片切割功能,如JQuery Cropper、Cropper.js、ngImgCrop等。它们封装了大部分细节,提供更丰富的功能和友好的API。 总的来说,...

    JavaScript图片切割代码

    JavaScript图片切割技术是一种在网页上实现动态图像裁剪的功能,常用于用户自定义头像、产品图片编辑等场景。这项技术结合了HTML、CSS和JavaScript,使得用户可以在浏览器端通过交互方式选择并调整图片的裁剪区域。...

    图片上设置热区,点击图片上的点,执行javascript方法

    在网页设计中,热区(Hotspots)是一种特殊的技术,允许我们为图片的不同区域赋予交互性,使得用户点击这些特定区域时可以触发某些预设的行为,例如执行JavaScript方法。这通常用于实现图像映射,即在一张大图上定义...

    JS+CSS3 3D图片分割拼接动画特效

    【JS+CSS3 3D图片分割拼接动画特效】是一种在网页中通过JavaScript和CSS3技术实现的创新视觉效果。这种特效将图片分解成多个3D片段,并通过动态拼接来创造出引人入胜的视觉体验。接下来,我们将深入探讨这一特效背后...

    将图片切割成瓦片图-(算法+实现)

    对于给定的链接,它指向了一个CSDN博客文章,其中详细介绍了如何用JavaScript实现图片切割成瓦片图的步骤。 `Leaflet`是一个流行的开源JavaScript库,专门用于交互式地图的开发。它可以方便地管理和展示瓦片图,...

    js + .Net 图片切割系统

    【标题】:“js + .Net 图片切割系统”是一个基于JavaScript和.NET技术的图像处理解决方案,主要用于实现对图片的局部裁剪和操作。这个系统结合了前端JavaScript的灵活性与后端.NET的强大处理能力,为用户提供了一种...

    java javascript 图片切割

    在IT行业中,图片处理是一项常见的任务,特别是在网页设计、...在给定的`TestImageCopper`文件中,可能包含了Java或JavaScript实现的图片切割示例代码,通过查看和学习这些代码,可以加深对图片切割技术的理解和应用。

    JavaScript切割图片

    本篇文章将深入探讨JavaScript如何实现图片切割功能。 首先,我们需要了解HTML5中的Canvas元素,它是JavaScript进行图像操作的基础。Canvas提供了一个二维绘图环境,通过JavaScript可以对画布进行绘制、擦除、变换...

    javascript实现的图片切割多块效果实例

    本文将详细阐述如何使用JavaScript实现图片的切割多块效果,包括如何通过操作图片和CSS样式来达到预期的视觉效果。通过以下知识点的学习,可以掌握实现这种效果的具体技巧。 ### JavaScript操作图片技巧 ...

    JavaScript 图片切割效果(带拖放、缩放效果)

    1. **HTML5 Canvas**:实现图片切割效果的核心是HTML5的Canvas元素。Canvas提供了一个画布,允许开发者通过JavaScript来绘制图形、图像,包括对图片进行裁剪。在ImgCropper.htm文件中,Canvas可能是主要的工作区域,...

    js实现canvas保存图片为png格式并下载到本地的方法

    之后,通过创建一个模拟的点击事件(使用`createEvent`和`dispatchEvent`)来触发a标签的点击行为,从而实现图片的下载。 4. 结合使用:将上述步骤整合,首先在canvas上绘制图形或图片,然后通过`toDataURL`转换为...

    js无刷新上传图片及在线切割

    4. **Canvas**:HTML5的Canvas元素是实现图片在线切割的核心。通过canvas的drawImage方法可以将图片绘制到画布上,然后使用getImageData或createImageData获取像素数据,结合用户的选择区域,进行裁剪操作。裁剪后的...

    【JavaScript源代码】NodeJS实现图片文本分割.docx

    ### Node.js 实现图片文本分割技术解析 #### 一、引言 在图像处理领域,文本分割是一项重要的技术,尤其对于复杂背景下的图像文本提取有着广泛的应用价值。本篇文章将详细解析一个基于Node.js实现的图片文本分割...

Global site tag (gtag.js) - Google Analytics