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

首頁 > 開發 > Flex > 正文

flex 手寫在線簽名實現代碼第1/2頁

2024-09-12 17:51:26
字體:
來源:轉載
供稿:網友
在線手寫簽名分兩部份。第一部分是畫圖功能的實現,第二部份是上傳圖片的功能(上傳到服務器或保存到本地)。
畫圖:畫圖比較簡單,只要用到了graphics對像的幾個方法。當鼠標按下時,調用graphics的beginFill和moveTo方法。同時,還要把調用了lineTo的方法加入到鼠標的MOUSE_MOVE事件中。代碼如下:
Actionscript代碼
復制代碼 代碼如下:

package com.humanmonth.home.component.page.signature
{
import flash.display.CapsStyle;
import flash.display.JointStyle;
import flash.display.LineScaleMode;
import flash.events.MouseEvent;
import mx.containers.Canvas;
import mx.core.UIComponent;
/**
* 實現手寫簽名的白板
* @author presses
*
*/
public class WriteArea extends Canvas
{
/**
*筆
*/
public var signature:UIComponent=new UIComponent();
/**
*顏色
*/
public var myColor:uint=0x000000 ;
/**
*線條粗細
*/
public var lineSize:int=1 ;
/**
*模式
*/
public var pattern:String="圓珠筆";
/**
*當前的x座標
*/
private var cX:Number;
/**
*當前的y座標
*/
private var cY:Number;
public function WriteArea()
{
this.addChild(signature);
this.addEventListener(MouseEvent.MOUSE_DOWN,beginDraw);
this.addEventListener(MouseEvent.MOUSE_UP,endDraw);
}
/**
*鼠標壓下時,開始畫圖,并添加移動鼠標畫線的監聽器
*/
private function beginDraw(event:MouseEvent):void{
this.signature.graphics.lineStyle(lineSize,myColor,1 ,true,LineScaleMode.NONE,CapsStyle.ROUND,JointStyle.ROUND, 99 );
this.signature.graphics.beginFill(myColor);
this.cX=event.localX;
this.cY=event.localY;
this.signature.graphics.moveTo(this.cX,this.cY);
this.addEventListener(MouseEvent.MOUSE_MOVE,drawIng);
}
/**
* 鼠標移動時,畫線
*/
private function drawIng(event:MouseEvent):void{
if(this.pattern=="圓珠筆"){
this.signature.graphics.moveTo(this.cX,this.cY);
}
this.signature.graphics.lineTo(event.localX,event.localY);
this.cX=event.localX;
this.cY=event.localY;
}
/**
* 結束畫圖
*/
private function endDraw(event:MouseEvent):void{
this.removeEventListener(MouseEvent.MOUSE_MOVE,drawIng);
}
}
}
package com.humanmonth.home.component.page.signature
{
    import flash.display.CapsStyle;
    import flash.display.JointStyle;
    import flash.display.LineScaleMode;
    import flash.events.MouseEvent;

    import mx.containers.Canvas;
    import mx.core.UIComponent;

    /**
     * 實現手寫簽名的白板
     * @author presses
     *
     */
    public class WriteArea extends Canvas
    {
        /**
         *筆
         */
        public var signature:UIComponent=new UIComponent();
        /**
         *顏色
         */
        public var myColor:uint=0x000000;
        /**
         *線條粗細
         */
        public var lineSize:int=1;
        /**
         *模式
         */
        public var pattern:String="圓珠筆";
        /**
         *當前的x座標
         */
        private var cX:Number;
        /**
         *當前的y座標
         */
        private var cY:Number;

        public function WriteArea()
        {
            this.addChild(signature);
            this.addEventListener(MouseEvent.MOUSE_DOWN,beginDraw);
            this.addEventListener(MouseEvent.MOUSE_UP,endDraw);
        }

        /**
         *鼠標壓下時,開始畫圖,并添加移動鼠標畫線的監聽器
         */
        private function beginDraw(event:MouseEvent):void{
            this.signature.graphics.lineStyle(lineSize,myColor,1,true,LineScaleMode.NONE,CapsStyle.ROUND,JointStyle.ROUND,99);
            this.signature.graphics.beginFill(myColor);
            this.cX=event.localX;
            this.cY=event.localY;
            this.signature.graphics.moveTo(this.cX,this.cY);
            this.addEventListener(MouseEvent.MOUSE_MOVE,drawIng);
        }

        /**
         * 鼠標移動時,畫線
         */
        private function drawIng(event:MouseEvent):void{
            if(this.pattern=="圓珠筆"){
                this.signature.graphics.moveTo(this.cX,this.cY);
            }
            this.signature.graphics.lineTo(event.localX,event.localY);
            this.cX=event.localX;
            this.cY=event.localY;
        }

        /**
         * 結束畫圖
         */
        private function endDraw(event:MouseEvent):void{
            this.removeEventListener(MouseEvent.MOUSE_MOVE,drawIng);
        }

    }
}

