`
nijiaben
  • 浏览: 131016 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

Flex流行MVC框架之Cairngorm小试牛刀

    博客分类:
  • Flex
阅读更多
   前几天学了下Flex的一MVC流行框架Cairngorm,并自己小试牛刀一把,暂作了一网站后台,通过项目让我现在觉得Cairngorm并不是一个如此神奇的东西,只要我们大家都能按照它走一遍就会有所收获,我们就会对MVC有个基本的了解,也会对Cairngorm有一个初步了解,希望大家通过我的这篇文章也能写出一个demo出来,当然是能在不看我这篇demo或者别人的demo的前提下写出来啦,呵呵,首先要说的是,这个框架并不是一定要在lcds下才能运行的,所以大家可以简单的建个Flex项目就OK了,下面就开始我们的Demo。在最后会把整个工程源码提供出来,欢迎下载。
    我们新建工程,有一个Cairngrom的swc包一定要引进去才行的哈,不然是不能成功的,所以大家可以Cairngrom的官方网站上去下载哈,我在这里提供地址,方便大家去下载http://labs.adobe.com/wiki/index.php/Cairngorm,还有更多的关于Cairngorm框架的资料可以访问http://www,cairngormdoc.org,欢迎和大家一起讨论该框架,欢迎大家加我QQ:234281357,也希望能从大家那学到许多东西。
    先把我刚写的一个小demo的部署结构给大家看看,

下面我会一一讲解每个包中应方的类,每个包的命名都是很规范的,这样大家就很清晰的理解你写的代码的意思,所以建议大家不要轻易改变这么命名。我先说说这里的包,既然是MVC框架的话,当然我们要把哪些是M,哪些是V以及哪些是C给分出来。M主要是模型,我们从命名也许也能猜到了,model和vo应该都归属于该层了,它主要是存放的是数据模型,vo中存的就是普通的数据,一般的话都是最小单位的数据,是不能进行再次分解的数据,代码如下:
package org.rjb.vo
{
	import com.adobe.cairngorm.vo.IValueObject;
    //一般情况下,我们需要实现框架中的IValueObject接口
	public class UserVO implements IValueObject{
		//存放用户名
		public var userName:String;
		//存放密码
		public var password:String;
	}
}
而model中的数据一般是包括相应的VO对象以及一些相关的应用变量,比如说系统状态什么的,当然要按自己的意思来了,并且我们一般把它做成单例类,前面我有篇文章就是讲单例模式的,并对比了java和actionscript3.0中不同的实现方式,如果还不是很了解的话大家可以去参考下。下面是改model类:
package org.rjb.model
{
	import com.adobe.cairngorm.model.ModelLocator;
	
	import org.rjb.vo.UserVO;
    [Bindable]
	public class UserModelLocator implements ModelLocator
	{
		//存放vo对象
		public var userVO:UserVO;
		//存放一些状态变量
		public var state:String="User---Login";
		//单例对象
		private static var modelLocator:UserModelLocator;
		
		public static function getInstance():UserModelLocator{
			if(modelLocator==null){
				modelLocator=new UserModelLocator(new SingleClass());
			}
			return modelLocator;
		}
		
		public function UserModelLocator(single:SingleClass){
			if(single==null){
				throw new Error( "You Can Only Have One UserModelLocator" );
			}
			
		}
	}
}
class SingleClass{}

设成单例类的话我们可以保证系统的数据得到同意,并且我们会把它设置为绑定模式,可以和接下来说的view包下的视图类进行数据绑定。view包下前面说了,是存放相关的视图的,可以是as的也可以是mxml的,看大家的意思了,比如说我们可以存放些自定义的组建或扩展的组件等,下面是LoginPanel.mxml的代码:
<?xml version="1.0" encoding="utf-8"?>
<mx:Panel xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute" width="400" height="300" horizontalAlign="center" verticalAlign="middle">
	<mx:Script>
		<![CDATA[
			import org.rjb.model.UserModelLocator;
			import com.adobe.cairngorm.control.CairngormEventDispatcher;
			import org.rjb.event.LoginEvent;
			import org.rjb.vo.UserVO;
			[Bindable]
			private var modelLovator:UserModelLocator=UserModelLocator.getInstance();
			//提交的出来方法
			private function submit():void{
				var userVO:UserVO=new UserVO;
				userVO.userName=this.userName.text;
				userVO.password=this.password.text;
				var loginEvent:LoginEvent=new LoginEvent(userVO);
				CairngormEventDispatcher.getInstance().dispatchEvent(loginEvent);
			}
			//重置的出来方法
			private function reset():void{
				this.userName.text="";
				this.password.text="";
			}
			//返回的处理方法
			private function returnToLogin():void{
				this.currentState="";
				modelLovator.state="User---Login";
				reset();
			}
		]]>
	</mx:Script>
	<mx:states>
		<mx:State name="success">
			<mx:RemoveChild target="{form1}"/>
			<mx:AddChild position="lastChild" relativeTo="{vbox1}">
				<mx:Text text="LOGIN SUCCESS&#xa;" horizontalCenter="0" verticalCenter="35" fontFamily="Courier New" fontSize="36" color="#EC175D" id="text1"/>
			</mx:AddChild>
			<mx:AddChild position="lastChild" relativeTo="{vbox1}">
				<mx:Button x="220" y="205" label="return" click="returnToLogin()"/>
			</mx:AddChild>
		</mx:State>
		<mx:State name="fail">
			<mx:RemoveChild target="{form1}"/>
			<mx:AddChild position="lastChild" relativeTo="{vbox1}">
				<mx:Text text="FAIL LOGIN&#xa;" fontSize="36" fontFamily="Georgia" color="#0F19E2" horizontalCenter="0" verticalCenter="0"/>
			</mx:AddChild>
			<mx:AddChild position="lastChild" relativeTo="{vbox1}">
				<mx:Button x="232" y="188" label="return" click="returnToLogin()"/>
			</mx:AddChild>
		</mx:State>
	</mx:states>
	<mx:VBox horizontalAlign="center" verticalAlign="middle" horizontalCenter="0" verticalCenter="0" id="vbox1">
		<mx:Text fontSize="18" text="{modelLovator.state}" enabled="true" id="info"/>
		<mx:Form horizontalCenter="4" verticalCenter="1" id="form1">
			<mx:FormItem label="username:" horizontalAlign="center" required="true">
				<mx:TextInput id="userName" text="ljp"/>
			</mx:FormItem>
			<mx:FormItem label="password:" horizontalAlign="center" required="true">
				<mx:TextInput displayAsPassword="true" id="password" text="pass"/>
			</mx:FormItem>
			<mx:FormItem>
			    <mx:HBox>
			    	<mx:Button label="submit" click="submit()"/>
			    	<mx:Button label="reset" click="reset()"/>
			    </mx:HBox>
	
			</mx:FormItem>	  
		</mx:Form>
	</mx:VBox>
</mx:Panel>

接下来我们说说event包,其实这个包我们和接下来说的commands包合并,我在这就分开了,为的是使结构更加清晰哈,在event包下我们存放的是我们自定义的事件,比如下面的LoginEvent.as:
package org.rjb.event
{
	import com.adobe.cairngorm.control.CairngormEvent;
	
	import flash.events.Event;
	
	import org.rjb.vo.UserVO;

	public class LoginEvent extends CairngormEvent
	{
		//定义事件类型常量
		public static const LOGIN_EVENT:String="login";
		//我们可以在这里加入额外的变量,当然是我们需要的哈
		public var userVO:UserVO;
		public function LoginEvent(userVO:UserVO)
		{
			super(LOGIN_EVENT);
			this.userVO=userVO;
		}
		
		override public function clone():Event
		{
			return new LoginEvent(userVO);
		}			
	}
}

好了,我们继续说说在command包下的东东哈,在这里的话主要是存放我们自定义的事件一旦发生的时候,我们究竟要怎么处理它,所以在这下面是我们自定义的类似监听事件的类,但是在这些类中我们一般只相当于一个事件处理的接口,我们会把真正的处理转交给business中的代理类中,尤其是进行远程调用的时候最常用,下面是我们的LoginCommand类:
package org.rjb.command
{
	import com.adobe.cairngorm.commands.ICommand;
	import com.adobe.cairngorm.control.CairngormEvent;
	
	import mx.controls.Alert;
	import mx.core.Application;
	import mx.rpc.IResponder;
	import mx.rpc.events.ResultEvent;
	
	import org.rjb.business.LoginDelegate;
	import org.rjb.event.LoginEvent;
	import org.rjb.model.UserModelLocator;

	public class LoginCommand implements ICommand, IResponder
	{
		//引用单例数据模型
		public var userModelLocator:UserModelLocator=UserModelLocator.getInstance();
		
		public function LoginCommand(){
			
		}
        
        //此处为处理入口,一般我们转交给代理类处理
		public function execute(event:CairngormEvent):void{
			var loginDelegate:LoginDelegate=new LoginDelegate(this);
			var loginEvent:LoginEvent=LoginEvent(event);
			loginDelegate.login(loginEvent.userVO);
		}
		//返回的结果进行处理
		public function result(data:Object):void{
			var result:String=data.toString();
			if(result=="OK"){
				mx.core.Application.application.loginPanel.currentState="success";
				userModelLocator.state="Login---Result";
			}else{
				mx.core.Application.application.loginPanel.currentState="fail";
			    userModelLocator.state="Login---Result";
			}
		}
		//处理过程出错时的处理
		public function fault(info:Object):void{
			mx.controls.Alert.show(info+"");
		}
		
	}
}

再说说这个控制类,也就是control包下的类,这个下面主要是负责分发事件的,我们要把我们的自定义事件和我们的相应的处理方法关联起来,都是在这里进行的,通常一个类就可以了,下面是LoginControl.as的源码:
package org.rjb.control
{
	import com.adobe.cairngorm.control.FrontController;
	
	import org.rjb.event.LoginEvent;
    import org.rjb.command.LoginCommand;
    
	public class LoginControl extends FrontController
	{
		public function LoginControl(){
			this.initialiseCommands();
		}
		
		public function initialiseCommands():void{
			this.addCommand(LoginEvent.LOGIN_EVENT,LoginCommand);
		}
	}
}

最后我们就说说我们的代理类哈,代理类前面已经说了是我们的真正的处理类,我们把视图区的数据传到这里进行处理,最好把结果返回到相应的IResponsder接口实现类中,下面是我们的LoginDelegate.as的源码:
package org.rjb.business
{
	import mx.rpc.IResponder;
	
	import org.rjb.vo.UserVO;
	
	public class LoginDelegate
	{
		public var responder:IResponder;
		public function LoginDelegate(responder:IResponder){
			this.responder=responder;
		}
		public function login(userVO:UserVO):void{
			var result:Object;
			if(userVO.userName=="ljp"&&userVO.password=="pass"){
				result="OK";
			}else{
				result="Fail";
			}
			responder.result(result);
		}
	}
}

好了,基本介绍完了,我们可以测试下了哈,下面是测试代码CairngormTest.mxml:
<?xml version="1.0" encoding="utf-8"?>
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute"
	 xmlns:view="org.rjb.view.*"
	 xmlns:control="org.rjb.control.*"
	 >
	<view:LoginPanel id="loginPanel"  verticalCenter="0" horizontalCenter="0"/>
	<control:LoginControl id="control" />
	
</mx:Application>
,
看看效果吧,当我们运行的时候界面是这样的:



当我们点击submit时如果成功则出现的结果是这样的:



当我们输入的账号密码错误时,出现如下的界面:


好了,这Cairngorm的小demo就到这了,希望能让大家有所收获...
  • 大小: 14.8 KB
  • 大小: 8 KB
  • 大小: 7.9 KB
  • 大小: 7.8 KB
17
0
分享到:
评论
11 楼 surpass_li 2009-10-23  
学习了,谢谢分享
10 楼 dxm1986 2009-09-22  
dxm1986 写道
假笨这个地方怎么弄的呀?
LoginEvent.as中的构造函数是这样的:
public function LoginEvent(userVO:UserVO)  

LoginCommand类中,

public function execute(event:CairngormEvent):void{  
            var loginDelegate:LoginDelegate=new LoginDelegate (this);  
            var loginEvent:LoginEvent=LoginEvent(event);  
            loginDelegate.login(loginEvent.userVO);  
        }  
黑体部份传进去的参数类型是不是有点问题呀?

呵呵.知道看了,看错了.没有一个new
9 楼 dxm1986 2009-09-22  
假笨这个地方怎么弄的呀?
LoginEvent.as中的构造函数是这样的:
public function LoginEvent(userVO:UserVO)  

LoginCommand类中,

public function execute(event:CairngormEvent):void{  
            var loginDelegate:LoginDelegate=new LoginDelegate (this);  
            var loginEvent:LoginEvent=LoginEvent(event);  
            loginDelegate.login(loginEvent.userVO);  
        }  
黑体部份传进去的参数类型是不是有点问题呀?
8 楼 jiangyaning8 2009-01-06  
兄弟不错太棒了 捧场!
7 楼 wuqiangjun_ql 2008-12-10  
先学习一下,有问题的话还希望版主多多指导。
6 楼 nijiaben 2008-11-07  
gdljg0460 写道

很详细的教程,我来顶顶先

呵呵,谢谢兄弟哈,相互学习啦
5 楼 gdljg0460 2008-11-07  
很详细的教程,我来顶顶先
4 楼 yeowin 2008-10-26  
不错啊,  看样子flex把你f的很爽啊,,嘿嘿
3 楼 qianli2008 2008-10-24  
不错啊,我正在使用mate框架,感觉都不错
2 楼 black.angel 2008-10-24  
好,很详细,我也回去磨磨刀。
1 楼 zhangcong170 2008-10-23  
虽然我不懂flex,但是感觉不错啊

相关推荐

    无需编写任何代码即可创建应用程序:Deepseek-R1 和 RooCode AI 编码代理.pdf

    deepseek最新资讯、配置方法、使用技巧,持续更新中

    Heric拓扑并网离网仿真模型:PR单环控制,SogIPLL锁相环及LCL滤波器共模电流抑制技术解析,基于Heric拓扑的离网并网仿真模型研究与应用分析:PR单环控制与Sogipll锁相环的共模电流抑

    Heric拓扑并网离网仿真模型:PR单环控制,SogIPLL锁相环及LCL滤波器共模电流抑制技术解析,基于Heric拓扑的离网并网仿真模型研究与应用分析:PR单环控制与Sogipll锁相环的共模电流抑制效能,#Heric拓扑并离网仿真模型(plecs) 逆变器拓扑为:heric拓扑。 仿真说明: 1.离网时支持非单位功率因数负载。 2.并网时支持功率因数调节。 3.具有共模电流抑制能力(共模电压稳定在Udc 2)。 此外,采用PR单环控制,具有sogipll锁相环,lcl滤波器。 注:(V0004) Plecs版本4.7.3及以上 ,Heric拓扑; 离网仿真; 并网仿真; 非单位功率因数负载; 功率因数调节; 共模电流抑制; 共模电压稳定; PR单环控制; sogipll锁相环; lcl滤波器; Plecs版本4.7.3及以上,Heric拓扑:离网并网仿真模型,支持非单位功率因数与共模电流抑制

    培训机构客户管理系统 2024免费JAVA微信小程序毕设

    2024免费微信小程序毕业设计成品,包括源码+数据库+往届论文资料,附带启动教程和安装包。 启动教程:https://www.bilibili.com/video/BV1BfB2YYEnS 讲解视频:https://www.bilibili.com/video/BV1BVKMeZEYr 技术栈:Uniapp+Vue.js+SpringBoot+MySQL。 开发工具:Idea+VSCode+微信开发者工具。

    基于SMIC 40nm工艺库的先进芯片技术,SMIC 40nm工艺库技术细节揭秘:引领半导体产业新革命,smic40nm工艺库 ,smic40nm; 工艺库; 芯片制造; 纳米技术,SMIC 40nm

    基于SMIC 40nm工艺库的先进芯片技术,SMIC 40nm工艺库技术细节揭秘:引领半导体产业新革命,smic40nm工艺库 ,smic40nm; 工艺库; 芯片制造; 纳米技术,SMIC 40nm工艺库:领先技术驱动的集成电路设计基础

    2013年上半年软件设计师上午题-真题及答案解析

    2013年上半年软件设计师上午题-真题及答案解析

    淮南市乡镇边界,shp格式

    shp格式,可直接导入arcgis使用

    ROS下的移动机器人路径规划算法:基于强化学习算法DQN、DDPG、SAC及TD3的实践与应用,ROS系统中基于强化学习算法的移动机器人路径规划策略研究:应用DQN、DDPG、SAC及TD3算法,RO

    ROS下的移动机器人路径规划算法:基于强化学习算法DQN、DDPG、SAC及TD3的实践与应用,ROS系统中基于强化学习算法的移动机器人路径规划策略研究:应用DQN、DDPG、SAC及TD3算法,ROS下的移动机器人路径规划算法,使用的是 强化学习算法 DQN DDPG SAC TD3等 ,ROS; 移动机器人; 路径规划算法; DQN; DDPG; SAC; TD3,ROS强化学习移动机器人路径规划算法研究

    粒子群优化算法精准辨识锂电池二阶RC模型参数:高仿真精度下的SOC估计铺垫,粒子群优化算法精准辨识锂电池二阶RC模型参数:仿真验证与SOC估计铺垫,使用粒子群优化算法(PSO)辨识锂电池二阶RC模型参

    粒子群优化算法精准辨识锂电池二阶RC模型参数:高仿真精度下的SOC估计铺垫,粒子群优化算法精准辨识锂电池二阶RC模型参数:仿真验证与SOC估计铺垫,使用粒子群优化算法(PSO)辨识锂电池二阶RC模型参数(附MATLAB代码) 使用粒子群优化算法来辨识锂离子电池二阶RC模型的参数。 将粒子群优化算法寻找到的最优参数代入二阶RC模型进行仿真,经过验证,端电压的估计误差小于0.1%,说明粒子群优化算法辨识得到的参数具有较高的精度,为锂离子电池SOC的估计做铺垫。 ,关键词:粒子群优化算法(PSO); 锂电池二阶RC模型参数辨识; MATLAB代码; 端电压估计误差; 锂离子电池SOC估计。,PSO算法优化锂电池二阶RC模型参数:高精度仿真与MATLAB代码实现

    selenium环境搭建-谷歌浏览器驱动

    selenium环境搭建-谷歌浏览器驱动

    35页-华为智慧社区商业解决方案.pdf

    在当今科技日新月异的时代,智慧社区的概念正悄然改变着我们的生活方式。它不仅仅是一个居住的空间,更是一个集成了先进科技、便捷服务与人文关怀的综合性生态系统。以下是对智慧社区整体解决方案的精炼融合,旨在展现其知识性、趣味性与吸引力。 一、智慧社区的科技魅力 智慧社区以智能化设备为核心,通过综合运用物联网、大数据、云计算等技术,实现了社区管理的智能化与高效化。门禁系统采用面部识别技术,让居民无需手动操作即可轻松进出;停车管理智能化,不仅提高了停车效率,还大大减少了找车位的烦恼。同时,安防报警系统能够实时监测家中安全状况,一旦有异常情况,立即联动物业进行处理。此外,智能家居系统更是将便捷性发挥到了极致,通过手机APP即可远程控制家中的灯光、窗帘、空调等设备,让居民随时随地享受舒适生活。 视频监控与可视对讲系统的结合,不仅提升了社区的安全系数,还让居民能够实时查看家中情况,与访客进行视频通话,大大增强了居住的安心感。而电子巡更、公共广播等系统的运用,则进一步保障了社区的治安稳定与信息传递的及时性。这些智能化设备的集成运用,不仅提高了社区的管理效率,更让居民感受到了科技带来的便捷与舒适。 二、智慧社区的增值服务与人文关怀 智慧社区不仅仅关注科技的运用,更注重为居民提供多元化的增值服务与人文关怀。社区内设有互动LED像素灯、顶层花园控制喷泉等创意设施,不仅美化了社区环境,还增强了居民的归属感与幸福感。同时,社区还提供了智能家居的可选追加项,如空气净化器、远程监控摄像机等,让居民能够根据自己的需求进行个性化选择。 智慧社区还充分利用大数据技术,对居民的行为数据进行收集与分析,为居民提供精准化的营销服务。无论是周边的商业信息推送,还是个性化的生活建议,都能让居民感受到社区的智慧与贴心。此外,社区还注重培养居民的环保意识与节能意识,通过智能照明、智能温控等系统的运用,鼓励居民节约资源、保护环境。 三、智慧社区的未来发展与无限可能 智慧社区的未来发展充满了无限可能。随着技术的不断进步与创新,智慧社区将朝着更加智能化、融合化的方向发展。比如,利用人工智能技术进行社区管理与服务,将能够进一步提升社区的智能化水平;而5G、物联网等新技术的运用,则将让智慧社区的连接更加紧密、服务更加高效。 同时,智慧社区还将更加注重居民的体验与需求,通过不断优化智能化设备的功能与服务,让居民享受到更加便捷、舒适的生活。未来,智慧社区将成为人们追求高品质生活的重要选择之一,它不仅是一个居住的空间,更是一个融合了科技、服务、人文关怀的综合性生态系统,让人们的生活更加美好、更加精彩。 综上所述,智慧社区整体解决方案以其科技魅力、增值服务与人文关怀以及未来发展潜力,正吸引着越来越多的关注与认可。它不仅能够提升社区的管理效率与居民的生活品质,更能够为社区的可持续发展注入新的活力与动力。

    PowerSettingsExplorer.rar

    PowerSettingsExplorer.rar 电脑的电源管理软件,明白的不多说。自己搜索即可知道。

    2025年开源人工智能:关键参与者与预测.pdf

    deepseek最新资讯,配置方法,使用技巧,持续更新中

    DeepSeek 发布 Janus Pro AI 图像生成器 – 开源且免费.pdf

    deepseek最新资讯、配置方法、使用技巧,持续更新中

    消息中间件rabbitmq-server

    RabbitMQ 是一个开源的消息代理(Message Broker),实现了 AMQP(Advanced Message Queuing Protocol) 协议,用于在分布式系统中实现高效、可靠的消息传递。

    西门子S7-1200与汇川PLC新通信选择:Ethernet IP通信的突破与优势,功能安全及精准同步的创新实践 ,西门子S7-1200与汇川PLC通信新选择:Ethernet IP通信方案亮相,替代

    西门子S7-1200与汇川PLC新通信选择:Ethernet IP通信的突破与优势,功能安全及精准同步的创新实践。,西门子S7-1200与汇川PLC通信新选择:Ethernet IP通信方案亮相,替代Modbus TCP实现更高级功能与安全控制。,西门子PLC和汇川PLC新通信选择-西门子S7-1200 1500系列PLC也开始支持Ethernet IP通信了。 这为西门子系列的PLC和包括汇川AM400 600等Codesys系PLC的通信提供了新的解决方案。 当前两者之间的通信大多采用ModBus TCP通信。 Modbus TCP和EtherNet IP的区别主要是应用层不相同,ModbusTCP的应用层采用Modbus协议,而EtherNetIP采用CIP协议,这两种工业以太网的数据链路层采用的是CSMACCD,因此是标准的以太网,另外,这两种工业以太网的网络层和传输层采用TCPIP协议族。 还有一个区别是,Modbus协议中迄今没有协议来完成功能安全、高精度同步和运功控制等,而EtherNet IP有CIPSatety、ClIP Sync和ClPMotion来

    自适应无迹卡尔曼滤波AUKF算法:系统估计效果展示与特性分析(含MATLAB代码与Excel数据),自适应无迹卡尔曼滤波AUKF算法:系统估计效果展示与特性分析(含MATLAB代码与Excel数据)

    自适应无迹卡尔曼滤波AUKF算法:系统估计效果展示与特性分析(含MATLAB代码与Excel数据),自适应无迹卡尔曼滤波AUKF算法:系统估计效果展示与特性分析(含MATLAB代码与Excel数据),自适应无迹卡尔曼滤波AUKF算法 配套文件包含MATLAB代码+excel数据+学习资料 估计效果与系统特性有关,图片展示为一复杂系统估计效果 ,AUKF算法; MATLAB代码; excel数据; 学习资料; 估计效果; 系统特性。,自适应无迹卡尔曼滤波AUKF算法:MATLAB代码与学习资料

    基于MATLAB Simscape的IGBT开关特性模型:揭示开关损耗、米勒平台及瞬态行为的分析工具,IGBT开关特性模型与MATLAB Simscape模拟:深入理解开关行为及损耗数据,IGBT开关

    基于MATLAB Simscape的IGBT开关特性模型:揭示开关损耗、米勒平台及瞬态行为的分析工具,IGBT开关特性模型与MATLAB Simscape模拟:深入理解开关行为及损耗数据,IGBT开关特性模型,MATLAB Simscape模型。 该模型展示了IGBT的详细的开关模型,用于创建开关损耗列表数据。 有助于理解IGBT米勒平台、瞬态开关行为。 也可以用于MOOSFET。 ,IGBT开关模型; MATLAB Simscape; 开关损耗; 米勒平台; 瞬态开关行为; MOOSFET。,MATLAB Simscape中IGBT精细开关模型:揭示米勒平台与瞬态行为

    基于卷积神经网络CNN的多输入单输出数据回归预测-含详细注释与多种评估指标(R2、MAE、MBE),基于卷积神经网络CNN的多输入单输出数据回归预测模型详解-附代码注释、指标评估及Excel数据处

    基于卷积神经网络CNN的多输入单输出数据回归预测——含详细注释与多种评估指标(R2、MAE、MBE),基于卷积神经网络CNN的多输入单输出数据回归预测模型详解——附代码注释、指标评估及Excel数据处理方法,基于卷积神经网络CNN的数据回归预测 多输入单输出预测 代码含详细注释,不负责 数据存入Excel,替方便,指标计算有决定系数R2,平均绝对误差MAE,平均相对误差MBE ,基于卷积神经网络CNN; 数据回归预测; 多输入单输出; 详细注释; Excel存储; 指标计算(R2; MAE; MBE); 不负责。,基于CNN的卷积数据回归预测模型:多输入单输出代码详解与性能评估

    四六级词汇系统 2024免费JAVA微信小程序毕设

    2024免费微信小程序毕业设计成品,包括源码+数据库+往届论文资料,附带启动教程和安装包。 启动教程:https://www.bilibili.com/video/BV1BfB2YYEnS 讲解视频:https://www.bilibili.com/video/BV1BVKMeZEYr 技术栈:Uniapp+Vue.js+SpringBoot+MySQL。 开发工具:Idea+VSCode+微信开发者工具。

Global site tag (gtag.js) - Google Analytics