ASP.NET MVC下使用SWFUpload完成剪切头像功能
首先介绍SWFUpload组件
var swfu;
window.onload = function () {
swfu = new SWFUpload({
// Backend Settings
upload_url: "/Image/upload", //提交上传的url
post_params: {
"ASPSESSID": "@Session.SessionID" //SessionID很重要,如果没有SessionID将无法上传,并且加载页面时Button都不会显示
},
// 上传文件设置
file_size_limit: "2 MB", //大小
file_types: "*.jpg",//格式
file_types_description: "JPG Images",
file_upload_limit: 0, // Zero means unlimited
//一系列事件 默认事件在Handler.js文件内
swfupload_preload_handler: preLoad,
swfupload_load_failed_handler: loadFailed,
file_queue_error_handler: fileQueueError,
file_dialog_complete_handler: fileDialogComplete,
upload_progress_handler: uploadProgress,//上传过程
upload_error_handler: uploadError,//上传异常
upload_success_handler: cutImage, //上传成功
upload_complete_handler: uploadComplete,
// Button样式相关设置
button_image_url: '@Url.Content("~/Content/js/swfuploadv250/images/XPButtonNoText_160x22.png")',
button_placeholder_id: "spanButtonPlaceholder",//Button按钮ID
button_width: 160,
button_height: 22,
button_text: '<span class="button">上传图片 <span class="buttonSmall">(2 MB Max)</span></span>',
button_text_style: '.button { font-family: Helvetica, Arial, sans-serif;color:red; font-size: 14pt; } .buttonSmall { font-size: 10pt; }',
button_text_top_padding: 1,
button_text_left_padding: 5,
// Flash文件(swfupload.swf) 路径设置
flash_url: '@Url.Content("~/Content/js/swfuploadv250/swfupload.swf")',
flash9_url: '@Url.Content("~/Content/js/swfuploadv250/swfupload_fp9.swf")',
custom_settings: {
upload_target: "divFileProgressContainer" //展示信息框 的id
},
// 是否开启调试
debug: false
});
Html
<body>
<div id="content">
aaabbb
<div id="swfu_container" style="margin: 0px 10px;">
<div>
<span id="spanButtonPlaceholder"></span>
</div>
<div id="divFileProgressContainer" style="height: 75px;"></div>
<div id="thumbnails"></div>
</div>
</div>
<div id="divImg" style="position:relative;overflow:hidden">
<div id="divCut" class="easyui-draggable" style="border:1px solid red;width:226px;height:198px;" data-options="onDrag:onDrag"></div>
</div>
<input type="button" value="头像截取" id="btnCut" />
<img id="cutImg" />
</body>
这时候页面效果

点击上传图片效果

控制器方法
public ActionResult Upload()
{
//获得上传数据
HttpPostedFileBase jpeg_image_upload = Request.Files["Filedata"];
//保存图片
string path = "../Images/temp.jpg";
jpeg_image_upload.SaveAs(Request.MapPath(path));
//获取图片大小
UploadImage.Models.ImageViewData imgViewModel = new Models.ImageViewData();
//取得上传图片流
using (System.Drawing.Image original_image = System.Drawing.Image.FromStream(jpeg_image_upload.InputStream))
{
imgViewModel.Path = path;
imgViewModel.Width = original_image.Width;
imgViewModel.Height = original_image.Height;
}
return Json(imgViewModel, JsonRequestBehavior.AllowGet);
}
//上传成功事件方法 上传相关信息 服务端返回的数据
function cutImage(file, serverData) {
var oJson = JSON.parse(serverData);
$("#divImg").css("backgroundImage", "url(" + oJson.Path + ")").css("width", oJson.Width + "px").css("height", oJson.Height + "px");
imgUrl = oJson.Path;
}
var imgUrl = "";
这是回调函数里的file参数信息,能用到的比较少。
creationdate: Wed Apr 09 2014 15:17:50 GMT+0800 (中国标准时间)
filestatus: -4
id: "SWFUpload_0_0"
index: 0
modificationdate: Thu Feb 27 2014 11:37:30 GMT+0800 (中国标准时间)
name: "1e6b388f8a513a5d6464f0b722e663aa.jpg"
post: Object
size: 101205
type: ".jpg"
uploadtype: 0
__proto__: Object

//截图图片
$("#btnCut").click(function () {
var $cut = $("#divCut");
var $divImg = $("#divImg");
var x = $cut.offset().left-$divImg.offset().left; //横坐标
var y = $cut.offset().top-$divImg.offset().left;//纵坐标
var width = $cut.width();//宽度
var height = $cut.height();//高度
//发送数据到服务端
$.post("/Image/ImageCut", { "x": parseInt(x), "y": parseInt(y), "width": parseInt(width), "height": parseInt(height), "imgUrl": imgUrl },
function (data) { $("#divImg").hide();
$("#cutImg").attr("src", data);
})
})
服务端代码
public ActionResult ImageCut(FormCollection form)
{
//1:接受参数
int x = int.Parse(form["x"]);
int y = int.Parse(form["y"]);
int width = int.Parse(form["width"]);
int height = int.Parse(form["height"]);
string imgUrl = form["imgUrl"];
string imgPath = string.Empty;
using (Bitmap map = new Bitmap(width, height))//创建图片的大小与要截取图像的大小一致
{
using (Graphics g = Graphics.FromImage(map))
{
//将之前上传的图片转成Image
using (Image img = Image.FromFile(Request.MapPath(imgUrl)))
{
// 操作的图, 要画大小, 画哪一块, 度量单位
g.DrawImage(img, new Rectangle(, , width, height), new Rectangle(x, y, width, height), GraphicsUnit.Pixel);
imgPath = "../Images/cuttemp.jpg";
map.Save(Request.MapPath(imgPath));//将BitMap保存
}
}
}
return Content(imgPath);
}
ASP.NET MVC下使用SWFUpload完成剪切头像功能的更多相关文章
- ASP.NET MVC下的四种验证编程方式[续篇]
在<ASP.NET MVC下的四种验证编程方式>一文中我们介绍了ASP.NET MVC支持的四种服务端验证的编程方式("手工验证"."标注Validation ...
- ASP.NET MVC下的四种验证编程方式
ASP.NET MVC采用Model绑定为目标Action生成了相应的参数列表,但是在真正执行目标Action方法之前,还需要对绑定的参数实施验证以确保其有效性,我们将针对参数的验证成为Model绑定 ...
- Response.End()在Webform和ASP.NET MVC下的表现差异
前几天在博问中看到一个问题--Response.End()后,是否停止执行?MVC与WebForm不一致.看到LZ的描述后,虽然奇怪于为何用Response.End()而不用return方式去控制流程 ...
- ASP.NET MVC下的四种验证编程方式[续篇]【转】
在<ASP.NET MVC下的四种验证编程方式> 一文中我们介绍了ASP.NET MVC支持的四种服务端验证的编程方式(“手工验证”.“标注ValidationAttribute特性”.“ ...
- ASP.NET MVC下的四种验证编程方式【转】
ASP.NET MVC采用Model绑定为目标Action生成了相应的参数列表,但是在真正执行目标Action方法之前,还需要对绑定的参数实施验证以确保其有效 性,我们将针对参数的验证成为Model绑 ...
- ASP.NET MVC下使用AngularJs语言(六):获取下拉列表的value和Text
前面Insus.NET有在Angularjs实现DropDownList的下拉列表的功能.但是没有实现怎样获取下拉列表的value和text功能. 下面分别使用ng-click和ng-change来实 ...
- ASP.NET MVC下使用AngularJs语言(五):ng-selected
这次学习ng-selected语法,这个是为DropDownList下拉列表显示默认选项. 演示从下面步骤开始 1,新建一个model: 上面#14行代码的property,数据类型为bool.即是存 ...
- ASP.NET MVC下使用AngularJs语言(二):ng-click事件
程序用户交互,用户使用mouse点击,这是一个普通的功能. 在angularjs的铵钮点击命令是ng-click. 创建Angularjs的app使用前一篇<ASP.NET MVC下使用Angu ...
- ASP.NET MVC下使用AngularJs语言(一):Hello your name
新春节后,分享第一个教程. 是教一位新朋友全新学习ASP.NET MVC下使用AngularJs语言. 一,新建一个空的Web项目.使用NuGet下载AngularJs和jQuery.二,配置Bund ...
随机推荐
- centos下无法直接删除乱码文件及文件夹解决方案
不知道怎么回事今天在系统上发现有一个名字为“\”的文件,使用rm -f \ 无法删除,最后没办法只能使用文件的inode号进行删除,以下是相关步骤: [oracle@prod-db ~]$ ls -i ...
- 宿主机Windows访问虚拟机Linux文件(二)
上一篇文章中详细讲述FTP服务(基于文件传输协议的服务),本文则介绍另一种能够实现此功能Telnet(Telecommunications network 远程登陆)服务.本文介绍的telnet我常用 ...
- Windows Experience Index
The Windows Experience is still there--even in build 9860. However, the GUI was retired with Window ...
- C#基于联通短信Sgip协议构建短信网关程序
此软件基于中国联通Sgip协议程序接口,适合在中国联通申请了短信发送端口的公司使用.短信群发已经成为现在软件系统.网络营销等必不可少的应用工具.可应用在短信验证.信息群发.游戏虚拟商品购买.事件提醒. ...
- NOIP模拟赛 无线通讯网
[题目描述] 国防部计划用无线网络连接若干个边防哨所.2种不同的通讯技术用来搭建无线网络:每个边防哨所都要配备无线电收发器:有一些哨所还可以增配卫星电话. 任意两个配备了一条卫星电话线路的哨所(两边都 ...
- 【线性基】bzoj2844: albus就是要第一个出场
线性基求可重rank 题目描述 给定 n 个数 $\{ a_i \}$ ,以及数 $x$. 将 $\{ a_i \}$ 的所有子集(包括空集)的异或值从小到大排序,得到 $\{ b_i \} $. ...
- 01创建线程CreateThread和_beginthreadex
Windows多线程之线程创建 一. 线程创建函数 CreateThread 1. 函数原型 HANDLE WINAPI CreateThread( _In_opt_ LPSECURITY_ATTRI ...
- Choose unique values for the 'webAppRootKey' context-param in your web.xml files! 错误的解决
大意是Log4jConfigListener在获取webapp.root值时,被后一context的值替换掉了,所以要在各个项目的web.xml中配置不同的webAppRootKey值,随即在其中一个 ...
- python3.7 内置函数整理
#!/usr/bin/env python __author__ = "lrtao2010" #python3.7 内置函数整理 #abs(x) #返回数字的绝对值. 参数可以是整 ...
- leetcode-16-greedyAlgorithm
455. Assign Cookies 解题思路: 先将两个数组按升序排序,然后从后往前遍历,当s[j] >= g[i]的时候,就把s[j]分给g[i],i,j都向前移动,count+1;否则向 ...