Go to documentation repository
Documentation for Intellect 4.11.0-4.11.3. Documentation for other versions of Intellect is available too.
Previous page Next page
The CAM object corresponds to the Camera system object.
The CAM object sends events given in the table. Procedure is started when the corresponding event appears.
Format of event procedure for the Camera object:
OnEvent("CAM","_id_","_event_")
Description of events of the CAM object.
Events | Description | Comment |
"ARM" | Camera is armed. | If arming was performed by the Operator from the Map or Video surveillance monitor, the user_id<> parameter contains the identifier of the user who performed this action. |
"ATTACH" | Connecting. | |
"BLINDING" | Camera is sealed. | |
"DETACH" | Break. | Event is generated while loss the input signal from camera on video capture device. |
"DISARM" | Camera is disarmed. | If disarming was performed by the Operator from the Map or Video surveillance monitor, the user_id<> parameter contains the identifier of the user who performed this action. |
"FILE_REC_ERROR" | Error of recording on disk. | Event is generated while error of video archive recording on disk happens. |
"MD_START" | Alarm. | |
"MD_STOP" | End of alarm. | |
"PRINT" | Print frame. | |
"REC" | Recording on disk. | If recording was initiated by the Operator from the Map or Video surveillance monitor, the user_id<> parameter contains the identifier of the user who performed this action. |
"REC_STOP" | Stop recording on disk. | If recording was stopped by the Operator from the Map or Video surveillance monitor, the user_id<> parameter contains the identifier of the user who performed this action. |
"UNBLINDING" | Camera is opened. | |
"RECORDER_ON" | Record is enabled. | |
"RECORDER_OFF" | Record is disabled. | |
"DISC_MOUNT" | Disk is mounted. | |
"DISC_UNMOUNT" | Disk is unmounted. | |
"FINISHED_AVI_EXPORT" | Video export is completed | If the video export fails, the event has nonnull error_result parameter. In the param<0> parameter there is additional information displayed in the corresponding column of the Event Viewer, in the following format: "ComputerName;ExportPeriod;UserName;UserID", for example, param0<LOCALHOST;04-06-18 16:50:55_04-06-18 16:55:55;Smith;1> |
"MD_LIMIT" | Object count in a frame exceeded. | The event is generated when the number of objects detected by the tracker in the frame is exceeded (see Creating and configuring the Tracker object section of the Administrator's Guide for details on how to set this parameter). An event is generated whenever the number of objects is changed (up or down), until it is less than the threshold. The object_count <> parameter is the number of objects in the frame that the tracker detected, exceeds the specified limit, and differs from the previous value. See also the description of the NEW_OBJECT event below. |
"NEW_OBJECT" | New object on a frame detected by tracker. | Among others, it contains the following parameters: total <> is the total number of objects in the frame at the time the event occurred. new_id <> is the identifier of the detected object. |
"ARCH_DELETE" | Record deletion | Deletion of the record from the camera archive via the Video Surveillance Monitor. |
"OPEN_FILE" | Opening file | Opening a file for playback by a virtual video capture device. Indicates that playback of the next file from the selected folder starts. Among others, the event contains the following parameters: name <> – the name of the file being played. tss <> – time in UTC format in milliseconds from 1/1/1970. |
"CLOSE_FILE" | Closing file | Finishing a file playback in a virtual video capture device. Indicates that playback of a file is ended. Among others, the event contains the following parameters: name <> – the name of the file that finished being played. tss <> – time in UTC format in milliseconds from 1/1/1970. |
"ARCH_PROTECTED" | File protected from rewriting | The event is displayed when a user protects the file from being overwritten. The param <0> parameter contains additional information about the computer name, fragment protected, user name and user id, which is displayed in the Add. Info column in the Event Viewer in the following format: "ComputerName;ProtectionPeriod;UserName;UserID", for example, param0<LOCALHOST;04-06-18 16:50:55.612_04-06-18 16:55:55.612;Smith;1> |
"ARCH_UNPROTECTED" | Rewrite protection removed from file | The event is displayed when a user removes protection of the file from being overwritten. The param <0> parameter contains additional information about the computer name, fragment protected, user name and user id, which is displayed in the Add. Info column in the Event Viewer in the following format: "ComputerName;ProtectionPeriod;UserName;UserID", for example, param0<LOCALHOST;04-06-18 16:50:55.612_04-06-18 16:55:55.612;Smith;1> |
FRAME_SKIPPED | Frame skipped | The event arrives at Intellect if there is a problem with frame skipping. A separate event for each skipped frame. This event can be disabled using the FileSystem.NotifyCoreFrameSkipped registry key (see Registry keys reference guide). |
ARCH_BOOKMARKED | Bookmark created | The event is displayed when a user adds a bookmark. The param <0> (i.e. the Add. Info column in the Event Viewer) parameter contains the comment to the bookmark. |
ARCH_UNBOOKMARKED | Bookmark deleted | The event is displayed when a user deletes a bookmark. |
TEMPERATURE_ALARM | Temperature threshold | param0<> contains the temperature value received from the thermal camera. |
Operator format to describe actions with the camera is:
DoReact("CAM","_id_","_command_" [,"_parameters_"]);
The list of commands and parameters for the CAM object is given in the following table:
Command – command description | Parameters | Description of parameters |
"SETUP" – sets (changes) parameters of camera | rec_priority<> | Record priority (from 0 to 3, 0 – standard, 3 – all recources). |
compression<> | Compression ration (0 – no compression, 1- maximal quility, …, 5 – minimal quality). | |
sat_u<> | Value of colour (0 – min, 10 – max). | |
proc_time<> | Append period (0 – 30 sec). | |
manual<> | Control brightness and contrast settings (0 – manual; 1 – auto; 2 – auto, but close to values specified manually). | |
contrast<> | Contrast (0 – min, 10 – max). | |
md_size<> | Size of motion detection objects (1 -16). | |
md_mode<> | Mode of pause record (1 – enabled, 0 disabled). | |
audio_type<> | Type of sound accompaniment. | |
pre_rec_time<> | Time of pre-record (0 – 20 sec). | |
bright<> | Brightness (0 – min, 10 – max). | |
audio_id<> | Number of microphone (empty parameter if there is no microphone). | |
rec_time<> | Record speed (1 – 30 fps, 0 – not used). | |
alarm_rec<> | Record of alarms (1 – enabled, 0 – disabled). | |
hot_rec_time<> | Time of hot record (0 – 30 sec). | |
hot_rec_period<> | Period of hot (0 – 20 sec). | |
mux<> | Number of channel (0 – 1 channel, 15 – 16 channel). | |
color<> | Colour (0 – black and white, 1 – multicolor). | |
activity<> | - | |
arch_days<> | Number of archive days. | |
blinding<> | Camera is sealed. | |
config_id<> | - | |
decoder<> | - | |
flags<> | Flags. | |
fps<> | Speed of record (0 – not used, 1 – 30 fps). | |
ifreq<> | Frequency of anchor frames in sequence (1 – each frame is anchor, 2 – 100 frame). | |
mask 0, mask1, mask2, mask3, mask4 | Detection mask. | |
md_contrast<> | Sensibility of motion detection (0 – 15). | |
motion<> | Estimation of motion compressor (5 - 255). | |
name<> | Name of object. | |
password_crc<> | Password for video archive. | |
priority<> | Priority of record resource (0 – auto, 1 – manual). | |
resolution<> | Resolution (0 – standard CIF, 1 - high 2CIF, 2 –maximal 4CIF). | |
type<> | Type of object. | |
yuv<> | Colour schema of video signal coding (0 – YUV4:2:0, 1 - YUV4:2:2). | |
"DELETE" – disables camera. | - | - |
"START_VIDEO" – enables video stream for current camera. | slave_id<> | Name of computer to which camera is connected. |
comress<> | Value of compression. | |
register_only<> | - | |
"STOP_VIDEO" – disables video stream for current camera. | slave_id<> | Name of computer to which camera is connected. |
"REQUEST_MASK" | mask<> | Mask. |
"MUX1", "MUX2", "MUX3" – display image of camera on 1, 2, 3 analog outputs. | - | - |
"ACTIVATE" – display camera on monitor. | monitor<> | Number of monitor. |
"ARM" – arm camera. | - | - |
"DISARM" – disarm camera. | - | - |
"REC" – start record from camera. | time<> | Time of record in seconds, if null than only one frame is recorded. |
rollback<> | If one, than record is performed with rollback. | |
priority<> | Set priority of command to start record. See Appendix 1. Priorities of start and stop recording commands | |
stream_id<> | Set an identification number of stream for record. Stream ID is set as "n.m" where n is the Camera object ID, m is the number of the stream. Note. If the specified stream is not in use for any purpose other than record by command (and custom on clients), make sure that the Lock disabling streams not in use checkbox is set checked for it – see the The Settings panel of the Camera object section of the Administrator's Guide. | |
"REC_STOP" – stop record from camera. | priority<> | Set priority of command to stop record. See Appendix 1. Priorities of start and stop recording commands |
user_id<> | If record was stopped by a user from the Video Surveillance Monitor, the parameter contains the user ID. Otherwise the parameter is absent. | |
from_macro<> | If record was stopped by a macro, the parameter contains the macro ID. Otherwise the parameter is absent. | |
"SET_MASK" – set mask. | mask<> | Mask. |
"ADD_SUBTITLES" – add titles. | command<> | Test of imposed titles. |
title_id<> | ID of Captioner object which is used to impose. | |
page<> | Required parameter to allow recording titles to the titles database to provide search by titles. Available values: BEGIN (start of record in database), END (end of record in database). | |
"SIP_CONNECT" - Sip connected | - | - |
"SIP_DISCONNECT" – Sip disconnected | - | - |
"SET_IPINT_PARAM" – Set (change) parameters of IP-device. Reaction allows changing of IP-device settings not entering its web-interface. Note. For reaction operation it is required to enable the mode of multi-flow video signal - see. Administrator's Guide, section Configuration of multistream video, and Appendix 2. Defining param_id and param_value values for SET_IPINT_PARAM reaction | param_id<> | Name of parameter. Set of parameters for each camera is individual - see Appendix 2. Defining param_id and param_value values for SET_IPINT_PARAM reaction |
param_value<> | Value of parameter. Set of parameters for each camera is individual - see Appendix 2. Defining param_id and param_value values for SET_IPINT_PARAM reaction | |
vstream_id<> | Number of video flow (optional parameter). Is given by “Number of camera”.”Number of flow”, for example 1.1, 1.2. | |
GET_FRAME – get frame from camera even if it is not displayed in the Video surveillance monitor. | path<> | Path to save frame. If there is no parameter than the FRAME_SENT event with the data parameter will be formed in the system. Processing of this event is described in the section The SaveToFile method of the Programming Guide (JScript). |
stream<> | Optional parameter. Sets Intellect stream to get a frame from. The stream can be specified by number or purpose. Possible purposes:
Stream number consists of camera ID and stream ID divided by dot, for example, 4.3 is for stream 3 from camera 4. | |
time<> | Optional parameter. Is set to request video frame from the archive. Format: DD-MM-YYYY hh:mm:ss. Example: time<19-09-2017 11:35:34>. | |
gate<> | Optional parameter. Network name of the Video Gate to get the frame from. | |
arch<> | Optional parameter. Network name of the Backup Archive to get the frame from. | |
slave_id<> | Optional parameter. Network name of the Server to get the frame from. | |
password_crc<> | Optional parameter. CRC sequence to be recorded to the file together with the frame. | |
ARCH_DEL_RECORD – delete archive recordings over the specified period. | fromTime<> | Mandatory parameter. Time in the YYYY-MM-DDTHH: MM: SS.NNN format, where NNN - milliseconds. The recordings will be deleted (starting with the first one containing the specified time and ending with the last one containing the toTime time). If no time is specified in the toTime parameter, then only one recording will be deleted. |
toTime<> | Optional parameter. Time in the YYYY-MM-DDTHH: MM: SS.NNN format, where NNN - milliseconds. See description above. | |
REC_RESTART – restart recording. | - | - |
ARCH_BOOKMARK_RECORD – create a bookmark. | time1<> | The date of the archive period beginning included in the bookmark in the DD-MM-YY HH: MM: SS.NNN format, where NNN - milliseconds. |
time2<> | The date of the archive period ending included in the bookmark in the DD-MM-YY HH: MM: SS.NNN format, where NNN - milliseconds. | |
comment<> | Comment to a bookmark. | |
slave_id<> | Computer and Video surveillance monitor IDs – the bookmark is created using them. Parameter format: <computer id >.<monitor id>. For example, slave_id<WS2.1> –WS2 is computer ID and 1 is Video surveillance monitor ID. | |
CRUISE_START – Auto cruise | cruise_id<> | Route name on camera |
action<> | Executed action: CRUISE_START – start cruising along the specified route. PATROL_PLAY – start patrolling along the specified route. | |
cam_id<> | Camera ID | |
"GET_DEPTH" – get the archive depth. The ARCHIVE_DEPTH event from the SLAVE object (see SLAVE) is created in the system as the response to this reaction. If one or both parameters are absent it means that there is the archive depth request for all possible parameters. | drive<> | Disk or network path to request the archive depth. The disk name is set in the "<disk letter>:\\" format, for example drive<D:\\> Note. The "\" character is an escape character. The network path is set in the UNC format. |
arch | Get the backup archive depth. Example. DoReactStr("CAM","2","GET_DEPTH","drive<D:\\>,cam<2>,arch"); | |
gate | Get the video gate archive. Example. DoReactStr("CAM","1","GET_DEPTH","drive<V:\\>,gate"); |
Properties of the CAM object are shown in the table.
Properties of the CAMobject | Description of properties |
ID<> | Object ID |
PARENT_ID<> | Parent object ID |
TELEMETRY_ID<> | Telemetry module ID (ID of ptz) |
REGION_ID<> | Region ID |
Examples of using events and reactions of the Camera object:
Switch camera to the colored mode and start recording from it while arming the first camera.
OnEvent("CAM","1","ARM") //first video camera is armed { DoReact("CAM","1","SETUP","color<1>"); // set colored mode of video camera DoReact("CAM","1","REC"); //record from the first camera }
Arm the first video camera while disabling the fifth video camera.
OnEvent("CAM","5","DETACH") // fifth video camera is disabled { DoReact("CAM","1","ARM"); //first video camera is armed }
Use half of resources while recording from the first camera (i.e. if 4 video cameras are connected through the first video capture device than the first camera will record with speed 6 fps, and other three cameras – with speed 2-2,5 fps) if it is in alarm state.
OnEvent("CAM","1","MD_START") //first video camera is in alarm state { DoReact("CAM","1","SETUP","rec_priority<2>"); // use half of resources while recording }
Set maximal compression synchronously with the fourth microphone of audio card on the first video camera while recording from the first video camera on disk.
OnEvent("CAM","1","REC") //first video camera recording on disk { DoReact("CAM","1", "SETUP", "compression<5>, audio_type<OLXA_LINE>, audio_id<4>"); //first video camera, maximal compression, synchronously with forth microphone of audio card.
Start recording from the first camera with minimal quality in black and white mode when it stopped to be in alarm.
OnEvent("CAM","1","MD_STOP") // first camera stopped to be in alarm state { value = 5; DoReact("CAM", "1", "SETUP", "compression<" + value + ">,color<0>"); //start record from the first video camera with minimal quality in black and white mode. }
Start recording from the first camera in the “rollback” mode when it disarmed.
OnEvent("CAM","1","DISARM") //first video camera is disarmed { DoReact("CAM","1","REC","rollback<1>"); // Start record from the first video camera in the "rollback" mode }
Set new parameters of video signal while connecting the first video camera.
OnEvent("CAM","1","ATTACH") //first video camera is connected { VIDEO_CANAL_ID = GETOBJECTPARAM("CAM","1","PARENT_ID"); // define ID of video channel to which the first camera belongs DoReact("GRABBER",VIDEO_CANAL_ID,"SETUP","chan<0>,mode<0>,resolution<1>,format<pal>"); //set new parameters of video channel. }
Start auto cruising on Camera 1 when Macro 2 is run.
OnEvent ("MACRO","2","RUN") { DoReact("CAM","1","CRUISE_START","cruise_id<1>,action<CRUISE_START>,cam_id<1>"); }
Check function of CAM object state:
CheckState("CAM","number","state")
The CAM object can be in the following states.
State of «CAM» object | Description |
"ALARMED" | Camera is in alarm mode. |
"DISARM_DETACHED" | No signal from camera. |
"DETACHED" | No signal from camera. |
"ARMED" | Camera is armed. |
"DISARMED" | Camera is disarmed. |