如上图,我们要实现中间两个飞机之间连线以及上面点的功能, 点如果采用twave的节点那么无法跟,线绑定所以方法是不可取的。
根据Twaver API有两种实现方式:
1.添加图标附加,图标附件可以添加多个,但是仅仅是一个图标没有其他更多的功能,比如图标上添加Label,以及添加tooltip,以及其他一些列鼠标事件。所以仅仅附件功能并不可取。
2.自定义Link和LinkUI.以及自定义更强大的附件。
我们现在采用第二种方式:
首先重写Link:
package com.zznode.iss.topo.gummonitor.components.common { import twaver.Link; import twaver.Node; public class CLink extends Link { public function CLink(id:Object=null, fromNode:Node=null, toNode:Node=null) { //TODO: implement function super(id, fromNode, toNode); } override public function get elementUIClass():Class { return ClinkUI; } } }
自定义Link中关键的是引入了自定义的CLinkUI它是负责线呈现的,简单说Link是个数据人那么CLinkUI是人的外表具体什么样的外表需要ClinkUI来实现
2.重写LinkUI
package com.zznode.iss.topo.gummonitor.components.common { import com.zznode.iss.common.components.topo.common.TopUtils; import flash.display.GradientType; import flash.display.Graphics; import flash.display.SpreadMethod; import flash.geom.Matrix; import flash.geom.Point; import mx.collections.ArrayCollection; import spark.components.Image; import spark.components.Label; import twaver.ICollection; import twaver.IData; import twaver.Link; import twaver.Node; import twaver.network.Network; import twaver.network.ui.LinkUI; public class ClinkUI extends LinkUI { public var attachmentDatas:ArrayCollection=new ArrayCollection(); public var airattachments:ArrayCollection=new ArrayCollection(); private var center:Point; private var contentCenter:Point; public function ClinkUI(network:Network, link:Link) { var serviceType:String=link.getClient(TopUtils.SERVICE_TYPE); var pArr:Array=serviceType.split("||"); for each(var pdata:String in pArr){ var pointStrArr:Array=pdata.split(","); var attachmenetData:Object=new Object(); for each(var attribute:String in pointStrArr){ var attS:Array=attribute.split(":"); attachmenetData[attS[0]]=attS[1]; } attachmentDatas.addItem(attachmenetData); var ariAttachment:AirAttachmentUI=new AirAttachmentUI(); ariAttachment.data=attachmenetData; ariAttachment.width=200; ariAttachment.height=60; airattachments.addItem(ariAttachment); } super(network, link); } override public function checkAttachments():void { super.checkAttachments(); super.checkLinkHandlerAttachment(); //this.checkLinkBundleAttachment(); } public var fp:Point; override protected function updateDisplayList(unscaledWidth:Number, unscaledHeight:Number):void{ super.updateDisplayList(unscaledWidth,unscaledHeight); //将fromPoint和toPoint转为本地坐标 fp=this.contentToGlobal(new Point(0,0)); for each(var att:AirAttachmentUI in airattachments){ att.xRelativeValue=att.data.Xlocation-this.fromPoint.x; att.x=this.fromPoint.x-fp.x-att.width/2+att.xRelativeValue+this.link.fromNode.width/2; att.y=this.fromPoint.y-fp.y-(att.height-att.icon.height/2); } } override protected function drawBody(g:Graphics):void{ var g:Graphics = this.graphics; g.clear(); //边框 可以有 g.lineStyle(1, 0xC0C0C0,0.5); g.drawRect( this.fromPoint.x,this.fromPoint.y-2.5, this.toPoint.x-this.fromPoint.x, 5); //画填充 var fillType:String = GradientType.LINEAR; var colors:Array = [0x8FCA39, 0xC0C0C0,0x5AC2FD]; var alphas:Array = [1, 0,1]; var ratios:Array = [0x32, 0x89, 0xFF]; var matr:Matrix = new Matrix(); //matr.createGradientBox(50, 50, Math.PI / 4, 0, 0); matr.createGradientBox(50, 50, 0, 0, 0); var spreadMethod:String = SpreadMethod.PAD; this.graphics.beginGradientFill(fillType, colors, alphas, ratios, matr, spreadMethod); g.drawRect( this.fromPoint.x,this.fromPoint.y-2.5, this.toPoint.x-this.fromPoint.x, 5); g.endFill(); /*var myMatrix:Matrix = new Matrix(); myMatrix.createGradientBox(200, 200, 1.6, 50, 50); var myColors:Array = [0xFF3300,0x666666]; var myAlphaS:Array = [100, 100]; var myRalphaS:Array = [0, 225]; graphics.beginGradientFill(GradientType.LINEAR, myColors, myAlphaS,myRalphaS, myMatrix); graphics.drawRoundRectComplex(this.fromPoint.x,this.fromPoint.y-20,70,70,5,5,5,5);*/ } override protected function createChildren():void{ super.createChildren(); fp=this.contentToGlobal(new Point(0,0)); for each(var att:AirAttachmentUI in airattachments){ this.addChild(att); } } protected function checkLinkBundleAttachment():void { // this._linkBundleAttachment = new LinkBundleAttachment(this); //this.addAttachment(this._linkBundleAttachment); } } }
updateDisplayList中我们控制了图标点的移动,呈现的UI,AirAttachmentUI
<?xml version="1.0" encoding="utf-8"?>
<s:Group xmlns:fx="http://ns.adobe.com/mxml/2009"
xmlns:s="library://ns.adobe.com/flex/spark"
xmlns:mx="library://ns.adobe.com/flex/mx" width="200" height="60" creationComplete="vgroup1_creationCompleteHandler(event)" >
<fx:Script>
<![CDATA[
import mx.events.FlexEvent;
private var _data:Object;
[Bindable]
/**
* 附件数据项
* Xlocation
* Ylocation
* */
public function get data():Object
{
return _data;
city.setStyle("color",data.citypicturecolor);
}
/**
* @private
*/
public function set data(value:Object):void
{
_data = value;
}
private var _xRelativeValue:Number;
public function get xRelativeValue():Number
{
return _xRelativeValue;
}
public function set xRelativeValue(value:Number):void
{
if(isNaN(_xRelativeValue)){
_xRelativeValue = value;
}
}
protected function vgroup1_creationCompleteHandler(event:FlexEvent):void
{
// TODO Auto-generated method stubdata.citypicturecolor
}
]]>
</fx:Script>
<s:Label id="city" width="100%" textAlign="center" y="{data.cityLabelY}" text="{data.cityname}" color="{data.citypicturecolor}"/>
<s:VGroup width="100%" height="100%" horizontalAlign="center" verticalAlign="bottom">
<s:Image id="icon" source="{data.citypicture}" width="16" height="16" />
</s:VGroup>
<!--<s:Label id="city" y="{data.cityLabelY}" text="{data.cityname}" color="{data.citypicturecolor}"/>
<s:Image id="icon" source="{data.citypicture}" width="16" height="16" />-->
</s:Group>
再看附件LinkBundleAttachment (CLinkUI中添加附件的代码因为不需要所以被注释了):
package com.zznode.iss.topo.gummonitor.components.common { import flash.display.DisplayObject; import flash.display.Graphics; import flash.geom.Matrix; import flash.geom.Point; import mx.controls.ColorPicker; import mx.utils.ColorUtil; import spark.components.Image; import spark.components.Label; import twaver.Collection; import twaver.ICollection; import twaver.IData; import twaver.Link; import twaver.Node; import twaver.Utils; import twaver.network.ui.Attachment; import twaver.network.ui.ElementUI; import twaver.network.ui.LinkUI; public class LinkBundleAttachment extends Attachment { var _linkBundleWidth:*; var _linkBundleHeight:*; var _linkBundleColor:*; var _linkBundleAlpha:*; private var center:Point; private var contentCenter:Point; [Embed(source="/resources/images/topo/red.png")] /**2G普通基站红**/ public var BTS_OTH_1:Class; private var img:Image; public function LinkBundleAttachment(elementUI:ElementUI, showOnTop:Boolean = false) { super(elementUI, showOnTop); } override public function draw(graphics:Graphics):void { var link:Link = Link(element); //var fromP:Node=link.fromNode; //var toP:Node=link.toNode; center=new Point((LinkUI(elementUI).toPoint.x+LinkUI(elementUI).fromPoint.x)/2,(LinkUI(elementUI).toPoint.y+LinkUI(elementUI).fromPoint.y)/2); contentCenter=LinkUI(elementUI).network.localToContent(center); var g:Graphics=graphics; g.lineStyle(1, 0x01f0e, 1); g.beginFill(0x091231, 0.5); g.drawCircle(LinkUI(elementUI).fromPoint.x,LinkUI(elementUI).fromPoint.y,30); //g.moveTo(LinkUI(elementUI).fromPoint.x,LinkUI(elementUI).fromPoint.y); //g.lineTo(center.x,center.y); g.drawCircle(center.x,center.y,10); //g.lineTo(LinkUI(elementUI).toPoint.x,LinkUI(elementUI).toPoint.y); //g.endFill();#EE2E35 g.drawCircle(LinkUI(elementUI).toPoint.x,LinkUI(elementUI).toPoint.y,30); //ClinkUI(elementUI).img.x=contentCenter.x-ClinkUI(elementUI).img.width/2;//-LinkUI(elementUI).x; //ClinkUI(elementUI).img.y=contentCenter.y-ClinkUI(elementUI).img.height/2;//-LinkUI(elementUI).y; var p:Point=ClinkUI(elementUI).contentToLocal(new Point(0,0)); var p2:Point=ClinkUI(elementUI).contentToGlobal(new Point(0,0)); for each(var att:AirAttachmentUI in ClinkUI(elementUI).airattachments){ att.x=-70;//LinkUI(elementUI).fromPoint.x-ClinkUI(elementUI).fp.x;//-att.xRelativeValue-att.width/2 att.y=-20;LinkUI(elementUI).fromPoint.y-ClinkUI(elementUI).fp.y;//-(att.height-att.icon.height/2); } /*for each(var attachment:AirAttachmentUI in ClinkUI(elementUI).airattachments){ //attachment.xRelativeValue=contentCenter.x-attachment.data.Xlocation; //attachment.x=contentCenter.x-attachment.width/2-attachment.xRelativeValue; //attachment.x=contentCenter.x-attachment.xRelativeValue; attachment.y=contentCenter.y-(attachment.height-attachment.icon.height/2); }*/ /*for each(var att:AirAttachmentUI in ClinkUI(elementUI).airattachments){ var iData:ICollection = network.elementBox.datas; for(var i:Number=0;i<iData.count;i++){ var data:IData = iData.getItemAt(i) as IData; if(data is Node){ var node:Node=Node(data); if(node.id==att.data.enodebid){ att.x=node.x; } } } }*/ } } }
如上是实现可以解决放大缩小等一些列问题
相关推荐
**Twave Flex API 英文版详解** Twave Flex API 是一套专为开发基于Adobe Flex技术的交互式应用程序而设计的软件开发工具包(SDK)。2010年10月发布的版本,针对的是Flex开发者,它提供了丰富的功能和接口,帮助...
Twave 组件,可以使用,但是不是注册版得
duration of p q R S Twave in ECG beat
筛选搜索-在“Pokémon搜索”选项卡中,键入“ prankster,twave”,然后按Enter键以获取可以学习Thunder Wave的带有Prankster的Pokémon列表。 面板用户界面-单击任何内容都会将其加载到右侧的新面板中,以便于...
仅供学习使用
内容概要:本文深入探讨了多种高级格兰杰因果检验方法,包括非线性格兰杰因果检验、分位数格兰杰因果检验、混频格兰杰因果检验以及频域因果检验。每种方法都有其独特之处,适用于不同类型的时间序列数据。非线性格兰杰因果检验分为非参数方法、双变量和多元检验,能够在不假设数据分布的情况下处理复杂的关系。分位数格兰杰因果检验则关注不同分位数下的因果关系,尤其适合经济数据的研究。混频格兰杰因果检验解决了不同频率数据之间的因果关系分析问题,而频域因果检验则专注于不同频率成分下的因果关系。文中还提供了具体的Python和R代码示例,帮助读者理解和应用这些方法。 适合人群:从事时间序列分析、经济学、金融学等领域研究的专业人士,尤其是对非线性因果关系感兴趣的学者和技术人员。 使用场景及目标:①研究复杂非线性时间序列数据中的因果关系;②分析不同分位数下的经济变量因果关系;③处理不同频率数据的因果关系;④识别特定频率成分下的因果关系。通过这些方法,研究人员可以获得更全面、细致的因果关系洞察。 阅读建议:由于涉及较多数学公式和编程代码,建议读者具备一定的统计学和编程基础,特别是对时间序列分析有一定了解。同时,建议结合具体案例进行实践操作,以便更好地掌握这些方法的实际应用。
内容概要:本文详细介绍了直流电机双闭环控制系统的原理及其仿真实现。首先构建了一个DC电机的动力学模型,定义了电枢电阻、电感、转矩常数等参数,并通过Python实现了电机的更新机制。接着引入了双环控制器,外环控制转速,内环控制电流,利用PID控制器进行调节。文中强调了电流环和转速环之间的协调关系,以及调参过程中的一些实用技巧,如先调整内环再调整外环,比例先行积分缓。同时提供了MATLAB/Simulink环境下的具体实现步骤,包括设置合理的采样时间和加入必要的滤波器,确保系统的稳定性。此外,还分享了一些常见的错误案例和解决办法,帮助读者更好地理解和应用这一技术。 适合人群:具有一定自动化控制基础,尤其是对电机控制感兴趣的工程技术人员。 使用场景及目标:适用于需要精确控制电机转速和电流的应用场合,如工业机器人、电动汽车等领域。目标是使读者能够掌握双闭环控制的基本原理,并能够在实际项目中灵活运用。 其他说明:文中不仅提供了详细的代码示例,还有丰富的图表辅助解释,便于读者直观理解各个部分的工作原理。对于初学者来说,建议从简单的单环控制入手,逐步过渡到复杂的双环控制。
微信默认视频来电铃声 phonering.mp3
自然语言处理隐私数据集公开收集
咱们期待已久的V2.3.3测试包来啦!大家可以下载体验,帮忙一起测试测试,有啥问题尽管提,咱们一起把它打磨得更完美~
Photo_250404014522.jpeg
内容概要:本文详细介绍了如何使用Matlab 2013进行单相PWM整流电路的双闭环控制仿真,旨在将输入的220V交流电转换为稳定的250V直流电。文章首先解释了单相PWM整流电路的工作原理及其重要性,接着阐述了双闭环控制策略的具体实现方法,包括电压外环和电流内环的设计。随后,文章详细描述了在Matlab Simulink环境中的建模步骤,涵盖了主电路搭建、双闭环控制模块构建以及PWM信号生成的关键环节。最后,通过仿真结果展示了输入电流与输入电压的同步性和输出直流电压的稳定性,并提供了针对常见问题的解决方案。 适合人群:从事电力电子领域的研究人员和技术人员,尤其是对PWM整流电路和Matlab仿真实验感兴趣的读者。 使用场景及目标:适用于高校实验室、科研机构和企业研发中心,帮助相关人员理解和掌握单相PWM整流电路的工作机制及其控制策略,提升电力电子设备的研发效率和性能。 其他说明:文中提供的代码片段和参数设置有助于读者快速上手并进行实验验证,同时也强调了实际应用中需要注意的问题,如滤波电容的选择、PI调节器参数的调整等。
内容概要:本文探讨了云计算和边缘计算的协同系统模型,特别是在该模型下使用线形搜索算法寻找最优路径以及通过多线程并行技术提升系统性能的方法。文中详细介绍了线形搜索算法的Matlab实现及其应用场景,如智能工厂的数据传输路径优化。此外,还讨论了如何在边缘设备上应用多线程并行技术,以充分利用CPU多核能力,提高处理效率。文章强调了在实际部署中需要注意的硬件限制和网络动态变化等问题,并提出了相应的解决策略。 适合人群:对云计算、边缘计算及并行计算感兴趣的开发者和技术研究人员。 使用场景及目标:适用于需要优化云边协同系统中数据传输路径和提升系统性能的实际项目。具体目标包括减少数据传输延迟、提高实时性和处理效率。 其他说明:文章提供了具体的Matlab代码示例,帮助读者更好地理解和实现相关算法。同时提醒读者注意硬件资源的限制,在实际应用中进行适当的调整和优化。
内容概要:本文详细介绍了如何在CATIA DMU模块中进行麦弗逊式独立悬架与齿轮齿条转向器的非参数化运动仿真。首先,文章解释了底盘结构及其运动特性,接着逐步展示了如何设置悬架和转向系统的运动副,包括旋转副、滑动副以及齿轮齿条副的具体配置方法。文中还特别强调了仿真过程中需要注意的技术细节,如参数设置、摩擦系数的选择、运动自由度的限制等。此外,作者分享了一些实用技巧,比如通过正弦函数驱动转向输入、利用传感器监测运动状态、导出并修改仿真动画等。 适合人群:从事汽车工程设计、机械仿真的工程师和技术人员,尤其是熟悉CATIA软件的用户。 使用场景及目标:适用于需要进行车辆转向系统和悬架系统联合仿真的场合,帮助工程师更好地理解和优化车辆动态性能,提高设计效率。 其他说明:文章提供了大量具体的VBA代码片段,便于读者直接应用于自己的项目中。同时,文中提到的一些调试经验和常见问题解决方法也非常有价值。
基于Javaweb(servlet+mysql)
内容概要:本文详细介绍了全桥LLC谐振变换器的设计与仿真,特别是针对高压输入(370-405V)和高功率输出(1000W,25V/40A)的应用场景。文章首先解释了全桥LLC谐振变换器的基础结构及其优势,接着展示了如何通过Python代码计算谐振频率,并通过MATLAB/Simulink进行了详细的电压环PI控制仿真。文中特别强调了PI控制器参数的优化,如比例系数(Kp)和积分系数(Ki)的选择,以及抗积分饱和处理的方法。此外,还探讨了轻载情况下的次谐波振荡问题及其解决方案,如频率钳位和动态调整PI参数。最后,通过仿真数据展示了不同输入电压条件下的性能表现,包括输出电压稳定性、恢复时间和效率。 适合人群:从事电力电子设计、电源管理系统的工程师和技术爱好者,尤其关注高效能电源转换和控制系统的人群。 使用场景及目标:适用于需要设计和优化全桥LLC谐振变换器的工程项目,特别是在高压输入和高功率输出的应用场合。目标是确保输出电压稳定,提高系统效率,并减少开关损耗。 其他说明:文中提供的代码和仿真结果仅为示例,实际应用中需要进一步的理论分析和完善的设计。此外,文中还提及了一些实际调试过程中遇到的问题及解决方案,有助于读者更好地理解和应对类似的技术挑战。
内容概要:本文详细介绍了交错并联Boost PFC电路的设计及其在Simulink中的双闭环控制仿真方法。交错并联Boost电路通过两个Boost模块相位差180度的工作方式,有效降低了输入电流纹波,减轻了元器件的压力。文中重点讨论了输出电压外环和电感电流内环的双闭环控制策略,以及具体的PI参数设置和调优技巧。通过合理的参数选择和控制策略,实现了较低的总谐波失真(THD)和稳定的输出电压。此外,还探讨了仿真过程中常见的问题及解决方案,如电流环带宽设置、积分时间调整、PWM相位同步等。 适合人群:从事电力电子设计、电源管理系统的工程师和技术人员,尤其是对PFC电路和Simulink仿真感兴趣的读者。 使用场景及目标:适用于需要进行PFC电路设计和仿真的场合,旨在提高输入电流质量,减少谐波失真,确保输出电压的稳定性。通过学习本文,读者能够掌握交错并联Boost PFC电路的设计思路和仿真技巧,为实际项目提供理论支持和技术指导。 其他说明:文中提供了详细的MATLAB/Simulink代码片段和参数设置建议,帮助读者更好地理解和应用所介绍的技术。同时,强调了仿真过程中需要注意的关键点,避免常见错误,确保仿真结果的有效性和准确性。
炼石图解网络数据安全管理条例及数据安全合规与技术体系2024630页.pdf
内容概要:本文深入探讨了电动车电驱系统中电机控制器的关键技术——主动阻尼控制及其相关技术的应用。文中介绍了主动阻尼控制的基本概念,即通过一系列控制策略使系统有效抵抗振动,特别是通过转矩补偿和加速度反馈来增强系统的稳定性。作者详细展示了如何利用Matlab二质量模型进行系统动态特性的模拟,并通过巴特沃斯高通滤波器提取转速波动来进行转矩补偿。此外,还讨论了加速度反馈的作用,即通过增加电机惯量来减少振动。最后,文章通过实际案例展示了这些技术的有效性,显著提高了电动车电驱系统的稳定性和可靠性。 适合人群:从事电动车电驱系统开发的技术人员、研究人员及高校相关专业师生。 使用场景及目标:适用于电动车电驱系统的设计与优化,旨在提高系统的稳定性和可靠性,减少振动和噪声,改善驾驶体验。同时,该技术有助于延长传动系统的使用寿命,降低故障率。 其他说明:文章不仅提供了详细的理论和技术背景,还包括具体的代码实现和实际应用案例,便于读者理解和实践。此外,文中提供的仿真模型和详实文档为后续研究和项目优化提供了有力支持。
内容概要:本文深入探讨了增量电导法(Incremental Conductance, INC)在太阳能光伏发电系统最大功率点跟踪(MPPT)中的应用。首先介绍了增量电导法的基本原理及其相对于扰动观测法的优势,特别是其在光照快速变化时的高效性能。接着展示了MATLAB核心代码实现,详细解释了电导变化率的计算以及占空比调整逻辑。随后讨论了Simulink建模的具体步骤和技术细节,如采样周期设定、PWM模块配置等。此外,针对不同应用场景提出了参数调试建议,包括步长选择、温度对步长的影响、负载电流前馈补偿等。最后分享了一些实用经验和注意事项,如避免数值震荡、处理光照突变等。 适合人群:从事光伏系统设计与开发的工程师,尤其是对MPPT算法感兴趣的科研人员和技术爱好者。 使用场景及目标:适用于希望深入了解并掌握增量电导法MPPT技术的研究人员和工程师。主要目标是通过理论讲解和实例代码帮助读者理解增量电导法的工作原理,并能够在MATLAB/Simulink环境中构建高效的MPPT控制系统。 其他说明:文中提供了详细的代码片段和具体的参数设置指导,有助于读者进行实际操作和实验验证。同时强调了在不同条件下(如光照突变、温度变化)的算法优化策略,使系统更加稳健可靠。