热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

拖拉切割直线

import flash.display.Sprite; import flash.geom.Point; import mx.controls.Alert; import


xmlns:fx="http://ns.adobe.com/mxml/2009"

xmlns:s="library://ns.adobe.com/flex/spark"

xmlns:mx="library://ns.adobe.com/flex/mx" min min
creatiOnComplete="onLoad();"
>


import
flash.display.Sprite;
import flash.geom.Point;

import
mx.controls.Alert;
import mx.core.DragSource;
import
mx.core.UIComponent;
import mx.events.DragEvent;
import
mx.events.MenuEvent;
import mx.managers.DragManager;

//
最原始的线条对象
private var uxLine:UXLine = new UXLine;
// 拖动初始点
private
var dragPoint:Point = new Point;

// 当前线条对象
private var
currentLine:UXLine = null;

private function onLoad():void{
//
初始化表格线
initGridLine(mxCanvas);

// 初始化uxLine
uxLine.xFrom =
50;
uxLine.yFrom = 50;
uxLine.xTo = 250;
uxLine.yTo =
250;
uxLine.draw();

mxCanvas.addElement(uxLine);

mxCanvas.addEventListener(UXLine.EVENT_LINE_BROKEN,
onLineBroken);
mxCanvas.addEventListener(UXLine.EVENT_LINE_NODE_MOVE,
onLineNodeMove);
}


// 线条分割事件
private function
onLineBroken(event:MouseEvent):void{
if(event.target is
UXLine){
currentLine =
UXLine(event.target);
systemManager.addEventListener(MouseEvent.MOUSE_MOVE,
onMouseMove4LB, true);

systemManager.addEventListener(MouseEvent.MOUSE_UP, onMouseUp4LB,
true);
}
}
// 线条分割选择点后 开始移动
private function
onMouseMove4LB(event:MouseEvent):void{
event.stopImmediatePropagation();
if(currentLine
!= null){
currentLine.draw2Line(currentLine.x, event.localY);
/*
Alert.show(event.localX.toString(),"title"); */
}
}
//
线条分割选择点后 移动完成
private function
onMouseUp4LB(event:MouseEvent):void{
event.stopImmediatePropagation();
systemManager.removeEventListener(MouseEvent.MOUSE_MOVE,
onMouseMove4LB, true);

systemManager.removeEventListener(MouseEvent.MOUSE_UP, onMouseUp4LB,
true );

var pointX:Number = event.localX;
var pointY:Number =
event.localY;
// 把线条拆分开,即新增加一条线来实现
if(currentLine !=
null){
var newLine:UXLine = new UXLine;
newLine.xFrom =
currentLine.xFrom;
newLine.yFrom =
currentLine.yFrom;
newLine.xTo = pointX;
newLine.yTo =
pointY;
newLine.draw();
mxCanvas.addElement(newLine);

currentLine.graphics.clear();
currentLine.xFrom
= pointX;
currentLine.yFrom =
pointY;
currentLine.draw();
//mxCanvas.removeElement(currentLine);
}
currentLine
= null;
}

// 选择线起点或终点的移动事件
private function
onLineNodeMove(event:MouseEvent):void{
if(event.target is
UXLine){
currentLine =
UXLine(event.target);
systemManager.addEventListener(MouseEvent.MOUSE_MOVE,
onMouseMove4Line, true);

systemManager.addEventListener(MouseEvent.MOUSE_UP, onMouseUp4Line,
true);
}
}

// 选择线起点或终点的移动事件
private function
onMouseMove4Line(event:MouseEvent):void{
event.stopImmediatePropagation();

if(currentLine
!= null){
if(currentLine.selectedNode ==
UXLine.SELECTED_FROM_NODE){
currentLine.xFrom =
event.localX;
currentLine.yFrom = event.localY;
}else
if(currentLine.selectedNode ==
UXLine.SELECTED_TO_NODE){
currentLine.xTo =
event.localX;
currentLine.yTo =
event.localY;
}
currentLine.draw();
}
}

//
释放移动动作
private function
onMouseUp4Line(event:MouseEvent):void{
event.stopImmediatePropagation();

systemManager.removeEventListener(MouseEvent.MOUSE_MOVE,
onMouseMove4Line, true);

systemManager.removeEventListener(MouseEvent.MOUSE_UP, onMouseUp4Line,
true );
currentLine = null;
}


/**
*
初始化表格线条
**/
private function
initGridLine(uiComponent:UIComponent):void{
const LINE_LENGTH:int =
4;
const LINE_MARGIN:int = 2;
const LINE_OFFSET:int =
24;
var rowIndex:int;
var colIndex:int;
var rowCount:int =
Math.floor(this.height / LINE_OFFSET);
var colCount:int =
Math.floor(this.width / LINE_OFFSET);
var startX:Number;
var
startY:Number;
var endX:Number;
var endY:Number;
var
lineIndex:int;
var lineCount:int;
var lineLength:int =
(LINE_LENGTH + LINE_MARGIN);
var thickness:Number = 0.5;
var
lineColor:uint =
0x000000;

uiComponent.graphics.clear();
uiComponent.graphics.beginFill(0xFFFFFF);
uiComponent.graphics.drawRect(0,
0, this.width,
this.height);
uiComponent.graphics.endFill();

uiComponent.graphics.lineStyle(thickness,
lineColor, 0.5);

// 画出横线
lineCount = Math.floor(uiComponent.width
/ lineLength);
for(rowIndex = 1; rowIndex <= rowCount; rowIndex
++){
startY = endY = rowIndex * LINE_OFFSET;
if(rowIndex%2 ==
0){
thickness = 1;
uiComponent.graphics.lineStyle(thickness,
lineColor, 0.3);
}else{
thickness =
0.5;
uiComponent.graphics.lineStyle(thickness, lineColor,
0.1);
}
for(lineIndex = 0; lineIndex ++){
startX = lineIndex * lineLength;
endX = startX +
LINE_LENGTH;
uiComponent.graphics.moveTo(startX,
startY);
uiComponent.graphics.lineTo(endX,
endY);
}
}
// 画出竖线
lineCount =
Math.floor(uiComponent.height / lineLength);
for(colIndex = 1; colIndex
<= colCount; colIndex ++){
startX = endX = colIndex *
LINE_OFFSET;
if(colIndex % 2 == 0){
thickness =
1;
uiComponent.graphics.lineStyle(thickness, lineColor,
0.3);
}else{
thickness =
0.5;
uiComponent.graphics.lineStyle(thickness, lineColor,
0.1);
}

for(lineIndex = 0; lineIndex lineIndex ++){
startY = lineIndex * lineLength;
endY = startY
+ LINE_LENGTH;
uiComponent.graphics.moveTo(startX,
startY);
uiComponent.graphics.lineTo(endX,
endY);
}
}
}

]]>

