欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

基于asp.net實現(xiàn)圖片在線上傳并在線裁剪功能

 更新時間:2016年12月08日 11:06:52   作者:冷戰(zhàn)  
本文主要介紹了基于asp.net實現(xiàn)圖片在線上傳并在線裁剪功能的具體事例代碼,具有一定的參考價值。需要的朋友可以參考下

1、說明

  接上一篇文章asp.net uploadify實現(xiàn)多附件上傳功能完成后,又突然用到頭像上傳并在線裁剪。在網(wǎng)上找個眾多例子都沒有符合要求的,有一篇文章寫的不錯,Asp.Net平臺下的圖片在線裁剪功能的實現(xiàn)代碼(源碼打包),大家可以看下

2、組成

  首先說明一下代碼實現(xiàn)所用到的技術(shù),僅供參考:

    開發(fā)工具:vs2010

    目標框架:.NET Framework3.5

    jcrop:Jcrop.js v0.9.12

    Uploadify:uploadify-v3.1

    Jquery:jquery-1.9.0.js

  最后我會將整個Demo上傳,如果同學們的電腦上有開發(fā)環(huán)境可直接打開項目解決方案運行。

3、代碼

Default.aspx(測試頁面)

<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="Default.aspx.cs" Inherits="ImgJcrop._Default" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
  <title>在線裁剪</title>
  <link href="Scripts/jcrop/jquery.Jcrop.css" rel="stylesheet" type="text/css" />
  <link href="Scripts/uploadify-v3.1/uploadify.css" rel="stylesheet" type="text/css" />
  <script src="Scripts/jquery.1.9.0.min.js" type="text/javascript"></script>
  <script src="Scripts/jcrop/jquery.Jcrop.js" type="text/javascript"></script>
  <script src="Scripts/uploadify-v3.1/jquery.uploadify-3.1.js" type="text/javascript"></script>
  <script type="text/javascript">
    $(function () {
      var jcrop_api, boundx, boundy;
      $("#file_upload").uploadify({
        "auto": true,
        "buttonText": "選擇圖片",
        "swf": "Scripts/uploadify-v3.1/uploadify.swf",
        "uploader": "App_Handler/Uploadify.ashx?action=upload",
        "fileTypeExts": "*.jpg; *.jpeg; *.gif; *.png; *.bmp",
        "fileTypeDesc": "支持的格式:",
        "multi": false,
        "removeCompleted": false,
        "onUploadStart": function (file) {
          $("#file_upload-queue").hide();
        },
        "onUploadSuccess": function (file, data, response) {
          var row = eval("[" + data + "]");
          if (row[0]["status"] == 0) {
            $("#cutimg").html("<img id=\"imgOriginal\" name=\"imgOriginal\" /><div style=\"overflow: hidden; margin-top: 20px;\"><div style=\"width: 120px; height: 120px; overflow: hidden;\"><img id=\"imgPreview\" /></div><br /><input type=\"button\" id=\"btnImgCut\" onclick=\"cutSaveImg()\" value=\"裁剪并保存圖片\" /></div>");
            $("#cutimg img").each(function () { $(this).attr("src", row[0]["message"]); });
            $("#hidImgUrl").val(row[0]["message"]);
            $('#imgOriginal').Jcrop({
              onChange: updatePreview,
              onSelect: updatePreview,
              aspectRatio: 1,
              //maxSize: [120, 120],
              setSelect: [0, 0, 120, 120]
            }, function () {
              var bounds = this.getBounds();
              boundx = bounds[0];
              boundy = bounds[1];
              jcrop_api = this;
            });
          } else {
            alert(row[0]["message"]);
          }
        }
      });
 
      function updatePreview(c) {
 
        if (parseInt(c.w) > 0) {
          var rx = 120 / c.w;
          var ry = 120 / c.h;
 
          $("#imgPreview").css({
            width: Math.round(rx * boundx) + "px",
            height: Math.round(ry * boundy) + "px",
            marginLeft: "-" + Math.round(rx * c.x) + "px",
            marginTop: "-" + Math.round(ry * c.y) + "px"
          });
        }
        $("#hidXone").val(c.x);
        $("#hidYone").val(c.y);
        $("#hidXtwo").val(c.hidXtwo);
        $("#hidYtwo").val(c.hidYtwo);
        $("#hidImgWidth").val(c.w);
        $("#hidImgHeight").val(c.h);
      };
    });
 
    function cutSaveImg() {
      $.ajax({
        type: "post",
        url: "App_Handler/Uploadify.ashx?action=cutsaveimg",
        data: { strImgUrl: $("#imgOriginal")[0].src, hidXone: $("#hidXone").val(), hidYone: $("#hidYone").val(), hidImgWidth: $("#hidImgWidth").val(), hidImgHeight: $("#hidImgHeight").val() },
        dataType: "html",
        success: function (data) {
          var row = eval("[" + data + "]");
          if (row[0]["status"] == 0) { }
          alert(row[0]["message"]);
        }
      });
    }
  </script>
