CAPL编程

1、CAPL概述
       

与Vspy的"C Code Interface"一样;在CANoe的使用中,一样提供了我们进行二次编程开发的工具——”CAPL Browser”。通过CAPL的编程,我们可以在节点上完成更为复杂的功能需求。操作如下:在CANoe工程的”Simulation Setup”界面下的左侧的网络节点中,点击铅笔形状的图标,进入CAPL编辑界面(若当前节点还没有创建对应的CAPL程序,则此时会先提示输入CAPL程序名,并保存为.can后缀的文件)

1.1、CAPL语言特性


CAPL(Communication Access Programming Laguage)语言是类C语言,语法其实与C语言很相似,但同时又包含了一些C++的特性,如this指针、事件等;
应用于Vector CAN工具节点的编程,是基于事件建模的语言;
可以使用write()函数进行调试,用于将调试信息输出到CANoe的write窗口上;
通过output()函数进行指定报文的发送;
通常是通过环境变量事件与CANoe面板进行关联,实现交互;
提供调用dll文件的方法(操作见"关于CAPL中对dll的调用操作"一文);这样保证了对由其他语言封装好的程序模块的调用;


        
1.2、CAPL的程序结构


        如下,一个完整的CAPL程序的结构包含了头文件、全局变量、事件函数、自定义函数;当然不是每个因素都要有,视具体程序功能确定。

variables里面可以给报文定义为变量

message 0x431 msg1;//将报文0x431定义为变量msg1
message * msg;//先声明报文,暂时没有ID
msg.can = 1;//将这条报文设置为通道1
msg.id = 0x23;//报文ID为0x23
//msg.name = "mymsg";//报文名称是只读的
msg.dlc = 8;//报文长度
msg.byte(0) = 0x10;//报文第0个字节的内容
output(msg);//发送报文

1.3、CAPL的数据类型

1.4、CAPL事件类型概述

        CAPL是基于事件建模的语言,从1.2小节对CAPL的程序结构的介绍也可以看出,关于CAPL的运用主要就是在于熟悉其事件的使用;其常用的事件如下:

2、CAPL事件类型
        

2.1、系统事件


        在CAPL的系统事件中,有preStart、start、preStop、stopMeasurement这4种。我们可以根据需要在相应的系统事件函数接口中定义想要进行的操作;当工程运行时,下述系统事件的发生顺序依次是

preStart-->start-->preStop-->stopMeasurement

关于系统事件的定义格式如下

on preStart   	  			/*系统事件,初始化时执行*/
{
 	resetCan();      			/*CAPL接口函数,用于复位CAN控制器*/
}

on start        			/*系统事件,工程开始时执行*/
{
 	write(“Just A Try”);    	/*write()函数将字符串信息在”write”窗口输出*/
}


