Go to documentation repository
To illustrate available fields of application of scripts in JScript see the following examples which can be used to create additional functions in the system on the basis of the Script object.
The Queue length detection object (part of the DetectorPack package), Camera and Captioner objects (instead of N, M, L symbols set the corresponding numbers of the Queue length detection, Camera and Captioner objects) are to be created and configured for correct script working in the Axxon PSIM software.
//Event reading by the queue length if (Event.SourceType == "OCCUPANCY_COUNTER" && Event.SourceId == "N" && Event.Action == "OCCUPANCY") //N - Number of Queue length detection { var n=Event.GetParam("occupancy"); //Displaying the queue number by the Captioner in the Monitor DoReactStr("CAM","M","CLEAR_SUBTITLES","title_id<L>"); //M - Number of Camera L - Number of Captioner DoReactStr("CAM","M","ADD_SUBTITLES","command<Queue length: "+n+" person(s).\r>,page<BEGIN>,title_id<L>"); //M, L - the same }
As a result the text message about the current queue length will be imposed on the video image while displaying the corresponding camera in the Video Surveillance monitor.
Settings of the font, color and position of text is configured on the settings panel of the Captioner object.
Note
When page<BEGIN> and page<END> parameters are in use, the corresponding fields of the subtitles database are filled in. This enables data search using the Search by titles interface object.
The People Counter Detection object (part of the DetectorPack package), Camera, Captioner and Macro objects (instead of N, M, L, P symbols set the corresponding numbers of the People counter detection, Camera, Captioner and Macro objects) are to be created and configured for correct script working in Axxon PSIM.
//Event reading and counting of entered people if (Event.SourceType == "PEOPLE_COUNTER" && Event.SourceId == "N" && Event.Action == "IN") //N - Number of People Counter detection { i = Itv_var("counter_i"); k = Itv_var("counter_k"); i++; Itv_var("counter_i")=i; //Displaying the number of people by Captioner in the Monitor DoReactStr("CAM","M","CLEAR_SUBTITLES","title_id<L>"); //M - Number of Camera L - Number of Captioner DoReactStr("CAM","M","ADD_SUBTITLES","command<Number of people (entering/exiting): "+i+" / "+k+"\r>,page<BEGIN>,title_id<L>"); //M, L - the same } //Event reading and counting of exitng people if (Event.SourceType == "PEOPLE_COUNTER" && Event.SourceId == "N" && Event.Action == "OUT") //N - Number of People Counter detection { i = Itv_var("counter_i"); k = Itv_var("counter_k"); k++; Itv_var("counter_k")=k; //Displaying the number of people by Captioner in the Monitor DoReactStr("CAM","M","CLEAR_SUBTITLES","title_id<L>"); //M - Number of Camera L - Number of Captioner DoReactStr("CAM","M","ADD_SUBTITLES","command<Number of people (entering/exiting): "+i+" / "+k+"\r>,page<BEGIN>,title_id<L>"); //M, L - the same } //Null the counter by Macro (previously the Macro is to be created in the Axxon PSIM) if (Event.SourceType == "MACRO" && Event.SourceId == "P" && Event.Action == "RUN") //P - Number of Macro { Itv_var("counter_i")=0; Itv_var("counter_k")=0; i=0; k=0; //Displaying number of people by Captioner in the Monitor DoReactStr("CAM","M","CLEAR_SUBTITLES","title_id<L>"); //M - Number of Camera L - Number of Captioner DoReactStr("CAM","M","ADD_SUBTITLES","command<Number of people (entering/exiting): "+i+" / "+k+"\r>,page<BEGIN>,title_id<L>"); //M, L - the same }
As a result the text message about number of entering and exiting people will be imposed on the video image while displaying the corresponding camera in the Video Surveillance monitor.
Note
When page<BEGIN> and page<END> parameters are in use, the corresponding fields of the subtitles database are filled in. This enables data search using the Search by titles interface object.
Settings of the font, color and position of text is configured on the settings panel of the Captioner object (see Configuring captions display on a video image).
Previously create the Macro object on the Programming tab to null the counter of visitors. The name of the object can be changed to “Null of people counter” for ease of using.
Macro of setting to zero can be run manually by main menu of Axxon PSIM or automatically in any specified time (use the Events table on the settings panel of the Macro object where the previously configured Time zone object is to be specified). Detailed information about using the Macro and Time zone objects is given in the Administrator’s Guide document).
It is possible to select the type of Text displaying while attaching object to the map (see Attaching objects to the layers of interactive map). Also the script on the JScript language can be used for changing the displayed text.
Example. The Text type of display on the map is selected for the Camera 1. It's required to display value of the MyVar value read from the C:\test.ini file on the map and debug window while processing the Macro 1.
if(Event.SourceType == "MACRO" && Event.Action == "RUN") { var result = parseInt(ReadIni("MyVar","C:\\test.ini")); result += 2; NotifyEventStr("CAM","1","ANALOG_PARAMS","text<Variable value = \n" + result + ">, blink_state<1>"); DebugLogString(result); }
The following example is valid only for cameras in configuration of which there is PTZ control panel. When configuring Video surveillance monitor select the Go to preset action with 1,2,3...,0 parameters for ten joystick buttons (see Assigning commands to joystick buttons using the Monitor section of Installing and configuring security system components guide).
Example. When the button is clicked on the control panel, display corresponding camera in the active monitor. The script is to timer trigger with ID=1.
Note
The Timer object is to be created and configured beforehand and the current year is to be set. Information on how to configure the Timer object can be found in Creating and configuring the Timer object.
After each button click on the control panel wait for 2 seconds until clicking another button. If there is no button click, then the camera with dialed number is to be displayed.
if (Event.SourceType=="TIMER" && Event.SourceId=="1" && Event.Action=="TRIGGER") { mon="1"; DebugLogString("on monitor "+ Itv_var("cam")); DoReactStr("MONITOR",mon,"ACTIVATE_CAM","cam<"+Itv_var("cam")+">"); Itv_var("cam")=""; } if (Event.GetParam("source_type")=="TELEMETRY" && Event.GetParam("action")=="GO_PRESET") { DoReactStr("TIMER","1","START","bound<2>"); var key=Event.GetParam("param4_val"); DebugLogString("Key:"+key); Itv_var("cam")=Itv_var("cam")+key; DebugLogString(Itv_var("cam")); }
Example. Camera IP address is 192.168.0.13.
The command enables the camera wiper:
192.168.10.101/httpapi/SendPTZ?action=sendptz&PTZ_PRESETSET=85
The command disables the camera wiper:
192.168.10.101/httpapi/SendPTZ?action=sendptz&PTZ_PRESETSET=86
These commands are to be sent to camera using the JScript script.
function DoPreset(preset) { xmlhttp=new ActiveXObject("MSXML2.XMLHTTP"); if(xmlhttp == null) { return; } xmlhttp.open("GET", "http://192.168.0.13/httpapi/SendPTZ?action=sendptz&PTZ_PRESETSET="+preset, false,"admin","1234"); xmlhttp.send(); DebugLogString(xmlhttp.status); } if (Event.SourceType == "MACRO" && Event.SourceId == "6" && Event.Action == "RUN") { DoPreset("85"); } if (Event.SourceType == "MACRO" && Event.SourceId == "7" && Event.Action == "RUN") { DoPreset("86"); }
If the object tracking function is in use (see Creating and configuring the Timer object), then detected objects will be framed in video when viewing the archive. To frame abandoned objects in live video use the script aimed to frame an abandoned object when receiving alarm from VMDA detection tool:
if (Event.SourceType=="CAM_VMDA_DETECTOR") { cam=GetObjectParentId("CAM_VMDA_DETECTOR",Event.SourceId,"CAM"); if (Event.Action=="ALARM") { var x1,x2,y1,y2; x1=Event.GetParam("x"); x2=Event.GetParam("w"); y1=Event.GetParam("y"); y2=Event.GetParam("h"); x2=parseInt(x1)+parseInt(x2); y2=parseInt(y1)+parseInt(y2); DoReactStr("MONITOR","","SET_MARKRECT","cam<"+cam+">,color<255>,id<"+cam+">,x1<"+x1+">,x2<"+x2+">,y1<"+y1+">,y2<"+y2+">"); DebugLogString("x1:"+x1+" x2:"+x2+" y1:"+y1+" y2:"+y2); } else { DoReactStr("MONITOR","","DEL_MARKRECT","cam<"+cam+">,id<"+cam+">"); } }
Objects from more than one main Server are not to be moved to the Backup Server. For this when moving objects from some main Server to the Backup Server all other Failover objects are to be disabled on this Backup Server.
if (Event.SourceType == "FAILOVER" ) { if (Event.Action == "START") {action="DISABLE";} if (Event.Action == "STOP") {action="ENABLE";} id=Event.SourceId; msg=CreateMsg(); msg.StringToMsg(GetObjectIds("FAILOVER")); var objCount=msg.GetParam("id.count"); for (i=0;i<objCount;i++) { pid=msg.GetParam("id."+i); if (!(id==pid)) { DoReactStr("FAILOVER",pid,action,""); } } }
Upon reaching the number of visitors equal to 20 on the embedded visitors counter of the Bosch FLEXIDOME IP dynamic 7000 VR IP camera (with ID 1), call the macro 1.
n=20; if(Event.SourceType == "CAM_IP_DETECTOR" && Event.SourceId=="1" && Event.Action == "DETECTED") { v=Event.GetParam("param0").split(";")[1]; if (parseInt(v.split(":")[1])==n) { DoReactStr("MACRO","1","RUN",""); } }
By macro 1, send a message with the attached files detected.png and found.jpg from the folder C:\\Pictures\\ to example@gmail.com. The message should be formatted as follows:
Face detected
Detected face | Face in DB |
detected.png file | found.jpg file |
if(Event.SourceType == "MACRO" && Event.SourceId=="1" &&Event.Action=="RUN") { var file1 = "detected.png"; var file2 = "found.jpg"; var file_folder = "C:\\Pictures\\"; var test_event = CreateMsg(); test_event.StringToMsg("MAIL_MESSAGE|1|SEND_RAW|cc<>,to<daniel@AxxonSoft.com>,objname<Mail message 1>,subject<>,parent_id<1>,flags<>,pack<>,name<Mail message 1>,from<example@gmail.com>,_marker<>"); test_event.SetParam("body","<html><body>\r\n<h3>Face found</h3>\r\n<table><tr>\r\n<td>Detected</td><td>Found in DB</td>\r\n</tr><tr>\r\n<td><img width='200' alt='image1' src='cid:" + file1 + "'/></td>\r\n<td><img width='200' alt='image2' src='cid:" + file2 + "'/></td>\r\n</tr><tr>\r\n<td>E-mail sent from Axxon PSIM</td>\r\n</tr></table>\r\n</body></html>"); test_event.SetParam("attachments",file_folder+file1+";" + file_folder+file2); test_event.SetParam("is_body_html", 1); DoReact(test_event); }
Using macro 101, create 50 users in Axxon PSIM with IDs from 100 to 150, assigning them an access level with ID 1 (provided that the AL is assigned to the department to which the users are added and users inherit the department AL) and linking an access card with a number, equal to the user ID. The card number must be in HEX format. The department should have no more than 30 users (to speed up the adding process).
Note
For more information on access levels and access cards, see the ACFA PSIM documentation in the AxxonSoft documentation repository.
If an ACS integration is configured in Axxon PSIM, which supports dynamic user recording, then the created user will be automatically written to the ACS controller when the CORE||UPDATE_OBJECT|objtype<PERSON> event is sent. If dynamics is not supported, then recording users to the controller will need to be initiated manually.
dep=10; // department ID start=100;// first user ID last=150; // last user ID acc_lev=1; // access level ID dep_count=30; // max number of users in the department if( Event.SourceType == "MACRO" && Event.Action == "RUN" && Event.SourceId=="101") { kol=0; card_count=0; NotifyEventStr("CORE","","UPDATE_OBJECT","objtype<DEPARTMENT>,objid<"+dep+">"); for (i=start;i<=last;i++) { kol++; card_count++; card=decToHex(card_count); if (card[card.length-1]==0) { card_count++; card=decToHex(card_count); } if (kol==dep_count) { NotifyEventStr("CORE","","UPDATE_OBJECT", "objtype<PERSON>,objid<"+i+">,name<user"+i+">,parent_id<"+dep+">, level_id<"+acc_lev+">, facility_code<0>, card<"+card+">"); kol=0; dep++; NotifyEventStr("CORE","","UPDATE_OBJECT","objtype<DEPARTMENT>,objid<"+dep+">"); } else { NotifyEventStr("CORE","","UPDATE_OBJECT", "objtype<PERSON>,objid<"+i+">,name<user"+i+">,parent_id<"+dep+">,level_id<"+acc_lev+">, facility_code<0>,card<"+card+">"); } Sleep(10); } } function decToHex(n) { return Number(n).toString(16); }
When working with objects in the Incident manager, it is possible to change the event status of an object (see Processing events). To change the event status of an object, you can use a JScript script.
Example. On macro 3, change the status of the camera 1 or 2 Alarm event to Completed.
if (Event.SourceType == "MACRO" && Event.SourceId == 3 && Event.Action == "RUN") { DoReactStr("INC_SERVER","1","UPDATE_STATUS","status<3>,objtypes<CAM>,objids<1|2>,actions<MD_START|MD_START>"); };