</head>
<body>
  <form id="form1" runat="server">
  <div>
    <input type="file" id="file_upload" name="file_upload" />
  </div>
  <div id="cutimg">
  </div>
  <asp:HiddenField ID="hidXone" runat="server" />
  <asp:HiddenField ID="hidYone" runat="server" />
  <asp:HiddenField ID="hidXtwo" runat="server" />
  <asp:HiddenField ID="hidYtwo" runat="server" />
  <asp:HiddenField ID="hidImgWidth" runat="server" />
  <asp:HiddenField ID="hidImgHeight" runat="server" />
  <asp:HiddenField ID="hidImgUrl" runat="server" />
  </form>
</body>
</html>

Uploadify.ashx(一般處理程序)

<%@ WebHandler Language="C#" Class="UploadifyUpload" %>
using System;
using System.Collections;
using System.Data;
using System.Web;
using System.Linq;
using System.Web.Services;
using System.Web.Services.Protocols;
using System.Web.SessionState;
using System.IO;
using System.Collections.Generic;
using System.Web.UI.WebControls;
using System.Text;
using System.Drawing;
using System.Drawing.Imaging;
public class UploadifyUpload : IHttpHandler, IRequiresSessionState
{
  public void ProcessRequest(HttpContext context)
  {
    context.Response.ContentType = "text/plain";
    context.Response.Charset = "utf-8";
 
    string action = context.Request["action"];
    switch (action)
    {
      case "upload":
        //上傳圖片
        upload(context);
        break;
      case "cutsaveimg":
        //裁剪并保存
        cutsaveimg(context);
        break;
    }
    context.Response.End();
  }
  /// <summary>
  /// 上傳圖片
  /// </summary>
  /// <param name="context"></param>
  private void upload(HttpContext context)
  {
    HttpPostedFile postedFile = context.Request.Files["Filedata"];
    if (postedFile != null)
    {
      string fileName, fileExtension;
      int fileSize;
      fileName = postedFile.FileName;
      fileSize = postedFile.ContentLength;
      if (fileName != "")
      {
        fileExtension = postedFile.FileName.Substring(postedFile.FileName.LastIndexOf('.'));
        string strPath = context.Server.MapPath("/") + "\\App_File\\Upload\\";//設(shè)置文件的路徑
        string strFileName = "upload" + DateTime.Now.ToString("yyyyMMddHHmmss") + fileExtension;
        string strFileUrl = strPath + strFileName;//保存文件路徑
        if (!Directory.Exists(strPath))
        {
          Directory.CreateDirectory(strPath);
        }
        postedFile.SaveAs(strFileUrl);//先保存源文件
        context.Response.Write("{\"status\":0,\"message\":\"/App_File/Upload/" + strFileName + "\"}");
      }
      else
      {
        context.Response.Write("{\"status\":1,\"message\":\"上傳失敗!\"}");
      }
    }
    else
    {
      context.Response.Write("{\"status\":1,\"message\":\"上傳失敗!\"}");
    }
  }
  /// <summary>
  /// 裁剪并保存圖片
  /// </summary>
  /// <param name="context"></param>
  private void cutsaveimg(HttpContext context)
  {
    string strImgUrl = context.Request["strImgUrl"];
    string strXone = context.Request["hidXone"];
    string strYone = context.Request["hidYone"];
    string strImgWidth = context.Request["hidImgWidth"];
    string strImgHeight = context.Request["hidImgHeight"];
    string[] urls = strImgUrl.Split('/');
    string str_url = urls.Last();
    try
    {
      string strOldFiel = context.Server.MapPath("~/App_File/Upload/");
      string strNewFiel = context.Server.MapPath("~/App_File/Cut/");
      string strOldUrl = Path.Combine(strOldFiel, str_url);
      string strNewUrl = Path.Combine(strNewFiel, "cut" + DateTime.Now.ToString("yyyyMMddHHmmss") + "." + str_url.Split('.')[1]);
      if (!Directory.Exists(strNewFiel))
      {
        Directory.CreateDirectory(strNewFiel);
      }
      int intStartX = int.Parse(strXone);
      int intStartY = int.Parse(strYone);
      int intWidth = int.Parse(strImgWidth);
      int intHeight = int.Parse(strImgHeight);
      CutGeneratedImage(intStartX, intStartY, intWidth, intHeight, strOldUrl, strNewUrl);
      context.Response.Write("{\"status\":0,\"message\":\"裁剪成功并保存!\"}");
    }
    catch
    {
      context.Response.Write("{\"status\":1,\"message\":\"裁剪失??!\"}");
    }
  }
  /// <summary>
  /// 裁剪圖片
  /// </summary>
  /// <param name="intWidth">要縮小裁剪圖片寬度</param>
  /// <param name="intHeight">要縮小裁剪圖片長度</param>
  /// <param name="strOldImgUrl">要處理圖片路徑</param>
  /// <param name="strNewImgUrl">處理完畢圖片路徑</param>
  public void CutGeneratedImage(int intStartX, int intStartY, int intWidth, int intHeight, string strOldImgUrl, string strNewImgUrl)
  {
    //上傳標準圖大小
    int intStandardWidth = 120;
    int intStandardHeight = 120;
 
    int intReduceWidth = 0; // 縮小的寬度
    int intReduceHeight = 0; // 縮小的高度
    int intCutOutWidth = 0; // 裁剪的寬度
    int intCutOutHeight = 0; // 裁剪的高度
    int level = 100; //縮略圖的質(zhì)量 1-100的范圍
    //獲得縮小,裁剪大小
    if (intStandardHeight * intWidth / intStandardWidth > intHeight)
    {
      intReduceWidth = intWidth;
      intReduceHeight = intStandardHeight * intWidth / intStandardWidth;
      intCutOutWidth = intWidth;
      intCutOutHeight = intHeight;
    }
    else if (intStandardHeight * intWidth / intStandardWidth < intHeight)
    {
      intReduceWidth = intStandardWidth * intHeight / intStandardHeight;
      intReduceHeight = intHeight;
      intCutOutWidth = intWidth;
      intCutOutHeight = intHeight;
    }
    else
    {
      intReduceWidth = intWidth;
      intReduceHeight = intHeight;
      intCutOutWidth = intWidth;
      intCutOutHeight = intHeight;
    }
    //通過連接創(chuàng)建Image對象
    //System.Drawing.Image oldimage = System.Drawing.Image.FromFile(strOldImgUrl);
    //oldimage.Save(Server.MapPath("tepm.jpg"));
    //oldimage.Dispose();
    //縮小圖片
    Bitmap bm = new Bitmap(strOldImgUrl);
    //處理JPG質(zhì)量的函數(shù)
    ImageCodecInfo[] codecs = ImageCodecInfo.GetImageEncoders();
    ImageCodecInfo ici = null;
    foreach (ImageCodecInfo codec in codecs)
    {
      if (codec.MimeType == "image/jpeg")
      {
        ici = codec;
        break;
      }
    }
    EncoderParameters ep = new EncoderParameters();
    ep.Param[0] = new EncoderParameter(System.Drawing.Imaging.Encoder.Quality, (long)level);
    //裁剪圖片
    Rectangle cloneRect = new Rectangle(intStartX, intStartY, intCutOutWidth, intCutOutHeight);
    PixelFormat format = bm.PixelFormat;
    Bitmap cloneBitmap = bm.Clone(cloneRect, format);
    //保存圖片
    cloneBitmap.Save(strNewImgUrl, ici, ep);
    bm.Dispose();
  }
  public bool IsReusable
  {
    get
    {
      return false;
    }
  }
}  