上傳簽名圖片(上傳到服務器或保存到本地):fp10(flash player)可以不經服務器,直接把圖片保存到本地。但為了兼容fp9,這里的實現是先把圖片上傳到服務器,再調用下載功能。實現的思路是先把畫圖的組件轉化為BitmapData,然后再編碼成jpeg格式,并上傳到服務器。最后調用客戶端下載。這里要注意的一點是,fp10對下載的api作了限制,下載動作只能由用戶觸發。代碼如下:
Actionscript代碼
復制代碼 代碼如下:

package com.humanmonth.home.component.page.signature.remote
{
import com.humanmonth.global.Config;
import flash.display.BitmapData;
import flash.events.Event;
import flash.net.FileReference;
import flash.net.URLLoader;
import flash.net.URLRequest;
import flash.net.URLRequestMethod;
import mx.controls.Alert;
import mx.graphics.codec.JPEGEncoder;
import mx.managers.CursorManager;
/**
* 圖片的上傳及下載
* @author presses
*
*/
public class Connector
{
private var file:FileReference;
private var myId:String;
public function Connector()
{
}
/**
* 保存圖片
*/
public function savePic(myData:BitmapData,fun:Function):void{
CursorManager.setBusyCursor();
var url:String=Config.picLink+"rea/pic.do?action=savePic&timestamp="+new Date().getTime();
var request:URLRequest = new URLRequest(url);
request.method=URLRequestMethod.POST;
request.contentType = "application/octet-stream";
request.data=new JPEGEncoder(80 ).encode(myData);
var loader:URLLoader = new URLLoader();
loader.load(request) ;
loader.addEventListener(Event.COMPLETE, fun) ;
loader.addEventListener(Event.COMPLETE,initMyId);
Alert.show("正在上傳圖片,等待數秒后,即可下載圖片");
}
private function initMyId(event:Event):void{
CursorManager.removeBusyCursor();
var loader:URLLoader=URLLoader(event.target);
this.myId=loader.data;
Alert.show("上傳圖片成功,現在可以點擊‘下載圖片'按鈕,保存圖片到本地。");
}
/**
* 下載圖片
*/
public function downloadFile(event:Event):void{
var url2:String=Config.picLink+"rea/pic.do?action=queryPicById&pid="+myId+"&timestamp="+new Date().getTime();
var req:URLRequest=new URLRequest(url2);
file=new FileReference();
file.download(req,"humanmonth.jpg");
}
}
}
package com.humanmonth.home.component.page.signature.remote
{
    import com.humanmonth.global.Config;

    import flash.display.BitmapData;
    import flash.events.Event;
    import flash.net.FileReference;
    import flash.net.URLLoader;
    import flash.net.URLRequest;
    import flash.net.URLRequestMethod;

    import mx.controls.Alert;
    import mx.graphics.codec.JPEGEncoder;
    import mx.managers.CursorManager;

    /**
     * 圖片的上傳及下載
     * @author presses
     *
     */
    public class Connector
    {
        private var file:FileReference;
        private var myId:String;
        public function Connector()
        {
        }

        /**
         * 保存圖片
         */
        public function savePic(myData:BitmapData,fun:Function):void{
         CursorManager.setBusyCursor();
            var url:String=Config.picLink+"rea/pic.do?action=savePic&timestamp="+new Date().getTime();
            var request:URLRequest = new URLRequest(url);             
            request.method=URLRequestMethod.POST;
             request.contentType = "application/octet-stream";
            request.data=new JPEGEncoder(80).encode(myData);
var loader:URLLoader = new URLLoader();
loader.load(request) ;
loader.addEventListener(Event.COMPLETE, fun) ;     
loader.addEventListener(Event.COMPLETE,initMyId);
Alert.show("正在上傳圖片,等待數秒后,即可下載圖片");        
        }

        private function initMyId(event:Event):void{
         CursorManager.removeBusyCursor();
            var loader:URLLoader=URLLoader(event.target);
            this.myId=loader.data;
            Alert.show("上傳圖片成功,現在可以點擊‘下載圖片'按鈕,保存圖片到本地。");

        }

        /**
         * 下載圖片
         */
        public function downloadFile(event:Event):void{
            var url2:String=Config.picLink+"rea/pic.do?action=queryPicById&pid="+myId+"&timestamp="+new Date().getTime();
            var req:URLRequest=new URLRequest(url2);
            file=new FileReference();
            file.download(req,"humanmonth.jpg");
        }
    }
}

