具体的参数使用和基本使用方式请看:http://www.uedsc.com/croppic-api.html

需要说明的几点:

1.支持两种上传方式:

(1)先将原图上传至服务器,然后再次将切图信息传给服务器。(两次请求,需要提供uploadUrlcropUrl两个)

(2)直接将图片通过Data URI scheme的方式将图片缓存在浏览器内,用户切图完毕后同切图信息一并发送至服务器。(一次请求,只需要提供cropUrl)

2.如果需要自定义切图的模板大小,需要修改croppic.js文件,修改如下:

然后在你程序使用的页面内灵活给这两个参数赋值就可以了。

3.后台程序处理的代码共享(注:使用了第二种,一次性上传的方式)

前台:

<div id="croppic"></div>

<script type="text/javascript">
    @{
        if (brand.Type==0)
        {
             <text>
    var my_cropH = 203;
    var my_cropW = 282;
    </text>
        }else {
            <text>
    var my_cropH = 300;
    var my_cropW = 224;
    </text>
        }
    }
    var croppicHeaderOptions = {
        cropData: {
            "Id": '@brand.Id'
        },
        cropUrl: '/Brand/CutImg',
        //customUploadButtonId: 'cropContainerHeaderButton',
        modal: false,
        processInline: true,
        loaderHtml: '<div class="loader bubblingG"><span id="bubblingG_1"></span><span id="bubblingG_2"></span><span id="bubblingG_3"></span></div> ',
        onBeforeImgUpload: function () { console.log('onBeforeImgUpload') },
        onAfterImgUpload: function () { console.log('onAfterImgUpload') },
        onImgDrag: function () { console.log('onImgDrag') },
        onImgZoom: function () { console.log('onImgZoom') },
        onBeforeImgCrop: function () { console.log('onBeforeImgCrop') },
        onAfterImgCrop: function () { console.log('onAfterImgCrop') },
        onReset: function () { console.log('onReset') },
        onError: function (errormessage) { console.log('onError:' + errormessage) }
    }
    var croppic = new Croppic('croppic', croppicHeaderOptions);
</script>

后台:

public ActionResult CutImg(int? imgInitW, int? imgInitH, decimal? imgW, decimal? imgH, int? imgY1, int? imgX1, decimal? cropH, decimal? cropW, int? rotation)
        {
            //保存图片
            var displayImageStream = Request["imgUrl"] == null ? null : Request["imgUrl"];
            byte[] imgByte = Convert.FromBase64String(displayImageStream.Substring(displayImageStream.IndexOf(",") + 1));
            Image oldImage;
            using (MemoryStream mstream = new MemoryStream(imgByte, 0, imgByte.Length))
            {
                oldImage = Image.FromStream(mstream);
                if (!oldImage.RawFormat.Equals(System.Drawing.Imaging.ImageFormat.Jpeg))
                {
                    return Json(new { status = "error", message = "切图出现问题" });
                }
            }
            //构建新的图片
            var croppedBitmap = new Bitmap((int)cropW, (int)cropH);
            try
            {
                using (var g = Graphics.FromImage(croppedBitmap))
                {
                    Bitmap bitmap = new Bitmap(oldImage, (int)imgW, (int)imgH);
                    g.DrawImage(bitmap,
                       new Rectangle(0, 0, (int)cropW, (int)cropH),
                       new Rectangle((int)imgX1, (int)imgY1, (int)cropW, (int)cropH), GraphicsUnit.Pixel);
                }
            }
            catch (Exception e)
            {
                return Json(new { status = "error", message = "internal error cropping the image" });
            }
            string relativePic = DateTime.Now.ToString("yyyy/MM/dd/") + Guid.NewGuid().ToString() + ".jpg";
            string strNewPic = AppDomain.CurrentDomain.BaseDirectory + relativePic;
            if (!Directory.Exists(Path.GetDirectoryName(strNewPic)))
                Directory.CreateDirectory(Path.GetDirectoryName(strNewPic));
            croppedBitmap.Save(strNewPic);
            return Json(new { status = "success", url = "../../" + relativePic });

}

学习:https://codeload.github.com/danielbcorreia/croppic-net/zip/master 从这个链接学习了部分代码,感谢。

