- 浏览: 577172 次
- 性别:
- 来自: 北京
文章分类
- 全部博客 (237)
- Java (48)
- Flex3 (43)
- Spring (7)
- Hibernate (7)
- 杂文 (2)
- 设计模式 (3)
- 数据库相关 (32)
- Eclipse开发环境 (10)
- C/C++ (1)
- 随笔 (1)
- 生活点滴 (2)
- Flex4 (3)
- Oracle (6)
- SQLServer (6)
- Degrafa (1)
- ActionScript (2)
- JavaScript (11)
- MySQL (8)
- 开源项目 (4)
- AspectJ (0)
- Spring Security (1)
- SSO (0)
- PV3D (2)
- JBPM (1)
- JBoss (0)
- Tomcat (5)
- Struts (1)
- WebService (2)
- 算法 (1)
- 数据结构 (1)
- POI (2)
- Lucene (2)
- 其他 (3)
- Blazeds (2)
- Alternative 3D (0)
- Ibatis (3)
- Intellij (3)
- freemaker (0)
- Maven (5)
- web (4)
- Eclipse (1)
- velocity (1)
- Linux (7)
- CXF (3)
- html (2)
- JVM (1)
最新评论
-
jpsb:
多谢楼主,问题解决,主要就是svn版本不同导致的
Eclipse 导入本地svn项目的问题 -
yycdaizi:
lanmolsz 写道无法同意楼主的说法,楼主所谓的晚捕捉就是 ...
Java异常处理原则 -
lanmolsz:
无法同意楼主的说法,楼主所谓的晚捕捉就是典型的让异常控制程序的 ...
Java异常处理原则 -
cici_new_1987:
...
Java异常处理原则 -
雁行:
倒是怀疑这个功能来着
Eclipse 导入本地svn项目的问题
转载自:http://www.iteye.com/topic/377994
- 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);
- }
- }
- }
效果图:http://rea.humanmonth.com/
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作了限制,下载动作只能由用户触发。代码如下:
- 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"); } } }
- 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);
- }
- }
- }
发表评论
-
AIR html 内存泄露
2010-07-15 14:21 1695众所周知,Flex虽然在客户体验方面独领风骚,但是其 ... -
Flex 内部命名空间
2010-05-11 13:27 1307使用方式如下: //引用命名空间 im ... -
AIR开发下的ALert窗口无法弹出
2010-05-05 10:55 1516最近在从事AIR编程。AIR开发和之前做的RIA开发还是 ... -
Flex调用JS代码
2010-03-03 11:23 5254在Flex开发中有时候需要调用JS代码,例如关闭浏览 ... -
Flex设置浏览器标题
2010-03-03 11:17 3015在Flex下设置页面浏览器标题Title工有两种方式 ... -
Flex版在线PhotoShop(2个)
2010-03-02 13:47 2146刚刚看到了一个Flex版本的Online PhotoShop工 ... -
Degrafa渲染DataGrid
2009-12-22 09:58 2088在DataGrid中可以利用多种组件实现Column ... -
Flex3D 视屏网站
2009-12-21 08:28 1149http://www.hboimagine.com/#/the ... -
多种DataGrid ItemRender实现
2009-12-10 15:00 2076在Flex开发中,可能在展示数据方面,DataGr ... -
Flex RSL(Runtime Shared Library)
2009-12-10 08:03 1752RSL是 Runtime Shared Lib ... -
Degrafa(Beta3)源码
2009-12-08 17:01 1212Degrafa源码共享下载,见附件。 -
Flex 动态换肤
2009-12-08 16:57 1806可能很多人在写Flex程序的时候为了界面的美化,都会用 ... -
Flex Sound Effect 异常
2009-12-08 13:14 1139早上在写Flex代码的时候,想放首歌听听,不知道什么原 ... -
推荐一个不错的Flex网站
2009-12-07 15:51 1247今天看到了一个相当不错的关于Flex/Flash开发的英文站点 ... -
Flex+Java文件上传
2009-12-07 10:14 4422在研究Flex DataGrid导入exc ... -
Flex DataGrid导入Excel(一)
2009-12-02 18:46 5567这篇Blog只是写实现思路。 记得刚毕业 ... -
Flex版FusionCharts图形组件
2009-11-27 08:34 3837在Flex图形领域,FusionCharts为广 ... -
DataGrid导出Excel
2009-11-24 16:54 6391在Adobe的RIA开发环境下,flex并没有导出 ... -
Flex高级表格(Mecgrid)
2009-11-20 13:52 4387最近在考虑DataGrid单元格定位的问题时,收集到了 ... -
DataGrid单元格定位
2009-11-20 13:39 4840在Flex项目开发中,相信很多人会用到DataG ...
相关推荐
在Flex 3.0中,我们可以使用`Flash Player`的内置API来实现手写签名的功能。用户可以通过鼠标或触摸设备模拟笔迹,绘制出签名。关键在于监听鼠标的移动事件,并在每次鼠标移动时在舞台上添加新的图形对象,如线条,...
本文所述的在线手写签名功能在Flex环境下实现,分为两个主要部分:画图功能和上传图片功能。 画图功能: 1. 创建一个Canvas容器,并在其上添加一个UIComponent作为签名的白板,这个组件用于绘制签名。 2. 定义基本...
【标题】:“flex实现在线翻译” 在Web应用开发中,Flex是一种基于Adobe Flash Player或Adobe AIR运行时的富互联网应用程序(RIA)框架。它允许开发者创建具有交互性和动态视觉效果的用户界面。在这个实例中,我们...
"Flexwheel"是基于Flex实现的一种特定组件,主要用于创建图片滚动和时间滚动的效果。这种效果常用于增强用户体验,尤其是在展示大量信息或者产品图片时,能够以吸引人的方式呈现内容。 首先,我们要理解什么是Flex...
在本案例中,我们讨论的主题是如何使用Flex实现一个功能,允许用户在网页上进行在线拍照,并且这个功能需要兼容老旧的Internet Explorer 8(IE8)浏览器,同时支持照片预览。 在Flex中实现在线拍照,首先需要考虑的...
在本案例中,"flex实现的翻书功能的网站漂亮的flex实现swf及源码",显然指的是使用Flex技术创建了一个模拟真实书籍翻页效果的交互式Web应用。这个应用不仅提供了视觉上的吸引力,还具有高度的用户参与度,让浏览者...
标题中的“flex实现在线拍照”指的是使用Adobe Flex技术来创建一个功能,允许用户通过Web浏览器进行实时拍照。Flex是一个开源的、基于ActionScript的框架,主要用于构建富互联网应用程序(RIA)。它提供了丰富的用户...
在探讨“Flex实现Camera摄像头在线拍照功能”这一主题时,我们深入分析了如何利用Adobe Flex框架结合Camera组件来实现在线拍照的功能。Flex是一种强大的RCP(Rich Client Platform)开发工具,由Adobe Systems开发,...
在这个"Flex实现的计算器"项目中,开发者使用了Adobe Flex来设计和开发一个基本的计算器,具备进行基本数学运算如加、减、乘、除的功能。 1. **Flex框架介绍** Flex提供了MXML和ActionScript两种编程语言,其中...
《基于Java+Flex实现的聊天程序详解》 在信息技术领域,构建实时的在线聊天系统是一项常见的挑战。本项目“基于Java+Flex实现的聊天程序”提供了一种有效的解决方案,它结合了Java的强大后端处理能力和Flex的富...
在这个特定的场景中,"Flex实现的xmpp消息发送接收"是指使用Flex技术来实现在Android、iOS等移动设备以及IE浏览器上的即时通讯功能。 XMPP(Extensible Messaging and Presence Protocol)是一种开放标准的协议,...
本篇文章将详细解释如何使用Flex来实现边框以及添加标题,并重点关注在标题框中显示文本的实现方法。 首先,我们需要了解Flex中的容器和组件。容器是Flex应用程序的基础,它们可以包含一个或多个组件,如按钮、文本...
flex实现简单浏览器,flex AIR中HTML控件实现了简单的网页浏览效果
在本实例中,“flex实现数据表格”指的是使用Flex技术来创建一个数据展示组件,即Datagrid,用于显示结构化的数据。Datagrid是Flex中非常重要的一个组件,它允许用户以表格形式查看和操作大量数据。 Flex Datagrid...
一类是给flex容器设置的,一类是给flex子元素设置的,本文在介绍一些典型场景实现的同时也会顺带讲解部分属性,当然更详细的内容可以阅读MDN上的教程。接下来需要使用到flex-grow属性,这个是flex子元素上的属性,...
在这个“j2ee+FLEX实现在线拍照”的项目中,Flex将提供拍照和图像处理的功能,用户可以直接在Web浏览器中进行拍照或选择本地图片上传;而后端的J2EE服务器则处理图片上传、存储和可能的进一步处理。 为了实现这一...
flex实现QQ面板效果flex实现QQ面板效果flex实现QQ面板效果flex实现QQ面板效果
在本文中,我们将深入探讨如何使用Flex来实现一个图片旋转效果,这在产品展示或交互式界面设计中非常常见。Flex是一种强大的、基于XML的框架,用于构建富互联网应用程序(RIA),尤其适用于创建动态、响应式的用户...
在Flex中实现打印预览功能可以帮助用户在正式打印前检查文档布局和格式,确保打印效果符合预期。以下是对Flex中实现打印预览功能的详细解释: 一、Flex中的打印服务 Flex内置了`flash.printing.PrintJob`类,提供了...
在本文中,我们将深入探讨如何使用Flex技术来实现阴影效果。Flex是一种强大的开发框架,主要用于构建富互联网应用程序(RIA),特别是在Adobe AIR和Flash Player环境中。它提供了丰富的组件库、强大的数据绑定机制...