Actionscript代碼
復制代碼 代碼如下:

package com.humanmonth.home.component.page.signature
{
import com.humanmonth.home.component.page.signature.remote.Connector;
import flash.display.BitmapData;
import flash.events.Event;
import flash.events.MouseEvent;
import mx.core.Application;
import mx.events.ColorPickerEvent;
import mx.events.FlexEvent;
import mx.events.ListEvent;
import mx.events.NumericStepperEvent;
/**
* 控制面版
* @author presses
*
*/
public class MyControlBarAs extends MyControlBar
{
public var writearea:WriteArea;
private var connector:Connector=new Connector();
public function MyControlBarAs()
{
super();
this.addEventListener(FlexEvent.CREATION_COMPLETE,myInit);
}
private function myInit(event:Event):void{
this.writearea=Application.application.signature.writearea;
this.reset.addEventListener(MouseEvent.CLICK,cleanArea);
this.size.addEventListener(NumericStepperEvent.CHANGE,setLineSize);
this.color.addEventListener(ColorPickerEvent.CHANGE,setColor);
this.pattern.addEventListener(ListEvent.CHANGE,setPattern);
this.savePic.addEventListener(MouseEvent.CLICK,savePicture);
this.downloadPic.addEventListener(MouseEvent.CLICK,connector.downloadFile)
}
/**
* 保存圖片
*/
private function savePicture(event:Event):void{
var myData:BitmapData=new BitmapData(this.writearea.width,this.writearea.height);
myData.draw(this.writearea);
connector.savePic(myData,enableDownload);
}
private function enableDownload(event:Event):void{
this.downloadPic.enabled=true;
}
/**
* 設置模式
*/
private function setPattern(event:Event):void{
this.writearea.pattern=String(this.pattern.value);
}
/**
* 清空寫字區
*/
private function cleanArea(event:Event):void{
this.writearea.signature.graphics.clear();
}
/**
* 設置線條粗細
*/
public function setLineSize(event:Event):void{
this.writearea.lineSize=this.size.value;
}
/**
* 設置顏色
*/
public function setColor(event:Event):void{
this.writearea.myColor=uint(this.color.value);
}
}
}
package com.humanmonth.home.component.page.signature
{
    import com.humanmonth.home.component.page.signature.remote.Connector;

    import flash.display.BitmapData;
    import flash.events.Event;
    import flash.events.MouseEvent;

    import mx.core.Application;
    import mx.events.ColorPickerEvent;
    import mx.events.FlexEvent;
    import mx.events.ListEvent;
    import mx.events.NumericStepperEvent;

    /**
     * 控制面版
     * @author presses
     *
     */
    public class MyControlBarAs extends MyControlBar
    {
        public var writearea:WriteArea;
        private var connector:Connector=new Connector();
        public function MyControlBarAs()
        {
            super();
            this.addEventListener(FlexEvent.CREATION_COMPLETE,myInit);
        }

        private function myInit(event:Event):void{
            this.writearea=Application.application.signature.writearea;
            this.reset.addEventListener(MouseEvent.CLICK,cleanArea);
            this.size.addEventListener(NumericStepperEvent.CHANGE,setLineSize);
            this.color.addEventListener(ColorPickerEvent.CHANGE,setColor);
            this.pattern.addEventListener(ListEvent.CHANGE,setPattern);
            this.savePic.addEventListener(MouseEvent.CLICK,savePicture);
            this.downloadPic.addEventListener(MouseEvent.CLICK,connector.downloadFile)
        }
        /**
         * 保存圖片
         */
        private function savePicture(event:Event):void{
            var myData:BitmapData=new BitmapData(this.writearea.width,this.writearea.height);
            myData.draw(this.writearea);
            connector.savePic(myData,enableDownload);
        }

        private function enableDownload(event:Event):void{
            this.downloadPic.enabled=true;
        }
        /**
         * 設置模式
         */
        private function setPattern(event:Event):void{
            this.writearea.pattern=String(this.pattern.value);
        }
        /**
         * 清空寫字區
         */
        private function cleanArea(event:Event):void{
            this.writearea.signature.graphics.clear();
        }

        /**
         * 設置線條粗細
         */
        public function setLineSize(event:Event):void{
            this.writearea.lineSize=this.size.value;
        }

        /**
         * 設置顏色
         */
        public function setColor(event:Event):void{
            this.writearea.myColor=uint(this.color.value);
        }

        
    }
}

