`

网站中集成jquery.imgareaselect实现图片的本地预览和选择截取

 
阅读更多

imgAreaSelect 是由 Michal Wojciechowski开发的一款非常好用的jquery插件,实现了图片的截取功能。其文档和Demo也是很详尽的。大家可以到http://odyniec.net/projects/imgareaselect/了解更多的细节。

下面我们就开始使用imgAreaSelect 开始code吧。

第一还是要引用jquery,接着引用下载好的 jquery.imgareaselect.pack.js 文件和 imgareaselect-default.css 样式文件。

接着写一些元素标签

<img id="ferret" src="" alt="It's coming right for us!" title="It's coming right for us!"
        style="float: left; margin-right: 10px; width: 400px; height: 300px" />
    
    <input type="hidden" name="x1" value="" />
    <input type="hidden" name="y1" value="" />
    <input type="hidden" name="x2" value="" />
    <input type="hidden" name="y2" value="" />
    <input id="loadFile" type="file" name="name" onchange="readURL(this);" />
    <input type="submit" name="submit" value="Submit" />
 这将用来展示图片和记录截取图片的坐标点。

接着开始写js

<script type="text/javascript">
        //绘制小图
        function preview(img, selection) {
            var scaleX = 100 / (selection.width || 1);
            var scaleY = 100 / (selection.height || 1);

            $('#ferret + div > img').css({
                width: Math.round(scaleX * 400) + 'px',
                height: Math.round(scaleY * 300) + 'px',
                marginLeft: '-' + Math.round(scaleX * selection.x1) + 'px',
                marginTop: '-' + Math.round(scaleY * selection.y1) + 'px'
            });
        }

        $(document).ready(function () {
            //添加小图
            $('<div><img id="ferret1"  src="" style="position: relative;" /><div>')
        .css({
            float: 'left',
            position: 'relative',
            overflow: 'hidden',
            width: '100px',
            height: '100px'
        })
        .insertAfter($('#ferret'));
            //主图编辑
            $('#ferret').imgAreaSelect({ x1: 120, y1: 90, x2: 280, y2: 210, aspectRatio: '4:3', onSelectChange: preview, onSelectEnd: function (img, selection) {
                $('input[name="x1"]').val(selection.x1);
                $('input[name="y1"]').val(selection.y1);
                $('input[name="x2"]').val(selection.x2);
                $('input[name="y2"]').val(selection.y2);
            }
            });
        });


        //本地预览
        function readURL(input) {
            var strSrc = $("#loadFile").val();

            //验证上传文件格式是否正确  
            var pos = strSrc.lastIndexOf(".");
            var lastname = strSrc.substring(pos, strSrc.length);
            if (lastname.toLowerCase() != ".jpg") {
                alert("您上传的文件类型为" + lastname + ",图片必须为 JPG 类型");
                return false;
            }

            //验证上传文件是否超出了大小  
            if (input.files[0].size / 1024 > 150) {
                alert("您上传的文件大小超出了150K限制!");
                return false;
            }


            if (input.files && input.files[0]) {
                var reader = new FileReader();


                reader.onload = function (e) {
                    $('#ferret').attr('src', e.target.result);
                    $('#ferret1').attr('src', e.target.result);
                };

                reader.readAsDataURL(input.files[0]);
            }
        }
    </script>
 上述js完成了本地预览(此处的预览在chrome中正常;在IE中有些问题暂时没有找到本地预览的方法,大家可以用远程方式替换)和截取图片的功能。

前端写完了,接下来开始写后端的代码了

protected void Page_Load(object sender, EventArgs e)
        {
            if (IsPostBack)
            {
                int x1 = Convert.ToInt32(Request["x1"]);
                int y1 = Convert.ToInt32(Request["y1"]);
                int x2 = Convert.ToInt32(Request["x2"]);
                int y2 = Convert.ToInt32(Request["y2"]);


                HttpFileCollection files = Request.Files;
                for (int i = 0; i < files.Count; i++)
                {
                    HttpPostedFile file = files[i];
                    file.SaveAs(Server.MapPath("Upload/" + file.FileName));

                    //设置缩略图
                    int Thumbnailwidth = 400;
                    int Thumbnailheight = 300;
                    //新建一个bmp图片  
                    Bitmap bitmap = new Bitmap(Thumbnailwidth, Thumbnailheight);

                    //新建一个画板  
                    Graphics graphic = Graphics.FromImage(bitmap);

                    //设置高质量插值法  
                    graphic.InterpolationMode = InterpolationMode.High;

                    //设置高质量,低速度呈现平滑程度  
                    graphic.SmoothingMode = SmoothingMode.HighQuality;

                    //清空画布并以透明背景色填充  
                    graphic.Clear(System.Drawing.Color.Transparent);

                    //原图片
                    Bitmap originalImage = new Bitmap(file.InputStream);

                    //在指定位置并且按指定大小绘制原图片的指定部分  
                    graphic.DrawImage(originalImage, new System.Drawing.Rectangle(0, 0, Thumbnailwidth, Thumbnailheight),
                        new System.Drawing.Rectangle(0, 0, originalImage.Width, originalImage.Height),
                        System.Drawing.GraphicsUnit.Pixel);

                    //得到缩略图
                    System.Drawing.Image ThumbnailImage = System.Drawing.Image.FromHbitmap(bitmap.GetHbitmap());

                    //创建选择图片
                    Bitmap selectbitmap = new Bitmap(x2-x1, y2-y1);

                    //新建一个画板  
                    Graphics selectgraphic = Graphics.FromImage(selectbitmap);
                   

                    //裁切
                    selectgraphic.DrawImage(ThumbnailImage, 0, 0, new Rectangle(x1, y1, x2 - x1, y2 - y1), GraphicsUnit.Pixel);

                    //保存
                    selectbitmap.Save(Server.MapPath("Upload/"+Guid.NewGuid() + file.FileName), ImageFormat.Jpeg);

                   //todo:将上述资源释放

                }
            }
        }

 这里我们先将图片缩小到与前台大图一样的比例,然后在进行截取,并保存到文件中。

转自http://www.cnblogs.com/WilliamWang/archive/2012/09/17/imgareaselect.html

分享到:
评论

相关推荐

    jquery.imgareaselect-0.9.2几种封装

    通过修改`jquery.imgareaselect.css`中的样式,可以自定义选区的边框、填充色、控制点等视觉效果,以适应不同网站的风格。 6. **兼容性** jQuery.imgAreaSelect兼容大部分现代浏览器,包括Firefox、Chrome、...

    jquery.imgareaselect-0.8.min.js

    jquery.imgareaselect-0.8.min.js

    jquery的imgareaselect截图插件

    总结,jQuery的imgAreaSelect插件是实现网页图片裁剪功能的强大工具,其简单易用的API和丰富的定制选项使得开发者能轻松地集成到项目中。通过理解其工作原理和使用方法,我们可以为用户提供更加友好的图片交互体验。

    jquery.imgareaselect

    总结来说,`jquery.imgareaselect`是Web开发中一个强大且易用的图像裁剪解决方案,它通过与jQuery的无缝集成,为开发者提供了一种高效、灵活的方式来实现图像上传和裁剪功能。其强大的功能和广泛的自定义选项,使其...

    jquery.imgareaselect-0.9.10插件下载

    jquery.imgareaselect-0.9.10图片裁切插件下载,可把上传的图片进行裁剪再保存,在以前来说非常棘手的问题,现在借助jquery的imgareaselect插件再配合PHP的GD库就可以轻松的实现图片裁切功能。注,本插件包内不包括...

    利用jquery的imgAreaSelect插件实现图片裁剪示例

    在网页开发中,图片裁剪是一项常见的功能,用于让用户自定义选择图片的显示区域或预览效果。jQuery作为一款强大的JavaScript库,提供了丰富的插件来扩展其功能,其中包括imgAreaSelect插件,它能帮助开发者轻松实现...

    jQuery插件ImgAreaSelect实现头像上传预览和裁剪功能实例讲解一

    jQuery插件ImgAreaSelect是一个能够为图片添加可拖拽的裁剪框的插件,适合于在网页上实现图片上传预览和裁剪功能。为了实现头像上传、预览以及裁剪功能,我们需要遵循以下步骤: 首先,要明确目标功能: 1. 图片...

    jquery的imgareaselect插件

    总结,jQuery的imgAreaSelect插件为网页开发中的图片裁剪提供了便捷的解决方案,通过其灵活的配置选项和事件机制,我们可以实现各种定制化的图像选区功能。同时,了解其工作原理和应用场景,将有助于我们在实际开发...

    ASP.NET JQuery ImgAreaSelect 实现上传图片在线剪裁

    总的来说,这个例子展示了如何在ASP.NET应用中结合JQuery ImgAreaSelect插件实现图片上传和在线剪裁。这不仅提高了用户的交互性,也为图片处理提供了一种灵活的方法。在实际项目中,你可能还需要考虑错误处理、图片...

    jQuery插件imgAreaSelect 实例代码

    &lt;script src="path/to/jquery.imgareaselect.js"&gt; ``` ### 2. 基本使用 在HTML中,你需要一个`&lt;img&gt;`标签来显示图片。然后,使用jQuery选择器选中该图片并调用`imgAreaSelect`方法。 ```javascript $(document)....

    jquery图片裁剪插件imgareaselect

    《jQuery图片裁剪插件imgareaselect详解与实践》 在现代网页设计中,用户交互体验愈发重要,其中图片裁剪功能常...通过理解和实践,开发者可以轻松地将图片裁剪功能集成到自己的项目中,提升产品的互动性和功能性。

    JQuery插件imgAreaSelect_Demo

    &lt;link href="path/to/jquery.imgareaselect.css" rel="stylesheet" /&gt; &lt;script src="path/to/jquery.js"&gt; &lt;script src="path/to/jquery.imgareaselect.pack.js"&gt; ``` 2. **基本用法** 要使用`imgAreaSelect`,...

    jQuery插件imgAreaSelect基础讲解

    imgAreaSelect是一个基于jQuery的插件,它的主要功能是让用户通过鼠标拖曳来选择图片中的任意部分,适用于图片裁剪、拖曳和编辑等场景。这个插件提供了丰富的自定义选项,使得开发者可以根据实际需求进行定制。 ...

    jquery_imgareaselect图片裁切插件使用的中文文档

    `jQuery_imgareaselect` 是一个用于图片裁剪的JavaScript插件,它允许用户通过鼠标在图片上选择一个矩形区域,然后可以...在实际应用中,可以根据项目需求调整选项和集成到后端裁剪服务,以实现完整的图片处理流程。

    基于jquery网页截图插件(imgareaselect)

    【基于jQuery网页截图插件(imgareaselect)】是一个用于网页截取图像选定区域的JavaScript库,它与jQuery框架紧密集成,为用户提供了一个简单易用的交互式选择工具。这个插件允许用户在网页上自由划定一个矩形区域...

    javascript截图 jQuery插件imgAreaSelect用法详解_.docx

    2. **`jquery.imgareaselect.js`** - 此文件提供了`imgAreaSelect`插件,该插件允许用户在图片上选择特定区域。 这些文件可以通过以下链接下载: - `jquery.js`: [下载链接](https://jquery.com/) - `imgareaselect...

    jQuery+ajaxupload+imgareaselect+asp.net上传预览截取图像

    在IT行业中,前端开发经常需要处理用户上传图片的需求,而"jQuery+ajaxupload+imgareaselect+asp.net上传预览截取图像"这个主题,就是一种高效且用户体验优秀的解决方案。接下来,我们将深入探讨这些技术及其整合...

    图片上传裁剪预览(uploadify+imgareaselect)_前后台代码实现

    通过这个项目,开发者可以学习如何整合前端与后端,实现图片上传、裁剪和预览的完整流程,这对于提升用户体验和增强网站功能具有重要意义。在实际应用中,还可以根据需求进一步优化,比如增加图片压缩、尺寸限制、...

    jquery图片截取DEMO

    在IT行业中,jQuery图片截取是一项常见的前端技术,主要用于用户交互式地选择并...通过理解以上知识点,并参考"jquery图片截取DEMO"中的实现,开发者可以快速地在自己的项目中集成图片截取功能,提升用户的互动体验。

Global site tag (gtag.js) - Google Analytics