亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 網站 > WEB開發 > 正文

SWFUpload.js方法圖片的上傳和imgAreaselect.js方法圖片任意部位的截取

2024-04-27 15:09:06
字體:
來源:轉載
供稿:網友

SWFUpload.js方法圖片的上傳和imgAreaselect.js方法圖片任意部位的截取

第一部分:圖片上傳                 1.創建c#web窗體                 2.添加SWFUpload.js的文件引用                      引用文件如下:    <script src="../Scripts/swfupload/swfupload.js"></script>                                                      <script src="../Scripts/swfupload/swfupload.queue.js"></script>                                                      <script src="../Scripts/js/handlers.js"></script>

                       注意:handlers.js的引用不放在其他2個引用文件夾下,放在同一個文件夾不知道出了什么錯誤。

                  3.添加選擇圖片按鈕和顯示圖片布局

<body>    <form id="form1" runat="server">        <div><span id="spanButtonPlaceHolder"></span></div>        <div id="divFilePRogressContainer" style="height: 75px;"></div>        <img id="divphotoimage" />          </form></body>                   4.編寫圖片上傳js代碼
<script>  var swfu;        window.onload = function () {                                         swfu = new SWFUpload({                // Backend Settings                upload_url: "../Handler/test.ashx?cmd=upload",	//一般處理程序(帶參數)                post_params: {                    "aspSESSID": "<%=session.SessionID %>"      //參數(不知道干嘛)                },                // File Upload Settings                file_size_limit: "2048",	// 2MB          //文件大小                file_types: "*.jpg",                            //類型                file_types_description: "JPG Images",           //類型描述                file_upload_limit: "0",    // Zero means unlimited  //上傳限制                // Event Handler Settings - these functions as defined in Handlers.js                //  The handlers are not part of SWFUpload but are part of my website and control how                //  my website reacts to the SWFUpload events.                file_queue_error_handler: fileQueueError,                          file_dialog_complete_handler: fileDialogComplete,                upload_progress_handler: uploadProgress,                upload_error_handler: uploadError,                upload_success_handler: showimage,               //圖片顯示成功的調用的方法,showimage是方法                upload_complete_handler: uploadComplete,                // Button settings                button_image_url: "../Scripts/js/images/XPButtonNoText_160x22.png", //選擇圖片按鈕在這里設計                 button_width: "160",                button_height: "22",                button_placeholder_id: "spanButtonPlaceHolder",                     //在哪里顯示(占位符)                button_text: '<span class="theFont">選擇文件</span>',               //按鈕顯示文字內容                button_text_style: ".theFont { font-size: 13;}",                button_text_left_padding: 12,                button_text_top_padding: 3,                // Flash Settings                flash_url: "../Scripts/swfupload/swfupload.swf",	// Relative to this file  swfupload.swf需要添加到引用的文件夾下                custom_settings: {                    upload_target: "divFileProgressContainer"           //圖片上傳成功的信息內容                },                // Debug Settings                debug: false            });        }
        //圖片上傳成功后
        function showimage(file, serverData) {                 //serverData是一般處理程序返回的文件上傳的圖片路徑            $("#divphotoimage").attr("src", serverData);                      }</script>

                        5.后臺處理                         

    #region 上傳圖片

        private void fileuloadimage(HttpContext context)

        {

            HttpPostedFile file = context.Request.Files[0];

            string filename = Path.GetFileName(file.FileName);

            string fileXect = Path.GetExtension(filename);

            string filepath = context.Request.MapPath("/uploadimage/") + filename;

            file.SaveAs(filepath);

            context.Response.Write("/uploadimage/" + filename);

        }

        #endregion

                        6.SWFUpload.js的下載鏈接:http://pan.baidu.com/s/1mi8trVq 密碼:xjbq

第二部分:圖片截取

                            1、下載imgAreaselect.js 鏈接:http://pan.baidu.com/s/1eR2jFgA 密碼:dcnr

                            2、 完整引用如下

                              <link href="../imgAreaSelect/imgareaselect-default.CSS" rel="stylesheet" />

    <script src="../Scripts/ui/jquery-1.4.2.js"></script>

    <script src="../imgAreaSelect/jquery.imgareaselect.min.js"></script>

    <script src="../Scripts/swfupload/swfupload.js"></script>

    <script src="../Scripts/swfupload/swfupload.queue.js"></script>

    <script src="../Scripts/js/handlers.js"></script>

3、界面布局

  <form id="form1" runat="server">        <div><span id="spanButtonPlaceHolder"></span></div>        <div id="divFileProgressContainer" style="height: 75px;"></div>        <img id="divphotoimage" />        <input id="imagecut" type="button" value="圖像截取" />        <input type="hidden" id="imgsrc" />        <br />        <img id="cutnewimage" />    </form>4、圖片上傳成功后顯示一個截取的圖片框
 function showimage(file, serverData) {            $("#divphotoimage").attr("src", serverData);
            //將圖片給了img后就會觸發該事件,理解為創建一個div (0,0)左上角 (250,250)右下角 onSelectEnd為事件:選擇要截圖的圖片后            $("#divphotoimage").imgAreaSelect({ selectionColor: 'bule', x1: 0, y1: 0, x2: 250, y2: 250, seclectionOpacity: 0.2, onSelectEnd: preview });            $("#imgsrc").val(serverData);  //將圖片路徑給隱藏域,在js里面最好不要使用全局變量,以后要用到圖片路徑        }5、圖片截取成功后數據的保存
  function preview(img, selection) {
            //存取圖片的x、y坐標和寬度高度            $("#divphotoimage").data('x', selection.x1);            $("#divphotoimage").data('y', selection.y1);            $("#divphotoimage").data('w', selection.width);            $("#divphotoimage").data('h', selection.height);        }6.參數的取出方法和傳遞給一般處理程序的方法
 $(function () {
            //點擊圖片截取按鈕觸發的事件            $("#imagecut").click(function () {
                var pars = {     //傳遞的參數                    x: $("#divphotoimage").data('x'),                    y: $("#divphotoimage").data('y'),                    width: $("#divphotoimage").data('w'),                    height: $("#divphotoimage").data('h'),                    imgsrc: $("#imgsrc").val(),                    cmd: "cut"                };                $.post("../Handler/test.ashx", pars, function (data) {  //一般處理程序請求的方法                    $("#cutnewimage").attr("src", data);                //將截取成功的圖片顯示出來                });            })        })7、后臺將傳遞的參數也是就截取的圖片畫出來,保存起來

  #region 截取圖片        private void cutuploadimage(HttpContext context)        {            int x = Convert.ToInt32(context.Request["x"]);            int y = Convert.ToInt32(context.Request["y"]);            int width = Convert.ToInt32(context.Request["width"]);            int height = Convert.ToInt32(context.Request["height"]);            string imgsrc = context.Request["imgsrc"];            Bitmap map = new Bitmap(width, height);        //創建畫布            Graphics g = Graphics.FromImage(map);          //創建畫筆            Image img = Image.FromFile(context.Request.MapPath(imgsrc)); //原始圖片
            //將原圖的指定范圍畫到畫布上            //第一個img參數,表示對哪張圖進行操作            //第二個參數,畫多么大            //第三個參數,畫多大的區域            //GraphicsUnit.Pixel像素單位 g.DrawImage(img, new Rectangle(0, 0, width, height), new Rectangle(x, y, width, height), GraphicsUnit.Pixel); string filecutname = Guid.NewGuid().ToString(); string fullDir = "/uploadimage/" + filecutname + ".jpg"; map.Save(context.Request.MapPath(fullDir), System.Drawing.Imaging.ImageFormat.Jpeg); context.Response.Write(fullDir); } #endregion

       第三部分:完整的demo

         前臺代碼:

<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="text.aspx.cs" Inherits="ebook.Pages.text" %>

<!DOCTYPE html>

<html xmlns="http://www.w3.org/1999/xhtml">

<head runat="server">

    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />

    <title></title>

    <link href="../imgAreaSelect/imgareaselect-default.css" rel="stylesheet" />

    <script src="../Scripts/ui/jquery-1.4.2.js"></script>

    <script src="../imgAreaSelect/jquery.imgareaselect.min.js"></script>

    <script src="../Scripts/swfupload/swfupload.js"></script>

    <script src="../Scripts/swfupload/swfupload.queue.js"></script>

    <script src="../Scripts/js/handlers.js"></script>

    <script>

        var swfu;

        window.onload = function () {

            swfu = new SWFUpload({

                // Backend Settings

                upload_url: "../Handler/test.ashx?cmd=upload",	// Relative to the SWF file

                post_params: {

                    "ASPSESSID": "<%=Session.SessionID %>"

                },

                // File Upload Settings

                file_size_limit: "2048",	// 2MB

                file_types: "*.jpg",

                file_types_description: "JPG Images",

                file_upload_limit: "0",    // Zero means unlimited

                // Event Handler Settings - these functions as defined in Handlers.js

                //  The handlers are not part of SWFUpload but are part of my website and control how

                //  my website reacts to the SWFUpload events.

                file_queue_error_handler: fileQueueError,

                file_dialog_complete_handler: fileDialogComplete,

                upload_progress_handler: uploadProgress,

                upload_error_handler: uploadError,

                upload_success_handler: showimage,

                upload_complete_handler: uploadComplete,

                // Button settings

                button_image_url: "../Scripts/js/images/XPButtonNoText_160x22.png", // Relative to the Flash file

                button_width: "160",

                button_height: "22",

                button_placeholder_id: "spanButtonPlaceHolder",

                button_text: '<span class="theFont">選擇文件</span>',

                button_text_style: ".theFont { font-size: 13;}",

                button_text_left_padding: 12,

                button_text_top_padding: 3,

                // Flash Settings

                flash_url: "../Scripts/swfupload/swfupload.swf",	// Relative to this file

                custom_settings: {

                    upload_target: "divFileProgressContainer"

                },

                // Debug Settings

                debug: false

            });

        }

        function showimage(file, serverData) {

            $("#divphotoimage").attr("src", serverData);

            $("#divphotoimage").imgAreaSelect({ selectionColor: 'bule', x1: 0, y1: 0, x2: 250, y2: 250, seclectionOpacity: 0.2, onSelectEnd: preview });

            $("#imgsrc").val(serverData);

        }

        //確定出要截取圖像的方位數據參數

        function preview(img, selection) {

            $("#divphotoimage").data('x', selection.x1);

            $("#divphotoimage").data('y', selection.y1);

            $("#divphotoimage").data('w', selection.width);

            $("#divphotoimage").data('h', selection.height);

        }

        $(function () {

            $("#imagecut").click(function () {

                var pars = {

                    x: $("#divphotoimage").data('x'),

                    y: $("#divphotoimage").data('y'),

                    width: $("#divphotoimage").data('w'),

                    height: $("#divphotoimage").data('h'),

                    imgsrc: $("#imgsrc").val(),

                    cmd: "cut"

                };

                $.post("../Handler/test.ashx", pars, function (data) {

                    $("#cutnewimage").attr("src", data);

                });

            })

        })

    </script>

</head>

<body>

    <form id="form1" runat="server">

        <div><span id="spanButtonPlaceHolder"></span></div>

        <div id="divFileProgressContainer" style="height: 75px;"></div>

        <img id="divphotoimage" />

        <input id="imagecut" type="button" value="圖像截取" />

        <input type="hidden" id="imgsrc" />

        <br />

        <img id="cutnewimage" />

    </form>

</body>

</html>

后臺代碼:

using System;using System.Collections.Generic;using System.Drawing;using System.Drawing.Drawing2D;using System.Drawing.Imaging;using System.IO;using System.Linq;using System.Web;namespace ebook.Handler{    /// <summary>    /// test 的摘要說明    /// </summary>    public class test : IHttpHandler    {        public void ProcessRequest(HttpContext context)        {            context.Response.ContentType = "text/plain";            string str = context.Request["cmd"];            if (str == "upload")            {                fileuploadimage(context);            }            else if (str == "cut")            {                cutuploadimage(context);            }        }        #region 截取圖片        private void cutuploadimage(HttpContext context)        {            int x = Convert.ToInt32(context.Request["x"]);            int y = Convert.ToInt32(context.Request["y"]);            int width = Convert.ToInt32(context.Request["width"]);            int height = Convert.ToInt32(context.Request["height"]);            string imgsrc = context.Request["imgsrc"];            Bitmap map = new Bitmap(width, height);            Graphics g = Graphics.FromImage(map);            Image img = Image.FromFile(context.Request.MapPath(imgsrc));            g.DrawImage(img, new Rectangle(0, 0, width, height), new Rectangle(x, y, width, height), GraphicsUnit.Pixel);            string filecutname = Guid.NewGuid().ToString();            string fullDir = "/uploadimage/" + filecutname + ".jpg";            map.Save(context.Request.MapPath(fullDir), System.Drawing.Imaging.ImageFormat.Jpeg);            context.Response.Write(fullDir);        }        #endregion        #region 上傳圖片        private void fileuploadimage(HttpContext context)        {            HttpPostedFile file = context.Request.Files[0];            string filename = Path.GetFileName(file.FileName);            string filejpg = Path.GetExtension(filename);            string guid = Guid.NewGuid().ToString();            string Dir = "/uploadimage/" + filename + guid + filejpg;            file.SaveAs(context.Request.MapPath(Dir));            context.Response.Write(Dir);        }        #endregion        public bool IsReusable        {            get            {                return false;            }        }    }}

                   
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
成人黄色生活片| 国产日韩欧美夫妻视频在线观看| 欧美性猛交xxxx富婆弯腰| 国内精品小视频在线观看| 亚洲精品第一页| 亚洲精品美女久久久久| 久久久中文字幕| 国产精品成人一区二区| 亚洲欧美日韩在线高清直播| 成人午夜激情免费视频| 精品久久久久久亚洲精品| 久久久久久久久中文字幕| 亚洲精品女av网站| 日韩精品免费看| 日韩av免费在线播放| 中文字幕不卡在线视频极品| 最新中文字幕亚洲| 国产91色在线播放| 日韩成人在线视频观看| 91理论片午午论夜理片久久| 97国产精品人人爽人人做| 欧美疯狂xxxx大交乱88av| 成人春色激情网| 久久久久久91| 成人免费网站在线| 亚洲免费av电影| 成人在线免费观看视视频| 国产成人午夜视频网址| 日韩在线视频一区| 国产极品jizzhd欧美| 久久久亚洲福利精品午夜| 欧美激情精品久久久久久蜜臀| 亚洲2020天天堂在线观看| 欧美成人午夜免费视在线看片| 国产日韩欧美电影在线观看| 欧美成人午夜激情视频| 国产一区二区三区在线播放免费观看| 欧美放荡办公室videos4k| 成人性生交大片免费观看嘿嘿视频| 国产亚洲精品美女久久久久| 欧美一区二区三区四区在线| 色婷婷av一区二区三区久久| 亚洲国产日韩欧美综合久久| 国产免费成人av| 亚洲精品女av网站| 国产精品久久在线观看| 久久亚洲成人精品| 欧美大全免费观看电视剧大泉洋| 国产精品亚洲激情| 中文字幕在线日韩| 国产一区视频在线播放| 欧美xxxx14xxxxx性爽| 欧美亚洲日本黄色| 欧美老妇交乱视频| 疯狂做受xxxx高潮欧美日本| 久久精品91久久香蕉加勒比| 日韩亚洲精品电影| 狠狠爱在线视频一区| 久久理论片午夜琪琪电影网| 正在播放国产一区| 亚洲国产中文字幕在线观看| 亚洲女同精品视频| 91丝袜美腿美女视频网站| 欧美性jizz18性欧美| 亚洲а∨天堂久久精品9966| 成人h猎奇视频网站| 91精品国产高清久久久久久91| 国产亚洲人成网站在线观看| 国产婷婷97碰碰久久人人蜜臀| 91精品视频一区| 国产91精品久久久| 久久久久中文字幕2018| 日韩av在线天堂网| 日韩在线小视频| 日韩av手机在线观看| 日韩一区二区在线视频| 九九热这里只有精品免费看| 免费不卡在线观看av| 亚洲第一区在线观看| 亚洲欧美一区二区精品久久久| 久国内精品在线| 欧美俄罗斯性视频| 一区二区亚洲欧洲国产日韩| 亚洲精品一区二区久| 欧美亚洲第一区| 欧美激情精品久久久久久大尺度| 亚洲美女精品成人在线视频| 国产欧美一区二区| 亚洲精品一区二三区不卡| 国产精品视频午夜| 亚洲free性xxxx护士hd| 欧美成人精品影院| 亚洲国产精品成人va在线观看| 成人精品aaaa网站| 亚洲男人天天操| 国内精品免费午夜毛片| 深夜成人在线观看| 欧美黑人极品猛少妇色xxxxx| 日本国产高清不卡| 57pao精品| 日韩欧美国产成人| 国产精品久久中文| 日韩av一区在线观看| 91久久夜色精品国产网站| 日韩免费黄色av| 欧美黑人xxxⅹ高潮交| 国产精品高潮呻吟久久av野狼| 狠狠躁夜夜躁人人爽天天天天97| 26uuu另类亚洲欧美日本老年| 最近中文字幕2019免费| 在线视频欧美日韩精品| 精品人伦一区二区三区蜜桃网站| 95av在线视频| 欧美黑人xxxⅹ高潮交| 国产z一区二区三区| 精品视频一区在线视频| 欧美俄罗斯乱妇| www.亚洲免费视频| 国产国语videosex另类| 国产精品美女无圣光视频| 久久这里只有精品视频首页| 欧美性受xxx| 国模私拍视频一区| 亚洲色图激情小说| 曰本色欧美视频在线| 黑人巨大精品欧美一区二区一视频| 亚洲性夜色噜噜噜7777| 亚洲成人在线网| 国产精品久久久久久久久久尿| 中文字幕久热精品视频在线| 国产欧美一区二区三区四区| 久久久久久午夜| 91精品综合久久久久久五月天| 国产精品精品久久久| 欧美视频13p| 美女精品视频一区| 国产xxx69麻豆国语对白| 国产成人欧美在线观看| 国产91精品久久久久| 久久久国产精品亚洲一区| 成人久久18免费网站图片| 久久久久久高潮国产精品视| 精品亚洲男同gayvideo网站| 成人a级免费视频| 日韩风俗一区 二区| 日韩大片在线观看视频| 国产成人久久久精品一区| 日韩在线免费视频观看| 国产精品视频999| 亚洲天堂第一页| 亚洲国产精品福利| 亚洲成人精品久久久| 久久国产精品99国产精| 一区二区欧美日韩视频| 中文字幕欧美日韩| 亚洲大胆人体视频| 亚洲日本aⅴ片在线观看香蕉| 欧美激情精品久久久久久大尺度| 国产福利精品在线| 在线成人中文字幕| 亚洲综合第一页| 亚洲国产欧美一区二区三区同亚洲| 亚洲男人7777| 欧美理论片在线观看|