flash在线拍照并上传(ASP.NET)

最近项目需要一个拍照的功能,在网上搜了好久都没有一些很好的解决方法,有人提供了,但不太全,这里我选贴出我参照的URL(http://www.aspstat.com/69), 我将它综合了其它一些代码, 用flash8做了一个. 代码如下:

 

var my_cam:Camera = Camera.get();

var my_video:Video;

my_video.attachVideo(my_cam);

var camera_lbl:mx.controls.Label;

var cameras_cb:mx.controls.ComboBox;

camera_lbl.text = my_cam.name;

cameras_cb.dataProvider = Camera.names;

function changeCamera():Void {

    my_cam = Camera.get(cameras_cb.selectedIndex);

    my_video.attachVideo(my_cam);

    camera_lbl.text = my_cam.name;

}

cameras_cb.addEventListener("change", changeCamera);

camera_lbl.setStyle("fontSize", 9);

cameras_cb.setStyle("fontSize", 9);



//init variable    

photow = new Number(50);    

photoh = new Number(50);

my_cam.setMode(photow, photoh, 10, true);



//该对象用于实现发送数据到网页可get或post    

var lv:LoadVars;    

lv = new LoadVars(); 



btnSavePic.onRelease = function()

{      

    saveCamera();    

	//getURL("http://localhost/CaptureAndSignatureWebApp/pageb.aspx", "_blank", "GET");

} 



function saveCamera()

{     

    //新建一个bitmapdate对象并获取video上的图像信息    

    lv.bm = new flash.display.BitmapData(photow, photoh,true, 0);       

    lv.bm.draw(my_video);     

    //photoPreview是在场景中的一个Movie clip实例,用于输出bitmapdate实现照片预缆    

    photoPreview.attachBitmap(lv.bm, 1);

	photoPreview._width=50;

	photoPreview._height=50;

	trace(lv.bm.height);    

    trace(lv.bm.width); 

	//getURL("http://www.macromedia.com", "_blank", "GET");

}



btnUpload.onRelease = function()

{

	SendPic();

}



btn1.onRelease = function()

{

	SendPic2();

}



function SendPic2()

{

	getURL("http://localhost/CaptureAndSignatureWebApp/pageb.aspx?aa=aabb", "_blank", "GET");

}



function SendPic()

{

    //loading._visible =true;    

	//getURL("http://localhost/CaptureAndSignatureWebApp/pageb.aspx?aa=aabb", "_blank", "GET");

	

    //读取图片矩形范围的像素信息,并以字符串的形式连接起来 begin    

    i = lv.bm.height;    

	trace("i: " + i.toString());

    j = lv.bm.width; 

	trace("j: " + j.toString());

	//trace("a: " + i.toString());

	//trace("b: " + j.toString());

    rgb_array = "";    

    for (var m = i - 1; m >= 0; m--)    

	//for (y = 10 - 1; y >= 0; y--)    

    {   

		trace(rgb_array);

        for (var n = 0; n < j; n ++)    

		//for (x = 0; x < 10; x++)

        {   

			trace("m: " + m.toString());

			trace("n: " + n.toString());

            color = lv.bm.getPixel(m, n).toString(16);    

			trace(color);

			trace(rgb_array);

            rgb_array = rgb_array + (color + ",");    

        } // end of for  

		

		//trace(rgb_array);

    } // end of for    

    lv.height = i;    

    lv.width = j;    

    lv.rgb_array = rgb_array;    

	camera_lbl.text = rgb_array;

	getURL("http://localhost/CaptureAndSignatureWebApp/pageb.aspx?passVal=1", "_blank", "POST");    

    //读取图片矩形范围的像素信息,并以字符串的形式连接起来 end    



	//getURL("javascript:alert('Step_1')"); 

    //发送到要处理的页面URL,可以在页面通过Request.Form["名称"]获取值,如:Request.Form["rgb_array"]    

    //lv.sendAndLoad("http://localhost/CaptureAndSignatureWebApp/pageb.aspx", lv, "POST");    

   

    //当页面返回信息即页面处理完成后,触发的行为     

	/*

    lv.onLoad = function (success)    

    {    

        if (success)    

        {    

            //跳转到其他页面    

            getURL("http://localhost/CaptureAndSignatureWebApp/pageb.aspx", "_self");    

        }

		else

		{

			getURL("javascript:alert('Not Success')");   

		}

    }

	*/

}
 
ASP.net的源代码如下:
using System;

using System.Data;

using System.Configuration;

using System.Collections;

using System.Web;

using System.Web.Security;

using System.Web.UI;

using System.Web.UI.WebControls;

using System.Web.UI.WebControls.WebParts;

using System.Web.UI.HtmlControls;



using System.Drawing;



namespace CaptureAndSignatureWebApp

{

    public partial class pageb : System.Web.UI.Page

    {

        protected void Page_Load(object sender, EventArgs e)

        {

            //string[] rgbArray = new string[] { Request.Form["rgb_array"] };

            //this.DrawImageFromFlashUploader(240, 140, rgbArray).Save("images/1.bmp");

            //this.Image1.ImageUrl = "images/1.bmp";



        }



        protected override void OnPreInit(EventArgs e)

        {

            base.OnPreInit(e);



            string ss = "";

            if (Request.Form.Count > 0)

            {

                //ss = Request.QueryString["passVal"];

                ss = Request.Form["rgb_array"];

                this.Label1.Text = ss;



                string[] rgbArray = ss.Split(new char[] { ',' });

                this.DrawImageFromFlashUploader(50, 50, rgbArray).Save(@"E:/Work/ODMS/SCAAS/技术难点/CaptureAndSignatureWebApp/CaptureAndSignatureWebApp/images/1.bmp");

                //this.Image1.ImageUrl = @"~E:/Work/ODMS/SCAAS/技术难点/CaptureAndSignatureWebApp/CaptureAndSignatureWebApp/images/1.bmp";

                this.IMG1.Src = @"images/1.bmp";

            }

        }



        public System.Drawing.Bitmap DrawImageFromFlashUploader(int width, int height, string[] rgbArray)

        {

            System.Drawing.Bitmap bm = new System.Drawing.Bitmap(width, height, System.Drawing.Imaging.PixelFormat.Format32bppRgb);

            int pos = 0;

            for (int i = bm.Height - 1; i >= 0; i--)

            {

                for (int j = 0; j < bm.Width; j++)

                {

                    bm.SetPixel(j, i, System.Drawing.Color.FromArgb(int.Parse(rgbArray[pos], System.Globalization.NumberStyles.HexNumber)));

                    pos++;

                }

            }



            return bm;

        }   



    }

}

希望看到这贴子的人,对你有帮助, 我干脆也打包上传算了

 

 

假如action script里有标签或按钮要实现多语言,可以在装载这个flash的c#的页面里,定义一个javascript变量, 如
var FLASHBTNSAVETEXT = '<%=this.GetLabel("COM_Confirm")%>';
可在action script的root中直接引用.
  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 10
    评论
逐个模块给出以下说明: 一个用户只能在同一时间登陆一次,需要经过电脑ip验证,用户名和密码验证,全部通过才可以进入首页。 用户登录:首先进入首页,显示该用户今天上传的图片。 1.查看图片:显示该用 户上传的所有图片,显示内容:图像描述,图像大小,是否验证,上传时间,查看,删除 2.上传图片:用户可以上传图片,在上传时有预览的功能,如果数据库中已存在上传过的照片,则提醒用户已上传,否则进入等待验证页面,等待后台验证,若验证成功则显示上传的图像,如果失败则提醒用户是否继续等待验证 3.修改口令:用户可以修改自己的密码 4.退出系统:用户退出当前系统,注销 5.团队简介和客户服务主要是显示团队介绍和联系方式 管理员登陆:进入首页,显示今天上传的所有图片,显示内容:编号,id,图像描述,图像大小,是否验证,上传用户,ip,上传时间,查看,删除 1.查看用户:显示用户名,密码,增加时间,上传几张图片,删除 2.增加用户:包括用户名,密码 3.查找用户:根据输入的用户名进行模糊查询,显示内容:用户名,密码,添加时间,上传几张图片,删除 4.查看所有图片:显示编号,id,图像描述,图像大小,是否验证,上传用户,ip,上传时间,查看,操作,其中id,图像描述,图像大小,是否验证,上传用户,ip,上传时间字段具有排序功能 5.查找图片:可以根据用户名和上传日期进行查询 6.查看节点:显示IP地址,删除 7.增加节点:输入客户端的ip地址进行添加 8.退出系统:进行注销 9.团队简介和客户服务:主要是显示团队介绍和联系方式
评论 10
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值