到這里為止,功能已經實現了。但效果不太好。主要是簽名時,筆畫不圓滑,在flex 的api中,好像找不到在flash中設置圓滑的功能。
效果圖:http://rea.humanmonth.com/
12下一頁閱讀全文
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美一级黄色网| 欧美精品999| 国产成人涩涩涩视频在线观看| 国模吧一区二区| 亚洲久久久久久久久久| 成人免费网站在线看| 国产999精品| 亚洲欧美日本精品| 九九精品在线播放| 国产精品十八以下禁看| 国产精品欧美日韩一区二区| 亚洲va久久久噜噜噜久久天堂| 国产精品美女主播在线观看纯欲| 国产精品一区二区电影| 国产午夜精品免费一区二区三区| 国产精品99久久久久久久久久久久| 久久久久久久色| 欧美午夜精品伦理| 中文字幕综合在线| 久久久久一本一区二区青青蜜月| 亚洲国产成人久久综合一区| 欧美国产精品va在线观看| 中国人与牲禽动交精品| 精品福利樱桃av导航| 2019中文字幕在线免费观看| 日本久久久久久| 欧美怡春院一区二区三区| 性欧美在线看片a免费观看| 欧美激情免费视频| 97精品国产97久久久久久| 亚洲欧洲成视频免费观看| 影音先锋欧美精品| 91久久国产婷婷一区二区| 成人在线视频福利| 亚洲成人av在线| 亚洲欧美日韩精品久久亚洲区| 久久久久一本一区二区青青蜜月| 51午夜精品视频| 精品久久久中文| 国产精品久久久久久久久久久不卡| 92福利视频午夜1000合集在线观看| 亚洲电影第1页| 久久99精品久久久久久青青91| 亚洲欧美日韩区| 这里只有精品在线观看| 欧美亚洲一区在线| 狠狠躁夜夜躁人人爽天天天天97| 国产福利精品av综合导导航| 大伊人狠狠躁夜夜躁av一区| 亚洲国产一区二区三区在线观看| 精品视频一区在线视频| 亚洲人成电影在线观看天堂色| 久久久久久久成人| 国精产品一区一区三区有限在线| 色综合亚洲精品激情狠狠| 一区二区三区日韩在线| 亚洲久久久久久久久久久| 亚洲性视频网址| 中文字幕欧美精品日韩中文字幕| 91精品国产网站| 日韩欧美在线免费| 国产精品都在这里| 亚洲天堂av电影| 欧美午夜片在线免费观看| 欧美夫妻性视频| 国产精品人人做人人爽| 中日韩美女免费视频网址在线观看| 成人av在线网址| 最近2019中文免费高清视频观看www99| 九九久久国产精品| 欧美黑人巨大精品一区二区| 秋霞成人午夜鲁丝一区二区三区| 91精品国产91久久久久久最新| 亚洲一级免费视频| 欧美在线xxx| 中文字幕久热精品视频在线| 中日韩午夜理伦电影免费| 91啪国产在线| 国产亚洲一区二区精品| 亚洲一级片在线看| 中文字幕精品—区二区| 26uuu另类亚洲欧美日本一| 国产精品露脸av在线| 亚洲xxxx视频| 性欧美办公室18xxxxhd| 日韩av电影在线免费播放| 亚洲深夜福利网站| 亚洲成人免费在线视频| 国产精品久久久久久久天堂| 国产成人免费av电影| 91精品国产自产91精品| 欧美成人久久久| 国内精品久久久久影院优| 欧美一区二区视频97| 国产高清视频一区三区| 久久露脸国产精品| 国产精品极品美女粉嫩高清在线| 亚洲国产另类久久精品| 久久香蕉精品香蕉| 欧美午夜性色大片在线观看| 人人澡人人澡人人看欧美| 欧美日韩在线视频观看| 日韩精品视频在线观看免费| 亚洲精品中文字幕女同| 亚洲国产成人精品久久久国产成人一区| 亚州欧美日韩中文视频| 日韩成人av在线播放| 欧美大肥婆大肥bbbbb| 国产一区二区在线播放| 欧美日韩国产限制| 欧美日韩国产成人在线观看| 亚洲欧洲激情在线| 欧美人与性动交a欧美精品| 欧美日韩国产一区中文午夜| 91地址最新发布| 欧美日韩成人网| 欧美成人久久久| 亚洲国语精品自产拍在线观看| 国产精品久久99久久| 国产91网红主播在线观看| 国产成人一区二区| 成人激情黄色网| 久久国产加勒比精品无码| 91久久久久久久久| 欧美黄网免费在线观看| 日韩av一区二区在线观看| 神马久久桃色视频| 88xx成人精品| 国产精品白丝jk喷水视频一区| 欧美最猛性xxxxx亚洲精品| 狠狠躁夜夜躁人人爽超碰91| 成人在线一区二区| 成人黄色短视频在线观看| 日韩欧美国产免费播放| 91性高湖久久久久久久久_久久99| 亚洲欧美日韩图片| 亚洲情综合五月天| 欧美成人黄色小视频| 国产美女91呻吟求| 精品国产乱码久久久久久天美| 成人日韩在线电影| 国产精品久久久av| 久久精品小视频| 国产精品女人久久久久久| 26uuu另类亚洲欧美日本老年| 国产精品视频久久久| 91亚洲国产成人精品性色| 日韩精品极品毛片系列视频| 国产一区二区三区视频在线观看| 日韩中文字幕国产| 97人人爽人人喊人人模波多| 欧美日韩aaaa| 亚洲国产97在线精品一区| 亚洲最新av网址| 日韩精品免费综合视频在线播放| 久久久久久网站| 久久久中精品2020中文| 精品视频在线播放色网色视频| 欧美大尺度电影在线观看| 久久av红桃一区二区小说| 欧美一级免费视频| 成人国内精品久久久久一区| 中文字幕一区日韩电影| 国内精品国产三级国产在线专|