Croppic插件使用介绍-asp.net的更多相关文章

  1. 头像截图上传三种方式之一(一个简单易用的flash插件)(asp.net版本)

    flash中有版权声明,不适合商业开发.这是官网地址:http://www.hdfu.net/ 本文参考了http://blog.csdn.net/yafei450225664/article/det ...

  2. 3.介绍ASP.NET Core框架

    介绍ASP.NET Core框架 在这篇文章中,我将要向你们简短介绍一下ASP.NET Core 框架.当今社会,当提到软件开发,每个人都是讨论着开源以及跨平台开发.总所周知,微软是以它的基于Wind ...

  3. ASP.NET 5 已死 - 隆重介绍 ASP.NET Core 1.0 和 .NET Core 1.0

    还没正式登场就死了?不能怪我标题党,是大神Scott在他博客上这么说的,我只是翻译了一下. 在1月20号最新的ASP.NET Community Standup视频中,微软aspnet开发组的大帅哥 ...

  4. 【转】Eclipse插件大全介绍及下载地址

    转载地址:http://developer.51cto.com/art/200906/127169.htm 尚未一一验证. eclipse插件大全介绍,以及下载地址 Eclipse及其插件下载网址大全 ...

  5. Xcode Alcatraz插件管理介绍和使用

    Xcode Alcatraz插件管理介绍和使用http://www.jianshu.com/p/7a2484123bf6 1.简介 Alcatraz是一个能帮你管理Xcode插件丶模版及颜色配置的工具 ...

  6. 详细介绍ASP.NET页面重定向方法

    ASP.NET中页面重定向的使用的很频繁,实现方法也有不同,自己也试过几种,现在总结一下. 一.Transfer Execute Redirect重定向方法介绍 1.Server.Transfer方法 ...

  7. 03_Elasticsearch如何安装以及相关插件的介绍

    03_Elasticsearch如何安装以及相关插件的介绍 elasticsearch -d (-d参数是为了让服务后台运行) Elasticsearch 目录结构: 文件夹 作用 /bin 运行El ...

  8. 图片剪切之Croppic插件

    前几天做图片上传时需要进行图片的剪切和缩放,上网查找时找到了这个插件.样式很好看,功能也很OK.但是网上都是php进行后台处理图片的例子,然后只好慢慢琢磨C#的处理.插件地址是:http://www. ...

  9. Cordova各个插件使用介绍系列(六)—$cordovaDevice获取设备的相关信息

    详情请看:Cordova各个插件使用介绍系列(六)—$cordovaDevice获取设备的相关信息 在项目中需要获取到当前设备,例如手机的ID,联网状态,等,然后这个Cordova里有这个插件可以用, ...

随机推荐

  1. ACM-ICPC 2018 徐州赛区网络预赛 J. Maze Designer

    传送门:https://nanti.jisuanke.com/t/31462 本题是一个树上的问题:结点间路径问题. 给定一个有N×M个结点的网格,并给出结点间建立墙(即拆除边)的代价.花费最小的代价 ...

  2. 使用HTML5 Canvas API

    一.检测浏览器支持情况 HTML5 Canvas的确是一个好东西,但是并不是所有浏览器都支持HTML5 Canvas的,这就要求我们在使用HTML5 Canvas前要检查浏览器是否支持这玩意儿. 在创 ...

  3. Mozilla新特性只支持https网站

    Mozilla的官方博客2015.4.30正式宣布了淘汰HTTP的方案. 其中包括:设定一个日期,所有的新特性将只提供给HTTPS网站:HTTP网站将逐步被禁止访问浏览器功能,尤其是那些与用户安全和隐 ...

  4. [bzoj1356]Rectangle[Baltic2009][几何常识乱搞]

    虽然说是几何常识乱搞,但是想不到啊.. 题意:n个点取4个组成矩形,使面积最大,求面积. n<=1500 题解: 1.对角线相等且相互交于中点的四边形是矩形. 2.矩形四点共圆. 所以$n^2$ ...

  5. ISO 7064:1983.MOD11-2校验码计算法 : (身份证校验码-18位)

    /* 假设某一17位数字是 17位数字 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 加权因子 7 9 10 5 8 4 2 1 6 3 7 9 10 5 8 4 2 计算17位 ...

  6. Html5 history Api简介

    一. Html4的History API back() 后退,跟按下“后退”键是等效的. forward() 前进,跟按下“前进”键是等效的. go() 用法:history.go(x):在历史的范围 ...

  7. oracle约束总结(not null/unique/primary key/foreign key/check)

    约束(constraint):对创建的表的列属性.字段进行的限制. 诸如:not null/unique/primary key/foreign key/check 作用范围:         ①列级 ...

  8. vim中自己主动加入凝视 加入文本信息

    工欲善其事,必先利其器.在开发过程中.方便.快捷的开发环境.能提高工作效率.优美的界面能让我们心情愉悦:最重要的是,能保持我们在外行严重高深莫測的牛逼~ 假设在创建新的源程序文件时希望能自己主动产生一 ...

  9. geek青年的状态机,查表,纯C语言实现

    geek青年的状态机,查表,纯C语言实现 1. 问题的提出.抽象 建一,不止是他,不少人跟我讨论过这种问题:怎样才干保证在需求变更.扩充的情况下.程序的主体部分不动呢? 这是一个很深刻和艰难的问题.在 ...

  10. POJ-3268-最短路(dijkstra算法)

    Silver Cow Party Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 12494   Accepted: 5568 ...