Difference between revisions of "Teltonika DualCam"
(215 intermediate revisions by 18 users not shown) | |||
Line 1: | Line 1: | ||
− | + | __TOC__ | |
+ | ==Introduction to the product== | ||
+ | Teltonika DualCam is connected to FMX125 and FMU126 devices using the RS232 interface. <br><br> | ||
+ | [[image:DualCam1.png|400px]] <br> | ||
+ | ==Basic characteristics== | ||
+ | <br> | ||
+ | <table class="nd-othertables" style="width: 68%;"> | ||
+ | <th style="width: 10%; text-align:left; vertical-align:middle; color:black">Technical data</th> | ||
+ | <th style="width: 20%; text-align:center; vertical-align:middle; color:black">Description</th> | ||
+ | </tr> | ||
+ | <tr> | ||
+ | <td style="width: 8%; text-align:left;">Supported by</td> | ||
+ | <td style="width: 8%; text-align:left">FMC125, FMM125, FMU125, FMU126, FMB125</td> | ||
+ | </tr> | ||
+ | <tr> | ||
+ | <td style="width: 8%; text-align:left">Day & Night Vision Effect</td> | ||
+ | <td style="width: 8%; text-align:left">Day (Color), Night (Black & White)</td> | ||
+ | </tr> | ||
+ | <tr> | ||
+ | <td style="width: 8%; text-align:left">Angle of View</td> | ||
+ | <td style="width: 8%; text-align:left">Horizontal 120°, Vertical 70°</td> | ||
+ | </tr> | ||
+ | <tr> | ||
+ | <td style="width: 8%; text-align:left">Dual Camera</td> | ||
+ | <td style="width: 8%; text-align:left">Front and Rear (equal characteristics)</td> | ||
+ | </tr> | ||
+ | <tr> | ||
+ | <td style="width: 8%; text-align:left">Camera casing dimensions</td> | ||
+ | <td style="width: 8%; text-align:left">126.2 x 36.6 x 36.6 mm</td> | ||
+ | </tr> | ||
+ | <tr> | ||
+ | <td style="width: 8%; text-align:left">Camera mounting</td> | ||
+ | <td style="width: 8%; text-align:left">Sticky tape (3M) or screws</td> | ||
+ | </tr> | ||
+ | <tr> | ||
+ | <br><table class="nd-othertables" style="width: 68%;"> | ||
− | + | <th style="width: 10%; text-align:left; vertical-align:middle; color:black">Electrical parameters</th> | |
+ | <th style="width: 20%; text-align:center; vertical-align:middle; color:black">Description</th> | ||
+ | </tr> | ||
+ | <tr> | ||
+ | <td style="width: 8%; text-align:left;">Input voltage range</td> | ||
+ | <td style="width: 8%; text-align:left">9 ~ 36 V</td> | ||
+ | </tr> | ||
+ | <tr> | ||
+ | <td style="width: 8%; text-align:left">Working temperature and humidity</td> | ||
+ | <td style="width: 8%; text-align:left">Temperature: 30 °C ~ 85 °C | ||
+ | Humidity: <90% | ||
+ | </td> | ||
+ | </tr> | ||
+ | <tr> | ||
+ | <td style="width: 8%; text-align:left">Stand-by electric current</td> | ||
+ | <td style="width: 8%; text-align:left">60 mA</td> | ||
+ | </tr> | ||
+ | <tr></table> | ||
+ | <br> | ||
+ | <table class="nd-othertables" style="width: 68%;"> | ||
+ | <th style="width: 10%; text-align:left; vertical-align:middle; color:black">Function parameters</th> | ||
+ | <th style="width: 20%; text-align:center; vertical-align:middle; color:black">Description</th> | ||
+ | </tr> | ||
+ | <tr> | ||
+ | <td style="width: 8%; text-align:left;">Real time clock (RTC) synchronization</td> | ||
+ | <td style="width: 8%; text-align:left">Available over FM (via NTP, NITZ or GNSS)</td> | ||
+ | </tr> | ||
+ | <tr> | ||
+ | <td style="width: 8%; text-align:left">Picture resolution</td> | ||
+ | <td style="width: 8%; text-align:left">1280 x 720 (default) (50KB transfer period 18 sec), Configurable: 160 x 120; 320 x 240; 640 x 480; 1920 x 1080</td> | ||
+ | </tr> | ||
+ | <tr> | ||
+ | <td style="width: 8%; text-align:left">IR Distance</td> | ||
+ | <td style="width: 8%; text-align:left">2 Meters</td> | ||
+ | </tr> | ||
+ | <tr> | ||
+ | <td style="width: 8%; text-align:left">Cable length</td> | ||
+ | <td style="width: 8%; text-align:left">RS232 (3.5 m)</td> | ||
+ | </tr> | ||
+ | <tr> | ||
+ | <td style="width: 8%; text-align:left">Video compression</td> | ||
+ | <td style="width: 8%; text-align:left">H.265</td> | ||
+ | </tr> | ||
+ | <tr> | ||
+ | <td style="width: 8%; text-align:left">Video resolution</td> | ||
+ | <td style="width: 8%; text-align:left">720P (20 sec. – 6MB, transfer period ~ 320 sec.)</td> | ||
+ | </tr> | ||
+ | <tr> | ||
+ | <td style="width: 8%; text-align:left">Video storage</td> | ||
+ | <td style="width: 8%; text-align:left">2psc. MicroSD card (Max 64GB up to 72 hours of video)</td> | ||
+ | </tr> | ||
+ | </table> | ||
+ | <br> | ||
− | DualCam | + | ==Installation== |
+ | To connect the DualCam to a supported device, you have to make sure to connect 4 PINs of the camera to the PINs of your device correctly. | ||
+ | [[Image:Dual_camera-wiring_scheme.png|{{{general|size}}}|center]] | ||
+ | {| class="wikitable" | ||
+ | |+ | ||
+ | ! style="width:10%; border: 1px solid white; border-bottom: 2px solid #0054A6; background: white; color: #0054A6; text-align: left;" |PIN NUMBER | ||
+ | ! style="width:15%; border: 1px solid white; border-bottom: 2px solid #0054A6; background: white; color: #0054A6; text-align: left;" |PIN NAME | ||
+ | ! style="width:25%; border: 1px solid white; border-bottom: 2px solid #0054A6; background: white; color: #0054A6; text-align: left;" | | ||
+ | DESCRIPTION | ||
+ | |- | ||
+ | | style="border: 1px solid white; border-bottom: 2px solid #E8E8E8; text-align: left; vertical-align: center; background: white;" |1 | ||
+ | | style="border: 1px solid white; border-bottom: 2px solid #E8E8E8; text-align: left; vertical-align: center; background: white;" |<span style="color:#008000">'''RS232-Tx'''</span> | ||
+ | | style="border: 1px solid white; border-bottom: 2px solid #E8E8E8; text-align: left; vertical-align: center; background: white;" |DualCam output for data transmission through RS232 | ||
+ | |- | ||
+ | | style="border: 1px solid white; border-bottom: 2px solid #E8E8E8; text-align: left; vertical-align: center; background: white;" |2 | ||
+ | | style="border: 1px solid white; border-bottom: 2px solid #E8E8E8; text-align: left; vertical-align: center; background: white;" |<span style="color:#D8D800">'''RS232-Rx'''</span> | ||
+ | | style="border: 1px solid white; border-bottom: 2px solid #E8E8E8; text-align: left; vertical-align: center; background: white;" |DualCam input for data reception through RS232 | ||
+ | |- | ||
+ | |- | ||
+ | | style="border: 1px solid white; border-bottom: 2px solid #E8E8E8; text-align: left; vertical-align: center; background: white;" |3 | ||
+ | | style="border: 1px solid white; border-bottom: 2px solid #E8E8E8; text-align: left; vertical-align: center; background: white;" |<span style="color:#FF0000">'''VCC(9-36V)''' </span>(+) | ||
+ | | style="border: 1px solid white; border-bottom: 2px solid #E8E8E8; text-align: left; vertical-align: center; background: white;" |Power supply for the DualCam | ||
+ | |- | ||
+ | | style="border: 1px solid white; border-bottom: 2px solid #E8E8E8; text-align: left; vertical-align: center; background: white;" |4 | ||
+ | | style="border: 1px solid white; border-bottom: 2px solid #E8E8E8; text-align: left; vertical-align: center; background: white;" |<span style="color:#000000">'''GND''' </span>(-) | ||
+ | | style="border: 1px solid white; border-bottom: 2px solid #E8E8E8; text-align: left; vertical-align: center; background: white;" |Ground | ||
+ | |} | ||
+ | <br> | ||
− | + | ==DualCam RS232 camera support== | |
+ | DualCam camera support was introduced from firmware version 03.27.00.Rev.100. A new RS232 mode "DualCam" | ||
+ | was added with parameters for setting control. The details of the RS232 mode parameter are provided in the table below. | ||
+ | {| class="wikitable" | ||
+ | |+ | ||
+ | ! rowspan="1" style="width: 400px; background: #0054A6; color: white;" |'''Parameter name''' | ||
+ | ! rowspan="1" style="width: 400px; background: #0054A6; color: white;" |'''Parameter ID''' | ||
+ | ! rowspan="1" style="width: 400px; background: #0054A6; color: white;" |'''Parameter value''' | ||
+ | |- | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |RS232 Mode | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |151 | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |18 | ||
+ | |} | ||
+ | Please note, that configurator version 8.1.6.0 has to be used if configuration is being made in offline mode. | ||
+ | <br> | ||
− | + | ==Camera Feature Settings== | |
− | + | [[Image:CameraFeatureSettings.PNG|{{{general|size}}}|right]] | |
− | + | Once this mode is enabled, new tab “Camera Settings” appears on the left sidebar. This will contain the main parameters for configuring the camera settings The parameter IDs and values are provided in the table below. Once configuration is | |
− | + | saved to device, these parameters are updated. | |
− | + | <br> | |
− | + | {| class="wikitable" | |
− | + | |+ | |
− | + | ! rowspan="1" style="width: 400px; background: #0054A6; color: white;" |'''Parameter name''' | |
− | + | ! rowspan="1" style="width: 400px; background: #0054A6; color: white;" |'''Parameter ID''' | |
− | + | ! rowspan="1" style="width: 400px; background: #0054A6; color: white;" |'''Parameter values''' | |
− | + | ! rowspan="1" style="width: 400px; background: #0054A6; color: white;" |'''Default values''' | |
− | + | |- | |
− | + | | colspan="1" rowspan="6" style="text-align: center; style=" width: 150px; background: white; color: black;" |Camera Picture Resolution | |
− | + | | colspan="1" rowspan="6" style="text-align: center; style=" width: 150px; background: white; color: black;" |66000 | |
− | + | |- | |
− | + | | rowspan="1" style="text-align: center; vertical-align: center;" |0 - 160 x 120 | |
− | + | | colspan="1" rowspan="5" style="text-align: center; style=" width: 150px; background: white; color: black;" |3 | |
− | == | + | |- |
− | ''' | + | | rowspan="1" style="text-align: center; vertical-align: center;" |1 - 320 x 240 |
+ | |- | ||
+ | | rowspan="1" style="text-align: center; vertical-align: center;" |2 - 640 x 480 | ||
+ | |- | ||
+ | | rowspan="1" style="text-align: center; vertical-align: center;" |3 - 1280 x 720 | ||
+ | |- | ||
+ | | rowspan="1" style="text-align: center; vertical-align: center;" |4 - 1920 x 1080 | ||
+ | |- | ||
+ | | colspan="1" rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |Camera Picture Compression | ||
+ | | colspan="1" rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |66001 | ||
+ | | rowspan="1" style="text-align: center; vertical-align: center;" |[0 - 100] (%) | ||
+ | | colspan="1" rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |50 | ||
+ | |- | ||
+ | | colspan="1" rowspan="2" style="text-align: center; style=" width: 150px; background: white; color: black;" |OSD Display | ||
+ | | colspan="1" rowspan="2" style="text-align: center; style=" width: 150px; background: white; color: black;" |66002 | ||
+ | | rowspan="1" style="text-align: center; vertical-align: center;" |0 - Disabled | ||
+ | | colspan="1" rowspan="2" style="text-align: center; style=" width: 150px; background: white; color: black;" |0 | ||
+ | |- | ||
+ | | rowspan="1" style="text-align: center; vertical-align: center;" |1 - Enabled | ||
+ | |- | ||
+ | | colspan="1" rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |Video Frame Rate | ||
+ | | colspan="1" rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |66003 | ||
+ | | colspan="1" rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |[1-30] (frames per second) | ||
+ | | colspan="1" rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |30 | ||
+ | |} | ||
+ | '''OSD display''' - On Screen Display feature displays date and time in the upper left corner of the photo. This feature can be enabled or disabled. | ||
+ | <br> | ||
− | [[ | + | ==Camera Scenario Settings== |
− | [ | + | [[Image:CameraScenarioSettings.PNG|{{{general|size}}}|right]] |
− | < | + | "Camera settings" tab also contains scenario settings that trigger camera video/photo capture when specific condition is met. |
+ | <br> | ||
+ | {| class="wikitable" | ||
+ | |+ | ||
+ | ! rowspan="1" style="width: 350px; background: #0054A6; color: white;" |'''Parameter name''' | ||
+ | ! rowspan="1" style="width: 350px; background: #0054A6; color: white;" |'''Parameter ID''' | ||
+ | ! rowspan="1" style="width: 350px; background: #0054A6; color: white;" |'''Parameter values''' | ||
+ | ! rowspan="1" style="width: 350px; background: #0054A6; color: white;" |'''Default values''' | ||
+ | |- | ||
+ | | colspan="1" rowspan="2" style="text-align: center; style=" width: 150px; background: white; color: black;" |Periodic Image sending | ||
+ | | colspan="1" rowspan="2" style="text-align: center; style=" width: 150px; background: white; color: black;" |66006 | ||
+ | | rowspan="1" style="text-align: center; vertical-align: center;" |0 - Disabled | ||
+ | | colspan="1" rowspan="2" style="text-align: center; style=" width: 150px; background: white; color: black;" |0 | ||
+ | |- | ||
+ | | rowspan="1" style="text-align: center; vertical-align: center;" |1 - Enabled | ||
+ | |- | ||
+ | | colspan="1" rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |Sending interval | ||
+ | | colspan="1" rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |66007 | ||
+ | | colspan="1" rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |[10-1800] (seconds) | ||
+ | | colspan="1" rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |600 | ||
+ | |- | ||
+ | | colspan="1" rowspan="5" style="text-align: center; style=" width: 150px; background: white; color: black;" |Video sending trigger | ||
+ | | colspan="1" rowspan="5" style="text-align: center; style=" width: 150px; background: white; color: black;" |66008 | ||
+ | |- | ||
+ | | rowspan="1" style="text-align: center; vertical-align: center;" |0 - None | ||
+ | | colspan="1" rowspan="4" style="text-align: center; style=" width: 150px; background: white; color: black;" |0 | ||
+ | |- | ||
+ | | rowspan="1" style="text-align: center; vertical-align: center;" |1 - DIN1 | ||
+ | |- | ||
+ | | rowspan="1" style="text-align: center; vertical-align: center;" |2 - DIN2 | ||
+ | |- | ||
+ | | rowspan="1" style="text-align: center; vertical-align: center;" |3 - Crash | ||
+ | |- | ||
+ | | colspan="1" rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |Video duration before trigger | ||
+ | | colspan="1" rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |66009 | ||
+ | | colspan="1" rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |[1-10] (seconds) | ||
+ | | colspan="1" rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |5 | ||
+ | |- | ||
+ | | colspan="1" rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |Video duration after trigger | ||
+ | | colspan="1" rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |66010 | ||
+ | | colspan="1" rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |[1-10] (seconds) | ||
+ | | colspan="1" rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |5 | ||
+ | |- | ||
+ | |} | ||
+ | <br> | ||
+ | ===Periodic image sending scenario=== | ||
+ | Periodic image sending triggers photo capture from a front camera, whenever the timeout is reached (sending interval parameter). If a camera has not finished uploading picture to a server, then the photo capture is skipped. | ||
+ | <br> | ||
− | == | + | <br> |
+ | ===Video sending by trigger=== | ||
+ | Video sending by trigger scenario monitors the selected trigger (video sending trigger parameter) and captures video before and after the event (video duration before trigger and video duration after trigger parameters). If the previously captured video has not finished downloading, then a new video capture is skipped until the old one has been sent. When this scenario is triggered, high priority eventual record is generated with the value corresponding to what triggered the scenario. See the table below. | ||
+ | {| class="wikitable" | ||
+ | |+ | ||
+ | ! rowspan="1" style="width: 400px; background: #0054A6; color: white;" |'''Parameter name''' | ||
+ | ! rowspan="1" style="width: 400px; background: #0054A6; color: white;" |'''Parameter ID''' | ||
+ | ! rowspan="1" style="width: 400px; background: #0054A6; color: white;" |'''Parameter value''' | ||
+ | |- | ||
+ | | rowspan="4" style="text-align: center; style=" width: 150px; background: white; color: black;" |SOS trigger | ||
+ | | rowspan="4" style="text-align: center; style=" width: 150px; background: white; color: black;" |499 | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |0 - Server request | ||
+ | |- | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |1 - DIN1 | ||
+ | |- | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |2 - DIN2 | ||
+ | |- | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |3 - Crash | ||
+ | |} | ||
+ | <br> | ||
− | + | ===Camera request command=== | |
+ | A new camera request has been added, which allows server to request files from a camera. The format is as provided below in the table: | ||
+ | {| class="wikitable" | ||
+ | |+ | ||
+ | ! rowspan="1" style="width: 400px; background: #0054A6; color: white;" |'''Command''' | ||
+ | ! rowspan="1" style="width: 400px; background: #0054A6; color: white;" |'''Arguments''' | ||
+ | ! rowspan="1" style="width: 400px; background: #0054A6; color: white;" |'''Explanation''' | ||
+ | |- | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |camreq: | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |<file_type>,<file_source>,<timestamp>,<duration> | ||
+ | | rowspan="1" style="text-align: left; style=" width: 150px; background: white; color: black;" |Captures appropriate file with the provided details. If the connection to server is opened, them files immediately become available for download. If not, then connection is tried to be made. | ||
+ | |} | ||
+ | The arguments are as follows: | ||
− | + | *<file_type> | |
+ | **0 - Video | ||
+ | **1 - Photo | ||
+ | *<file_source> | ||
+ | **1 - Front camera | ||
+ | **2 - Rear camera | ||
+ | **3 - Both cameras | ||
+ | *<timestamp> | ||
+ | **Unix timestamps in decimal (not required for photo download) | ||
+ | *<duration> | ||
+ | **Video duration in seconds from provided timestamps (not required for photo download), (max 30 sec) | ||
− | ==Video | + | {| class="wikitable" |
+ | |+ | ||
+ | ! rowspan="1" style="width: 600px; background: #0054A6; color: white;" |'''Conditions''' | ||
+ | ! rowspan="1" style="width: 600px; background: #0054A6; color: white;" |'''Command response''' | ||
+ | |- | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |Arguments are invalid | ||
+ | | rowspan="1" style="text-align: left; style=" width: 150px; background: white; color: black;" |Invalid argument in camera request cmd! | ||
+ | |- | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |Photo requested | ||
+ | | rowspan="1" style="text-align: left; style=" width: 150px; background: white; color: black;" |Request for photo from source <1-3> received | ||
+ | |- | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |Video requested | ||
+ | | rowspan="1" style="text-align: left; style=" width: 150px; background: white; color: black;" |Request for video from source <1-3> received for <1-30> seconds since YYYY-MM-DDHH:MM:SS | ||
+ | |} | ||
+ | <br> | ||
− | + | ==Camera ping transmission and TF status checking== | |
+ | Camera pinging was implemented to periodically check if a camera is connected to a device. This is done via “Get TF status” command for both front and rear camera every 20 seconds when ignition is on. The received result from this command is stored in two corresponding AVL elements “Front camera state” and “Rear camera state”. The following do not only store TF status, but also if response from the camera was received or not. | ||
+ | {| class="wikitable" | ||
+ | |+ | ||
+ | ! rowspan="1" style="width: 400px; background: #0054A6; color: white;" |'''Parameter name''' | ||
+ | ! rowspan="1" style="width: 400px; background: #0054A6; color: white;" |'''Parameter AVL ID''' | ||
+ | ! rowspan="1" style="width: 400px; background: #0054A6; color: white;" |'''Parameter values''' | ||
+ | |- | ||
+ | | rowspan="2" style="text-align: center; style=" width: 150px; background: white; color: black;" |Front camera state: | ||
+ | | rowspan="2" style="text-align: center; style=" width: 150px; background: white; color: black;" |498 | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |0 - Camera not detected | ||
+ | |- | ||
+ | |- | ||
+ | |- | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |1 - No card | ||
+ | |- | ||
+ | | rowspan="4" style="text-align: center; style=" width: 150px; background: white; color: black;" |Rear camera state: | ||
+ | | rowspan="4" style="text-align: center; style=" width: 150px; background: white; color: black;" |497 | ||
+ | |- | ||
+ | |- | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |2 - Card mount failed | ||
+ | |- | ||
+ | |- | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |3 - Card failed | ||
+ | |- | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |4 - Card faulty | ||
+ | |- | ||
+ | |} | ||
+ | <br> | ||
− | [[Category: | + | ==Camera RTC synchronization== |
+ | Camera RTC synchronization is done anytime the device itself is synchronized (via NTP, NITZ or GNSS). | ||
+ | <br> | ||
+ | |||
+ | ==Other camera related functionality== | ||
+ | Camera is configured if all of these conditions are met: | ||
+ | |||
+ | #'''RS232 mode is selected (DualCam)''' | ||
+ | #'''Camera was not configured since startup or one of the related parameters were changed (compression, framerate or OSD)''' | ||
+ | #'''Camera file transfer is not active''' | ||
+ | |||
+ | Active camera reconfiguration is accompanied by two consecutive camera shutter clicks. | ||
+ | If camera is disconnected and later reconnected, a device will detect it by periodic camera ping packet. Once camera is detected, the device will reissue the reconfiguration procedure. | ||
+ | <br> | ||
+ | ===Camera file transfer reconnection=== | ||
+ | If FMU1YX device has bad reception, server is not reachable or wrong server details are configured, then the device tries to open a link to a camera server few consecutive times. If no connection was possible to be established, then the connection is postponed for 30 minutes and tried again (or tried every configured sending interval if periodic image sending is enabled). | ||
+ | <br> | ||
+ | |||
+ | ==DualCam camera file transfer support== | ||
+ | [[Image:CameraServerSettings.PNG|{{{general|size}}}|right]] | ||
+ | Once camera has at least one file captured, it starts connection to a remote server, which is configured by parameters “Domain” and “Port” found in the “Camera Settings” tab. | ||
+ | <br> | ||
+ | |||
+ | ==Initialization packet== | ||
+ | On connection, a device sends an initialization packet. | ||
+ | {| class="wikitable" | ||
+ | |+ | ||
+ | ! rowspan="1" style="width: 400px; background: #0054A6; color: white;" |'''Header(0x0000)''' | ||
+ | ! rowspan="1" style="width: 400px; background: #0054A6; color: white;" |'''Protocol ID''' | ||
+ | ! rowspan="1" style="width: 400px; background: #0054A6; color: white;" |'''IMEI''' | ||
+ | ! rowspan="1" style="width: 400px; background: #0054A6; color: white;" |'''Settings''' | ||
+ | |- | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |2 bytes | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |2 bytes | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |8 bytes | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |4 bytes | ||
+ | |} | ||
+ | Protocol ID – just a reference for the protocol version that is running on a device (for server cross compatibility with older versions). Firmware FMB.Ver.03.27.00.Rev.100 and up have protocol ID 5. | ||
+ | Settings flag contains information on what is available for download. Structure is provided below: | ||
+ | {| class="wikitable" | ||
+ | |+ | ||
+ | ! colspan="32" rowspan="1" style="width: 400px; background: #0054A6; color: white;" |'''Settings, 4 B''' | ||
+ | |- | ||
+ | ! colspan="8" rowspan="1" style="width: 400px; background: #0054A6; color: white;" |'''Byte 3''' | ||
+ | ! colspan="8" rowspan="1" style="width: 400px; background: #0054A6; color: white;" |'''Byte 2''' | ||
+ | ! colspan="8" rowspan="1" style="width: 400px; background: #0054A6; color: white;" |'''Byte 1''' | ||
+ | ! colspan="8" rowspan="1" style="width: 400px; background: #0054A6; color: white;" |'''Byte 0''' | ||
+ | |- | ||
+ | ! rowspan="1" style="width: 400px; background: background: white; color: black;" | | ||
+ | ! rowspan="1" style="width: 400px; background: background: white; color: black;" | | ||
+ | ! rowspan="1" style="width: 400px; background: background: white; color: black;" |1 | ||
+ | ! rowspan="1" style="width: 400px; background: background: white; color: black;" |2 | ||
+ | ! rowspan="1" style="width: 400px; background: background: white; color: black;" |3 | ||
+ | ! rowspan="1" style="width: 400px; background: background: white; color: black;" |4 | ||
+ | ! rowspan="1" style="width: 400px; background: background: white; color: black;" | | ||
+ | ! rowspan="1" style="width: 400px; background: background: white; color: black;" | | ||
+ | ! rowspan="1" style="width: 400px; background: background: white; color: black;" | | ||
+ | ! rowspan="1" style="width: 400px; background: background: white; color: black;" | | ||
+ | ! rowspan="1" style="width: 400px; background: background: white; color: black;" | | ||
+ | ! rowspan="1" style="width: 400px; background: background: white; color: black;" | | ||
+ | ! rowspan="1" style="width: 400px; background: background: white; color: black;" | | ||
+ | ! rowspan="1" style="width: 400px; background: background: white; color: black;" | | ||
+ | ! rowspan="1" style="width: 400px; background: background: white; color: black;" | | ||
+ | ! rowspan="1" style="width: 400px; background: background: white; color: black;" | | ||
+ | ! rowspan="1" style="width: 400px; background: background: white; color: black;" | | ||
+ | ! rowspan="1" style="width: 400px; background: background: white; color: black;" | | ||
+ | ! rowspan="1" style="width: 400px; background: background: white; color: black;" | | ||
+ | ! rowspan="1" style="width: 400px; background: background: white; color: black;" | | ||
+ | ! rowspan="1" style="width: 400px; background: background: white; color: black;" | | ||
+ | ! rowspan="1" style="width: 400px; background: background: white; color: black;" | | ||
+ | ! rowspan="1" style="width: 400px; background: background: white; color: black;" | | ||
+ | ! rowspan="1" style="width: 400px; background: background: white; color: black;" | | ||
+ | ! rowspan="1" style="width: 400px; background: background: white; color: black;" | | ||
+ | ! rowspan="1" style="width: 400px; background: background: white; color: black;" | | ||
+ | ! rowspan="1" style="width: 400px; background: background: white; color: black;" | | ||
+ | ! rowspan="1" style="width: 400px; background: background: white; color: black;" | | ||
+ | ! rowspan="1" style="width: 400px; background: background: white; color: black;" | | ||
+ | ! rowspan="1" style="width: 400px; background: background: white; color: black;" | | ||
+ | ! rowspan="1" style="width: 400px; background: background: white; color: black;" | | ||
+ | ! rowspan="1" style="width: 400px; background: background: white; color: black;" | | ||
+ | |} | ||
+ | |||
+ | #Video, rear (%videor) | ||
+ | #Video, front(%videof) | ||
+ | #Photo, rear (%photor) | ||
+ | #Photo, rear (%photor) | ||
+ | |||
+ | If identifier sent to a server is not valid, device disconnects. | ||
+ | <br> | ||
+ | |||
+ | ==General command structure== | ||
+ | General communication packet structure is as in the table bellow. It consist of CMD_ID (2 bytes), Data length of a command and a payload. | ||
+ | {| class="wikitable" | ||
+ | |+ | ||
+ | ! rowspan="1" style="width: 400px; background: #0054A6; color: white;" |'''Command ID''' | ||
+ | ! rowspan="1" style="width: 400px; background: #0054A6; color: white;" |'''Data length''' | ||
+ | ! rowspan="1" style="width: 400px; background: #0054A6; color: white;" |'''Data''' | ||
+ | |- | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |2 bytes | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |2 bytes | ||
+ | | rowspan="1" style="text-align: left; style=" width: 150px; background: white; color: black;" |[data length] bytes | ||
+ | |} | ||
+ | <br> | ||
+ | ==Communication protocol== | ||
+ | '''Close a session command (CMD ID 0x0000)'''<br> | ||
+ | In case when a device connects to a server, but the server does not expect it to connect, server will respond by sending a CLOSE command after which the connection will be terminated. This command is also used when device connects to a server for a custom file sending and server finishes to send all custom files to the device. | ||
+ | {| class="wikitable" | ||
+ | |+ | ||
+ | ! rowspan="1" style="width: 600px; background: #0054A6; color: white;" |'''Command ID''' | ||
+ | ! rowspan="1" style="width: 600px; background: #0054A6; color: white;" |'''Data length''' | ||
+ | |- | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |0x0000 | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |0x0000 | ||
+ | |} | ||
+ | <br> | ||
+ | '''Start file transfer command (CMD ID 0x0001)'''<br> | ||
+ | After device is connected for a file download, server initiates file transfer by sending a START command. | ||
+ | {| class="wikitable" | ||
+ | |+ | ||
+ | ! rowspan="1" style="width: 400px; background: #0054A6; color: white;" |'''Command ID''' | ||
+ | ! rowspan="1" style="width: 400px; background: #0054A6; color: white;" |'''Data length''' | ||
+ | ! rowspan="1" style="width: 400px; background: #0054A6; color: white;" |'''File Packets (4 bytes)''' | ||
+ | ! rowspan="1" style="width: 400px; background: #0054A6; color: white;" |'''File CRC (2 bytes)''' | ||
+ | |- | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |0x0004 | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |0x0006 | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |0x12345678 | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |... | ||
+ | |} | ||
+ | <br> | ||
+ | '''File request command (CMD ID 0x0008)'''<br> | ||
+ | After device is connected for a file upload, server initiates file transfer by sending a FILE REQ command. | ||
+ | {| class="wikitable" | ||
+ | |+ | ||
+ | ! rowspan="1" style="width: 400px; background: #0054A6; color: white;" |'''Command ID''' | ||
+ | ! rowspan="1" style="width: 400px; background: #0054A6; color: white;" |'''Data length''' | ||
+ | ! rowspan="1" style="width: 400px; background: #0054A6; color: white;" |'''File Identifier''' | ||
+ | |- | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |0x0008 | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |2 bytes | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |''See the table below'' | ||
+ | |} | ||
+ | Device should answer with a START command described above indicating a size and CRC of the requested file. | ||
+ | {| class="wikitable" | ||
+ | |+ | ||
+ | ! rowspan="1" style="width: 600px; background: #0054A6; color: white;" |'''File source, type''' | ||
+ | ! rowspan="1" style="width: 600px; background: #0054A6; color: white;" |'''Identifier (ASCII chars)''' | ||
+ | |- | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |Photo from camera, rear | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |%photor | ||
+ | |- | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |Photo from camera, front | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |%photof | ||
+ | |- | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |Video from camera, rear | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |%videor | ||
+ | |- | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |Video from camera, front | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |%videof | ||
+ | |} | ||
+ | <br> | ||
+ | '''Resume file transfer command (CMD ID 0x0002)'''<br> | ||
+ | In a response to the START command a RESUME command must be sent from a server. | ||
+ | {| class="wikitable" | ||
+ | |+ | ||
+ | ! rowspan="1" style="width: 400px; background: #0054A6; color: white;" |'''Command ID''' | ||
+ | ! rowspan="1" style="width: 400px; background: #0054A6; color: white;" |'''Data length''' | ||
+ | ! rowspan="1" style="width: 400px; background: #0054A6; color: white;" |'''Packet offset (4 bytes)''' | ||
+ | |- | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |0x0002 | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |0x0004 | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |0x00000000 | ||
+ | |} | ||
+ | To begin a file transfer from the start, offset should be set to zero (4 bytes value). In case when the file transfer has been interrupted, to resume file transfer, offset can be set to the desired value (0 ≤ [offset] ≤ [file size]). | ||
+ | <br> | ||
+ | <br> | ||
+ | '''Synchronize file transfer command (CMD ID 0x0003)'''<br> | ||
+ | In a response to the RESUME command a SYNC command is sent from device. | ||
+ | {| class="wikitable" | ||
+ | |+ | ||
+ | ! rowspan="1" style="width: 400px; background: #0054A6; color: white;" |'''Command ID''' | ||
+ | ! rowspan="1" style="width: 400px; background: #0054A6; color: white;" |'''Data length''' | ||
+ | ! rowspan="1" style="width: 400px; background: #0054A6; color: white;" |'''File offset (4 bytes)''' | ||
+ | |- | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |0x0003 | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |0x0004 | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |0x00000000 | ||
+ | |} | ||
+ | By sending a SYNC command, it is ensured that the next data command will contain a file data starting from the specified offset. | ||
+ | <br> | ||
+ | <br> | ||
+ | '''File data transfer command (CMD ID 0x0004)'''<br> | ||
+ | After sending a SYNC command, a file data transfer is started by sending DATA commands. | ||
+ | {| class="wikitable" | ||
+ | |+ | ||
+ | ! rowspan="1" style="width: 400px; background: #0054A6; color: white;" |'''Command ID''' | ||
+ | ! rowspan="1" style="width: 400px; background: #0054A6; color: white;" |'''Data length''' | ||
+ | ! rowspan="1" style="width: 400px; background: #0054A6; color: white;" |'''File data (up to 1024 bytes)''' | ||
+ | ! rowspan="1" style="width: 400px; background: #0054A6; color: white;" |'''Data CRC (2 bytes)''' | ||
+ | |- | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |0x0004 | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |0x0402 | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |... | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |... | ||
+ | |} | ||
+ | A File data is split into 1024 byte parts, each part wrapped into a DATA command and is sent. <br> | ||
+ | Note: ''if a command with a bad CRC is received, RESUME command should be sent with the last valid file offset, after receiving a RESUME command, server will stop sending DATA commands and continue communication from'' '''“Resume file transfer”''' ''step.''<br> | ||
+ | CRC polynomial expression: 0x8408 | ||
+ | Initial value, when calculating CRC, is previously received packet (CMD ID 0x0004) CRC value. | ||
+ | <br> | ||
+ | <br> | ||
+ | '''File transfer status command (CMD ID 0x0005)'''<br> | ||
+ | After a file transfer is completed and no more files are required from the device, a server should send a COMPLETED command to the device (this command does not work after executing repeat init command0 x0009 – in this case the server should send a CLOSE SESSION 0x0000 command mentioned before). | ||
+ | {| class="wikitable" | ||
+ | |+ | ||
+ | ! rowspan="1" style="width: 400px; background: #0054A6; color: white;" |'''Command ID''' | ||
+ | ! rowspan="1" style="width: 400px; background: #0054A6; color: white;" |'''Data length''' | ||
+ | ! rowspan="1" style="width: 400px; background: #0054A6; color: white;" |'''Status (4 bytes)''' | ||
+ | |- | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |0x0005 | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |0x0004 | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |0x00000000 | ||
+ | |} | ||
+ | In case of the server using invalid arguments, commands or not following the file request flow, the device will send this command with a Status field set to one of the few possible error codes. List of possible ones is provided below. | ||
+ | {| class="wikitable" | ||
+ | |+ | ||
+ | ! rowspan="1" style="width: 400px; background: #0054A6; color: white;" |'''Status value (hexadecimal)''' | ||
+ | ! rowspan="1" style="width: 400px; background: #0054A6; color: white;" |'''Description''' | ||
+ | ! rowspan="1" style="width: 400px; background: #0054A6; color: white;" |'''Notes''' | ||
+ | |- | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |0x00000000 | ||
+ | | rowspan="1" style="text-align: left; style=" width: 150px; background: white; color: black;" |File transfer process completed | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |Sent from server | ||
+ | |- | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |0x00000002 | ||
+ | | rowspan="1" style="text-align: left; style=" width: 150px; background: white; color: black;" |Failed to close GPRS | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |Sent from device | ||
+ | |- | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |0x00000003 | ||
+ | | rowspan="1" style="text-align: left; style=" width: 150px; background: white; color: black;" |Failed to close socket | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |Sent from device | ||
+ | |- | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |0x00000005 | ||
+ | | rowspan="1" style="text-align: left; style=" width: 150px; background: white; color: black;" |Invalid response from server to init packet | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |Sent from device | ||
+ | |- | ||
+ | | rowspan="1" style="text-align: center; style=" width: 150px; background: white; color: black;" |0x00000011 | ||
+ | | rowspan="1" style="text-align: left; style=" width: 150px; background: white; color: black;" |This error code forces the device to disconnect from server | ||
+ | | rowspan="1" style="text-align: left; style=" width: 150px; background: white; color: black;" |Sent from device. Possible causes: | ||
+ | |||
+ | *Camera is not configured | ||
+ | *The requested file is not available by camera | ||
+ | |} | ||
+ | After a COMPLETED command device should disconnect from the server. | ||
+ | <br> | ||
+ | <br> | ||
+ | '''Initialization packet repeat command (CMD ID 0x0009)'''<br> | ||
+ | When sent, the initialization packet is repeated. This is used, when all of the files are downloaded and additional check is carried out for any additional files, that may have been captured during the download operation. | ||
+ | <br> | ||
+ | |||
+ | ==File transfer visual flow== | ||
+ | [[Image:FileTransferVisual.PNG|{{{general|size}}}|center]] | ||
+ | [[Category:Accessories]] |
Revision as of 14:39, 2 February 2021
Main Page > Video Solutions > Teltonika DualCamIntroduction to the product
Teltonika DualCam is connected to FMX125 and FMU126 devices using the RS232 interface.
Basic characteristics
Technical data | Description |
---|---|
Supported by | FMC125, FMM125, FMU125, FMU126, FMB125 |
Day & Night Vision Effect | Day (Color), Night (Black & White) |
Angle of View | Horizontal 120°, Vertical 70° |
Dual Camera | Front and Rear (equal characteristics) |
Camera casing dimensions | 126.2 x 36.6 x 36.6 mm |
Camera mounting | Sticky tape (3M) or screws |
Electrical parameters | Description |
---|---|
Input voltage range | 9 ~ 36 V |
Working temperature and humidity | Temperature: 30 °C ~ 85 °C
Humidity: <90% |
Stand-by electric current | 60 mA |
Function parameters | Description |
---|---|
Real time clock (RTC) synchronization | Available over FM (via NTP, NITZ or GNSS) |
Picture resolution | 1280 x 720 (default) (50KB transfer period 18 sec), Configurable: 160 x 120; 320 x 240; 640 x 480; 1920 x 1080 |
IR Distance | 2 Meters |
Cable length | RS232 (3.5 m) |
Video compression | H.265 |
Video resolution | 720P (20 sec. – 6MB, transfer period ~ 320 sec.) |
Video storage | 2psc. MicroSD card (Max 64GB up to 72 hours of video) |
Installation
To connect the DualCam to a supported device, you have to make sure to connect 4 PINs of the camera to the PINs of your device correctly.
PIN NUMBER | PIN NAME |
DESCRIPTION |
---|---|---|
1 | RS232-Tx | DualCam output for data transmission through RS232 |
2 | RS232-Rx | DualCam input for data reception through RS232 |
3 | VCC(9-36V) (+) | Power supply for the DualCam |
4 | GND (-) | Ground |
DualCam RS232 camera support
DualCam camera support was introduced from firmware version 03.27.00.Rev.100. A new RS232 mode "DualCam" was added with parameters for setting control. The details of the RS232 mode parameter are provided in the table below.
Parameter name | Parameter ID | Parameter value |
---|---|---|
RS232 Mode | 151 | 18 |
Please note, that configurator version 8.1.6.0 has to be used if configuration is being made in offline mode.
Camera Feature Settings
Once this mode is enabled, new tab “Camera Settings” appears on the left sidebar. This will contain the main parameters for configuring the camera settings The parameter IDs and values are provided in the table below. Once configuration is
saved to device, these parameters are updated.
Parameter name | Parameter ID | Parameter values | Default values |
---|---|---|---|
Camera Picture Resolution | 66000 | ||
0 - 160 x 120 | 3 | ||
1 - 320 x 240 | |||
2 - 640 x 480 | |||
3 - 1280 x 720 | |||
4 - 1920 x 1080 | |||
Camera Picture Compression | 66001 | [0 - 100] (%) | 50 |
OSD Display | 66002 | 0 - Disabled | 0 |
1 - Enabled | |||
Video Frame Rate | 66003 | [1-30] (frames per second) | 30 |
OSD display - On Screen Display feature displays date and time in the upper left corner of the photo. This feature can be enabled or disabled.
Camera Scenario Settings
"Camera settings" tab also contains scenario settings that trigger camera video/photo capture when specific condition is met.
Parameter name | Parameter ID | Parameter values | Default values |
---|---|---|---|
Periodic Image sending | 66006 | 0 - Disabled | 0 |
1 - Enabled | |||
Sending interval | 66007 | [10-1800] (seconds) | 600 |
Video sending trigger | 66008 | ||
0 - None | 0 | ||
1 - DIN1 | |||
2 - DIN2 | |||
3 - Crash | |||
Video duration before trigger | 66009 | [1-10] (seconds) | 5 |
Video duration after trigger | 66010 | [1-10] (seconds) | 5 |
Periodic image sending scenario
Periodic image sending triggers photo capture from a front camera, whenever the timeout is reached (sending interval parameter). If a camera has not finished uploading picture to a server, then the photo capture is skipped.
Video sending by trigger
Video sending by trigger scenario monitors the selected trigger (video sending trigger parameter) and captures video before and after the event (video duration before trigger and video duration after trigger parameters). If the previously captured video has not finished downloading, then a new video capture is skipped until the old one has been sent. When this scenario is triggered, high priority eventual record is generated with the value corresponding to what triggered the scenario. See the table below.
Parameter name | Parameter ID | Parameter value |
---|---|---|
SOS trigger | 499 | 0 - Server request |
1 - DIN1 | ||
2 - DIN2 | ||
3 - Crash |
Camera request command
A new camera request has been added, which allows server to request files from a camera. The format is as provided below in the table:
Command | Arguments | Explanation |
---|---|---|
camreq: | <file_type>,<file_source>,<timestamp>,<duration> | Captures appropriate file with the provided details. If the connection to server is opened, them files immediately become available for download. If not, then connection is tried to be made. |
The arguments are as follows:
- <file_type>
- 0 - Video
- 1 - Photo
- <file_source>
- 1 - Front camera
- 2 - Rear camera
- 3 - Both cameras
- <timestamp>
- Unix timestamps in decimal (not required for photo download)
- <duration>
- Video duration in seconds from provided timestamps (not required for photo download), (max 30 sec)
Conditions | Command response |
---|---|
Arguments are invalid | Invalid argument in camera request cmd! |
Photo requested | Request for photo from source <1-3> received |
Video requested | Request for video from source <1-3> received for <1-30> seconds since YYYY-MM-DDHH:MM:SS |
Camera ping transmission and TF status checking
Camera pinging was implemented to periodically check if a camera is connected to a device. This is done via “Get TF status” command for both front and rear camera every 20 seconds when ignition is on. The received result from this command is stored in two corresponding AVL elements “Front camera state” and “Rear camera state”. The following do not only store TF status, but also if response from the camera was received or not.
Parameter name | Parameter AVL ID | Parameter values |
---|---|---|
Front camera state: | 498 | 0 - Camera not detected |
1 - No card | ||
Rear camera state: | 497 | |
2 - Card mount failed | ||
3 - Card failed | ||
4 - Card faulty |
Camera RTC synchronization
Camera RTC synchronization is done anytime the device itself is synchronized (via NTP, NITZ or GNSS).
Camera is configured if all of these conditions are met:
- RS232 mode is selected (DualCam)
- Camera was not configured since startup or one of the related parameters were changed (compression, framerate or OSD)
- Camera file transfer is not active
Active camera reconfiguration is accompanied by two consecutive camera shutter clicks.
If camera is disconnected and later reconnected, a device will detect it by periodic camera ping packet. Once camera is detected, the device will reissue the reconfiguration procedure.
Camera file transfer reconnection
If FMU1YX device has bad reception, server is not reachable or wrong server details are configured, then the device tries to open a link to a camera server few consecutive times. If no connection was possible to be established, then the connection is postponed for 30 minutes and tried again (or tried every configured sending interval if periodic image sending is enabled).
DualCam camera file transfer support
Once camera has at least one file captured, it starts connection to a remote server, which is configured by parameters “Domain” and “Port” found in the “Camera Settings” tab.
Initialization packet
On connection, a device sends an initialization packet.
Header(0x0000) | Protocol ID | IMEI | Settings |
---|---|---|---|
2 bytes | 2 bytes | 8 bytes | 4 bytes |
Protocol ID – just a reference for the protocol version that is running on a device (for server cross compatibility with older versions). Firmware FMB.Ver.03.27.00.Rev.100 and up have protocol ID 5. Settings flag contains information on what is available for download. Structure is provided below:
Settings, 4 B | |||||||||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
Byte 3 | Byte 2 | Byte 1 | Byte 0 | ||||||||||||||||||||||||||||
1 | 2 | 3 | 4 |
- Video, rear (%videor)
- Video, front(%videof)
- Photo, rear (%photor)
- Photo, rear (%photor)
If identifier sent to a server is not valid, device disconnects.
General command structure
General communication packet structure is as in the table bellow. It consist of CMD_ID (2 bytes), Data length of a command and a payload.
Command ID | Data length | Data |
---|---|---|
2 bytes | 2 bytes | [data length] bytes |
Communication protocol
Close a session command (CMD ID 0x0000)
In case when a device connects to a server, but the server does not expect it to connect, server will respond by sending a CLOSE command after which the connection will be terminated. This command is also used when device connects to a server for a custom file sending and server finishes to send all custom files to the device.
Command ID | Data length |
---|---|
0x0000 | 0x0000 |
Start file transfer command (CMD ID 0x0001)
After device is connected for a file download, server initiates file transfer by sending a START command.
Command ID | Data length | File Packets (4 bytes) | File CRC (2 bytes) |
---|---|---|---|
0x0004 | 0x0006 | 0x12345678 | ... |
File request command (CMD ID 0x0008)
After device is connected for a file upload, server initiates file transfer by sending a FILE REQ command.
Command ID | Data length | File Identifier |
---|---|---|
0x0008 | 2 bytes | See the table below |
Device should answer with a START command described above indicating a size and CRC of the requested file.
File source, type | Identifier (ASCII chars) |
---|---|
Photo from camera, rear | %photor |
Photo from camera, front | %photof |
Video from camera, rear | %videor |
Video from camera, front | %videof |
Resume file transfer command (CMD ID 0x0002)
In a response to the START command a RESUME command must be sent from a server.
Command ID | Data length | Packet offset (4 bytes) |
---|---|---|
0x0002 | 0x0004 | 0x00000000 |
To begin a file transfer from the start, offset should be set to zero (4 bytes value). In case when the file transfer has been interrupted, to resume file transfer, offset can be set to the desired value (0 ≤ [offset] ≤ [file size]).
Synchronize file transfer command (CMD ID 0x0003)
In a response to the RESUME command a SYNC command is sent from device.
Command ID | Data length | File offset (4 bytes) |
---|---|---|
0x0003 | 0x0004 | 0x00000000 |
By sending a SYNC command, it is ensured that the next data command will contain a file data starting from the specified offset.
File data transfer command (CMD ID 0x0004)
After sending a SYNC command, a file data transfer is started by sending DATA commands.
Command ID | Data length | File data (up to 1024 bytes) | Data CRC (2 bytes) |
---|---|---|---|
0x0004 | 0x0402 | ... | ... |
A File data is split into 1024 byte parts, each part wrapped into a DATA command and is sent.
Note: if a command with a bad CRC is received, RESUME command should be sent with the last valid file offset, after receiving a RESUME command, server will stop sending DATA commands and continue communication from “Resume file transfer” step.
CRC polynomial expression: 0x8408
Initial value, when calculating CRC, is previously received packet (CMD ID 0x0004) CRC value.
File transfer status command (CMD ID 0x0005)
After a file transfer is completed and no more files are required from the device, a server should send a COMPLETED command to the device (this command does not work after executing repeat init command0 x0009 – in this case the server should send a CLOSE SESSION 0x0000 command mentioned before).
Command ID | Data length | Status (4 bytes) |
---|---|---|
0x0005 | 0x0004 | 0x00000000 |
In case of the server using invalid arguments, commands or not following the file request flow, the device will send this command with a Status field set to one of the few possible error codes. List of possible ones is provided below.
Status value (hexadecimal) | Description | Notes |
---|---|---|
0x00000000 | File transfer process completed | Sent from server |
0x00000002 | Failed to close GPRS | Sent from device |
0x00000003 | Failed to close socket | Sent from device |
0x00000005 | Invalid response from server to init packet | Sent from device |
0x00000011 | This error code forces the device to disconnect from server | Sent from device. Possible causes:
|
After a COMPLETED command device should disconnect from the server.
Initialization packet repeat command (CMD ID 0x0009)
When sent, the initialization packet is repeated. This is used, when all of the files are downloaded and additional check is carried out for any additional files, that may have been captured during the download operation.