on preStop    				/*系统事件,工程预备停止时执行;发生在stopMeasurement事件前面*/
{
  	write("The Project Will Stop!”);
}

on stopMeasurement  		/*系统事件,工程停止时执行*/
{
  	write("The End!\n");
}

2.2、CAN控制器事件

        当硬件对CAN控制器检测到相应动作发生时执行;以BusOff事件为例,格式如下:

	on busOff       /*CAN控制器事件:硬件检测到BusOff时执行*/
	{
	  	write("BusOff Error!");
	}

2.3、CAN消息事件

        通过”on message”定义消息事件,该事件会在指定的报文消息被接收时被调用。关于消息事件的定义格式示例如下

on message 123         		/*接收到123(10进制)这个ID的报文时执行*/
on message 0x441       		/*接收到0x441(16进制)这个ID的报文时执行*/
on message BCM 	       		/*接收到BCM(工程dbc文件中的报文名)这个报文时执行*/
on message*	      			/*接收到任意报文时都执行(注意*与message之间没有空格)*/
on message 0x300-0x444	 	/*接收到这个范围内的ID报文时执行*/
{
  	write(“Received %x”,this.id);	 /*打印接收到的报文id*/
  	write(“Received Message %d in total!”,count);
}

  以上是关于消息事件的定义格式,关于消息的索引及发送操作我们通过下例介绍:
        假设VoiceStatus是我们工程dbc文件中定义的一个报文,该报文包括了VoiceType和VoiceOperation这两个信号;其中,VoiceType这个变量占据第1个字节;VoiceOperation占据第2、3个字节;则关于消息的索引,通过报文的信号(msg.VoiceType这样)去操作如下:
 

void TxMsg_VoiceStatus(void) 
{
    message VoiceStatus msg;         /*将工程中dbc中定义的VoiceStatus这条报文取名为msg*/
    msg.VoiceType = @VoiceType;      /*对应赋值给到报文的信号,通过报文别名"msg."调出*/
    msg.VoiceOperation = @VoiceOperation;
    output(msg);                     /*通过output指令发送该报文*/
}

2.4、信号事件

信号变化时触发

on signal sig
{
    write("signal change");
}

只要周期存在,就会一直触发

on signal sig update
{
    write("signal update");
}

2.5、键盘事件

        通过”on key”定义键盘事件,该事件会在我们按下指定按键时执行;关于键盘事件的定义格式示例如下

on key ‘a’      	/*在小写输入法下,按下键盘的’A’键时执行*/
on key ‘A’      	/*在大写输入法下,按下键盘的’A’键时执行*/
on key ‘ ’      	/*按下键盘的空格键时执行,注意单引号中间是有空格的*/
on key 0x20     	/*按下键盘的空格键时执行*/
on key F2      	    /*按下键盘的’F2’键时执行*/
on key CtrlF3      	/*同时按下键盘的’Ctrl’键和’F3’键时执行*/
on key*      		/*按下键盘的任意键时都会执行(注意*与key之间没有空格) */
{
  	write(“The Key Is Press”);
}

2.6、时间事件

        通过”on timer”定义时间事件;该事件会在设定的时间到达时执行。关于时间事件的定义格式及使用示例如下

variables
{
  msTimer Timer1;    		/*在variables中声明一个以ms为单位的定时器变量Timer1*/
}

on start
{
  setTimer(Timer1,100);     /*将Timer1的定时时间设定为100ms,并启动它*/
}

on timer Timer1  	 		/*定义的Timer1时间事件,每100ms执行一次*/
{
  setTimer(Timer1,100);     /*启动下一个周期循环*/
}

on key ‘a‘		 			/*键盘事件,按下键盘’A’键时执行*/
{
  cancelTimer(Timer1);	 	/*停止Timer1这个100ms执行一次的定时器*/
}

2.7、错误帧事件

        通过”on errorFrame ”定义错误帧事件;该事件会在硬件检测到错误帧时执行。关于错误帧事件的定义格式示例如下

on errorFrame       /*错误帧事件:硬件检测到错误帧时执行*/
{
  write("The error has occur"); 
}

2.8、环境变量事件


        通过”on envVar”定义环境变量事件;该事件会在指定的环境变量值有新的输入时执行(环境变量常常用于关联上一个面板控件,当我们对控件进行操作时,对应改变关联上的环境变量值;而此时我们在CAPL中关于该环境变量的事件就会被调用;以此完成交互操作)。关于环境变量事件的定义格式示例如下:
 

on envVar BCM_HightBeamAlarm    /*环境变量事件:指定的环境变量值有输入时执行*/
{
	  byte num=0;
	  num = getValue(this);     /*可以使用getValue(环境变量名/this关键字)获取指定的环境变量的值*/
	  if(num == 1)
	  {
	    write("The envVar is %d",@BCM_HightBeamAlarm);  
	  }
	  else
	  {
	    putValue(this,1);/*使用putValue(环境变量名/this关键字,设定的值)改变指定的环境变量的值;直接赋值的话,格式是@BCM_HightBeamAlarm = 1; */
	    write("Change envVar to %d",@BCM_HightBeamAlarm);
	  }
}

关于在CAPL中对环境变量的操作中,getValue()与putValue()是常用的接口函数。其函数格式如下,具体介绍及示例也可以通过神键"F1"召唤帮助文档,在"CAPL"相关章节中进行学习。

Ps:关于环境变量的定义是在dbc文件中完成的;CANoe工程导入该dbc文件即可使用其定义的环境变量了。环境变量的创建如下:

2.9、系统变量事件


        通过”on sysvar”定义系统变量事件;该事件会在指定的系统变量值有新的输入时执行,其格式及使用方法与前一小节的环境变量基本一致;差别只在于环境变量是在dbc文件中定义的;而系统变量的定义如下:
        点击工具栏的”Environment”下的”System Variables”;此时界面如下,右键空白处,选择”New”进行新建;在弹出的窗口对新建的系统变量进行参数设置。

一般来说,前面带@的就是系统变量。

        关于系统变量事件的定义格式示例如下:

	on sysvar SysVar1	 /*系统变量事件:指定的系统变量值有新的输入时执行*/
	{
	  	write("The SysVar1 is %d",@SysVar1);
	}

3、CAPL文件

添加模块

在Simulation Setup界面对着总线右键,insert Network Node。建议不要选CAPL测试那个,我还没搞懂那个是拿来干嘛的,一运行就报错。想要编辑源文件的话,就双击元件打开。

模块设置

对着元件右键configuration,就可以配置元件,源文件后缀是can

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

不吃鱼的羊

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值