4、最后奉上Demo

  ImgJcrop

以上就是本文的全部內(nèi)容,希望本文的內(nèi)容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,同時也希望多多支持腳本之家!

相關(guān)文章

  • asp.net xml序列化與反序列化

    asp.net xml序列化與反序列化

    在.NET下有一種技術(shù)叫做對象序列化,它可以將對象序列化為二進制文件、XML文件、SOAP文件,這樣, 使用經(jīng)過序列化的流進行傳輸效率就得到了大大的提升。
    2008-08-08
  • 什么是JWT超詳細講解

    什么是JWT超詳細講解

    JWT(json?web?token),它并不是一個具體的技術(shù)實現(xiàn),而更像是一種標準,這篇文章主要介紹了什么是JWT及一些基本知識,需要的朋友可以參考下
    2022-12-12
  • ASP.NET Dictionary 的基本用法示例介紹

    ASP.NET Dictionary 的基本用法示例介紹

    ASP.NET中的Dictionary想必使用.net的朋友并不陌生吧,下面以示例的方式為大家介紹下其基本用法,感興趣的朋友可以參考下
    2014-01-01
  • ASP.NET中使用Ajax的方法

    ASP.NET中使用Ajax的方法

    之前在Ajax初步理解中介紹了對Ajax的初步理解,本文將介紹在ASP.NET中如何方便使用Ajax,第一種當然是使用jQuery的ajax,功能強大而且操作簡單方便,第二種是使用.NET封裝好的ScriptManager
    2013-10-10
  • asp.net中Response.Redirect與Server.Transfer的區(qū)別分析

    asp.net中Response.Redirect與Server.Transfer的區(qū)別分析

    一般來說如果需要在兩個頁面間共享數(shù)據(jù),而且數(shù)據(jù)量比較大的時候,用transfer會比較合適,在第二個頁面中可以直接使用前一頁面的數(shù)據(jù)。
    2010-10-10
  • 一篇文章教你如何排查.NET內(nèi)存泄漏

    一篇文章教你如何排查.NET內(nèi)存泄漏

    這篇文章主要給大家介紹了如何通過一篇文章教你排查 .NET 內(nèi)存泄漏的相關(guān)資料,.NET內(nèi)存泄漏,更準確的說應(yīng)該是對象超過生命周期而不能被GC回收,本文通過示例代碼介紹的非常詳細,需要的朋友可以參考下
    2021-09-09
  • asp.net圖片上傳生成縮略圖的注意事項

    asp.net圖片上傳生成縮略圖的注意事項

    asp.net圖片上傳生成縮略圖的注意事項...
    2007-09-09
  • asp.net 讀取并顯示excel數(shù)據(jù)的實現(xiàn)代碼

    asp.net 讀取并顯示excel數(shù)據(jù)的實現(xiàn)代碼

    Microsoft Office Excel是一個很好的電子表格應(yīng)用程序,在本文中,it同學會將教給你看到如何使用ASP.NET從Excel電子表格讀取并顯示顯示數(shù)據(jù)。
    2010-02-02
  • ASP.NET Core中如何利用多種方式給Action傳參

    ASP.NET Core中如何利用多種方式給Action傳參

    這篇文章主要給大家介紹了關(guān)于ASP.NET Core中如何利用多種方式給Action傳參的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-12-12
  • ASP.NET 在線文件管理

    ASP.NET 在線文件管理

    最近做了一個 在線文件管理程序,支持瀏覽服務(wù)器所有文件(不單單是站點的文件)。
    2009-11-11

最新評論