id="mxCanvas" >
text="提示:按住Ctrl再选择线条画折线,选择线的两端可移动线条" toolTip="按住Ctrl再选择线条画折线" x="278"
y="11"/>


拖拉切割直线,布布扣,bubuko.com


推荐阅读
  • 深入理解 Oracle 存储函数:计算员工年收入
    本文介绍如何使用 Oracle 存储函数查询特定员工的年收入。我们将详细解释存储函数的创建过程,并提供完整的代码示例。 ... [详细]
  • Vue 2 中解决页面刷新和按钮跳转导致导航栏样式失效的问题
    本文介绍了如何通过配置路由的 meta 字段,确保 Vue 2 项目中的导航栏在页面刷新或内部按钮跳转时,始终保持正确的 active 样式。具体实现方法包括设置路由的 meta 属性,并在 HTML 模板中动态绑定类名。 ... [详细]
  • 本文探讨了如何通过最小生成树(MST)来计算严格次小生成树。在处理过程中,需特别注意所有边权重相等的情况,以避免错误。我们首先构建最小生成树,然后枚举每条非树边,检查其是否能形成更优的次小生成树。 ... [详细]
  • 本文总结了2018年的关键成就,包括职业变动、购车、考取驾照等重要事件,并分享了读书、工作、家庭和朋友方面的感悟。同时,展望2019年,制定了健康、软实力提升和技术学习的具体目标。 ... [详细]
  • 在计算机技术的学习道路上,51CTO学院以其专业性和专注度给我留下了深刻印象。从2012年接触计算机到2014年开始系统学习网络技术和安全领域,51CTO学院始终是我信赖的学习平台。 ... [详细]
  • CSS 布局:液态三栏混合宽度布局
    本文介绍了如何使用 CSS 实现液态的三栏布局,其中各栏具有不同的宽度设置。通过调整容器和内容区域的属性,可以实现灵活且响应式的网页设计。 ... [详细]
  • Linux 系统启动故障排除指南:MBR 和 GRUB 问题
    本文详细介绍了 Linux 系统启动过程中常见的 MBR 扇区和 GRUB 引导程序故障及其解决方案,涵盖从备份、模拟故障到恢复的具体步骤。 ... [详细]
  • 本文介绍了如何使用jQuery根据元素的类型(如复选框)和标签名(如段落)来获取DOM对象。这有助于更高效地操作网页中的特定元素。 ... [详细]
  • 本文介绍如何在 Xcode 中使用快捷键和菜单命令对多行代码进行缩进,包括右缩进和左缩进的具体操作方法。 ... [详细]
  • 在Linux系统中配置并启动ActiveMQ
    本文详细介绍了如何在Linux环境中安装和配置ActiveMQ,包括端口开放及防火墙设置。通过本文,您可以掌握完整的ActiveMQ部署流程,确保其在网络环境中正常运行。 ... [详细]
  • 本文介绍如何通过Windows批处理脚本定期检查并重启Java应用程序,确保其持续稳定运行。脚本每30分钟检查一次,并在需要时重启Java程序。同时,它会将任务结果发送到Redis。 ... [详细]
  • MySQL中枚举类型的所有可能值获取方法
    本文介绍了一种在MySQL数据库中查询枚举(ENUM)类型字段所有可能取值的方法,帮助开发者更好地理解和利用这一数据类型。 ... [详细]
  • 本文介绍了一款用于自动化部署 Linux 服务的 Bash 脚本。该脚本不仅涵盖了基本的文件复制和目录创建,还处理了系统服务的配置和启动,确保在多种 Linux 发行版上都能顺利运行。 ... [详细]
  • 理解存储器的层次结构有助于程序员优化程序性能,通过合理安排数据在不同层级的存储位置,提升CPU的数据访问速度。本文详细探讨了静态随机访问存储器(SRAM)和动态随机访问存储器(DRAM)的工作原理及其应用场景,并介绍了存储器模块中的数据存取过程及局部性原理。 ... [详细]
  • 几何画板展示电场线与等势面的交互关系
    几何画板是一款功能强大的物理教学软件,具备丰富的绘图和度量工具。它不仅能够模拟物理实验过程,还能通过定量分析揭示物理现象背后的规律,尤其适用于难以在实际实验中展示的内容。本文将介绍如何使用几何画板演示电场线与等势面之间的关系。 ... [详细]
author-avatar
Angels萱萱
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有