<img alt="example of region editor" src="https://raw.githubusercontent.com/Breakthrough/DVR-Scan/releases/1.6/docs/assets/region-editor-multiple.jpg" width="480"/>
<img alt="example of region editor" src="https://raw.githubusercontent.com/Breakthrough/DVR-Scan/releases/1.6/docs/assets/region-editor-mask.jpg" width="480"/>
Multiple regions can now be defined with any shape, size, and complexity. Region data can be saved to a file and loaded again. Regions can also be specified by command line.
There are also several other bugfixes and improvements, such as improved seeking performance.
Changelog
- [feature] [New region editor](https://www.dvr-scan.com/guide/#region-editor) `-r`/`--region-editor` allows creation of multiple regions without shape restrictions, replaces `-roi`/`--region-of-interest`
- [feature] Multiple regions of interest (rectangular or polygonal) can now be created:
- Using the new region editor by adding the `-r`/`--region-editor` flag: `dvr-scan -i video.mp4 -r`
- New `-a`/`--add-region` replaces `-roi`/`--region-of-interest` option: `dvr-scan -i video.mp4 -a 5 5 20 5 20 20 5 20`
- Regions can now be saved to a file: press S in the region editor or use `-s`/`--save-region`
- Regions can now be loaded from a file: press O in the region editor or use `-R`/`--load-region`
- Config files can specify a region file to use by default with the `load-region` option, replaces the `region-of-interest` setting
- [feature] New `-fm` / `--frame-metrics` option draws motion score on each frame to help tune detection parameters
- [cli] Short flag `-v` is now used for `--verbosity`, replaced by `-V` for `--version`
- [cli] `-roi`/`--region-of-interest` is now deprecated, replaced by region editor and add/save/load region flags
- Specifying this option will display the ROI in the new region format allowing you to update usages more easily
- [general] Improved seeking performance, using `-st`/`--start-time` is now much faster ([92](https://github.com/Breakthrough/DVR-Scan/issues/92))
-detection-parameters)
- [general] Noise reduction kernel can now be disabled by setting `-k`/`--kernel-size` to `0` ([123](https://github.com/Breakthrough/DVR-Scan/issues/123))
- [general] Include stack traces in logfiles when setting `--verbosity debug`
- [bugfix] Add `max-score` option to config file to fix CNT mode always treating first few frame as motion, default is 255.0 [119](https://github.com/Breakthrough/DVR-Scan/issues/119)
- [bugfix] Fix timecode format `HH:MM:SS[.nnn]` being rejected for start/end time ([141](https://github.com/Breakthrough/DVR-Scan/issues/141))
- [bugfix] Fix incorrect RGB mapping for config file (values were treated as BGR instead)
- [other] Config option `timecode` has been renamed to `time-code` to match the command-line option
- [other] Config options that started with `timecode-` have been renamed to start with `text-`, and are now shared between the `time-code` and `frame-metrics` overlays:
- `time-code-margin` is now `text-margin`
- `time-code-font-scale` is now `text-font-scale`
- `time-code-font-thickness` is now `text-font-thickness`
- `time-code-font-color` is now `text-font-color`
- `time-code-bg-color` is now `text-bg-color`
[dvr-scan-1.6.tar.gz](https://github.com/Breakthrough/DVR-Scan/files/12912074/dvr-scan-1.6.tar.gz)
v1.5.1-release
Minor re-release of v1.5 to fix crash when opening multiple videos.
Changelog
* [bugfix] Fix crash when opening multiple input videos ([95](https://github.com/Breakthrough/DVR-Scan/issues/95))
* [bugfix] Fix incorrect warning regarding frame decode failures at end of video
v1.5-release
Release Notes
* Significant performance improvements on multicore systems
* Support wildcards/globs as inputs for scanning entire folders (`-i folder/*.mp4`)
* Allow use of ffmpeg for better output quality (`-m ffmpeg`) or codec-copying mode (`-m copy`)
* Configuration files are now supported, [see documentation for details](https://dvr-scan.readthedocs.io/en/latest/guide/config_file/)
* Can specify config file path with `-c`/`--config`, or create a `dvr-scan.cfg` file in your user config folder
* Windows binaries are now signed, thanks [SignPath.io](https://signpath.io/) (certificate by [SignPath Foundation](https://signpath.org/))
* **Experimental** Nvidia CUDA® support has been added (set `-b MOG2_CUDA`)
* If installing via `pip`, requires manual installation of OpenCV compiled with CUDA support
* If downloading Windows version, make sure to download the GPU-enabled build (`dvr-scan-1.5-win64-cuda.zip`)
* CUDA-enabled builds only support GTX 900-series and above GPUs, do not include the `CNT` method, and are not yet code signed
* Minimum supported Python version is now 3.7
* Minimum supported OpenCV version is now 3.x
Command-Line Changes
* New options:
* `-c`/`--config` - set path to config file
* `-d`/`--output-dir` - set directory to write output files (default is working directory)
* `-m`/`--output-mode` - set output mode (one of: `opencv`, `ffmpeg`, `copy`)
* `-mo`/`--mask-output` - path to write motion mask for analysis
* `--verbosity`, `--logfile` - control output verbosity, path to save log output
* `-i`/`--input` now supports globs/wildcards to scan entire folders, e.g. `-i folder/*.mp4`
* Change default value for `-l`/`--min-event-length` to 0.1 seconds, previously was 2 frames
* Long form of `-roi` has been renamed to `--region-of-interest` (previously was `--rectangle-of-interest`)
* `-c` is now used for `--config`, previously was for `--codec`
* Add experimental `MOG2_CUDA` option for `-b`/`--bg-subtractor`
* Rename existing `MOG` option to `MOG2`
* `--codec` has been removed, the value should now be set using [config file option `opencv-fourcc`](https://dvr-scan.readthedocs.io/en/v1.5/guide/config_file/#inputoutput)
Changelog
* [feature] Configuration file support and new `-c`/`--config` argument to specify path to config files ([77](https://github.com/Breakthrough/DVR-Scan/issues/77))
* Breaks existing behavior of `-c` (was previously the shortform of `--codec`)
* [feature] Add support for multiple output modes via `-m`/`--output-mode` argument ([27](https://github.com/Breakthrough/DVR-Scan/issues/27), [#42](https://github.com/Breakthrough/DVR-Scan/issues/42))
* [feature] Experimental support for GPU-based CUDA MOG2 filter ([12](https://github.com/Breakthrough/DVR-Scan/issues/12))
* [feature] Video encoding and decoding are now done in parallel with the scanning logic leading to improved performance on most systems ([52](https://github.com/Breakthrough/DVR-Scan/issues/52))
* [feature] Add support for exporting motion masks via `-mo`/`--mask-output` argument
* Useful for detailed analysis or tuning of detection parameters
* ffmpeg can be used to generate output videos by specifying `-m ffmpeg`
* Codec-copy mode, using ffmpeg, can be used by specifying `-m copy`
* [feature] Add `--verbosity` and `--logfile` arguments to provide more control over program output
* [feature] Allow scanning entire folders using wildcards with `-i`/`--input` ([5](https://github.com/Breakthrough/DVR-Scan/issues/5))
* Glob expansion is also performed on each input path directly, so quoted globs also function correctly
* [bugfix] Fix incorrect results when `-st`/`--start-time` is set
* [bugfix] Event start times are now correctly calculated when using `-fs`/`--frame-skip` ([68](https://github.com/Breakthrough/DVR-Scan/issues/68), [#70](https://github.com/Breakthrough/DVR-Scan/issues/70))
* Note that all skipped frames within the event window are included in motion event, thus the calculated start time may be slightly earlier
* [bugfix] Only get screen resolution when required (was causing issues on headless machines)
* [bugfix] Fix output messages conflicting with progress bar shown during scanning
* [bugfix] Output events now start from 1 to align with the event list
* [bugfix] Event end times now include the presentation duration of the last frame
* [bugfix] Small values for `-l`/`--min-event-length` are now handled correctly, previously would cause an error
* [enhancement] Progress bar now indicates how many events have been detected so far
* [enhancement] Change default value for `min_event_len` to 0.1 seconds, previously was 2 frames ([91](https://github.com/Breakthrough/DVR-Scan/issues/91))
Known Issues
* Attempting to open multiple input videos will cause DVR-Scan to crash, fixed in v1.5.1 ([95](https://github.com/Breakthrough/DVR-Scan/issues/95))
* Variable framerate videos (VFR) are not fully supported, and will yield incorrect timestamps ([20](https://github.com/Breakthrough/DVR-Scan/issues/20))
* Video output when using frame skip and `-m opencv` (default output mode) will result in frames missing from the exported videos ([81](https://github.com/Breakthrough/DVR-Scan/issues/81))
* Use `-m ffmpeg` or `-m copy` as a workaround
* Multiple input videos are not supported with `-m ffmpeg` or `-m copy` ([86](https://github.com/Breakthrough/DVR-Scan/issues/86))
* Use ffmpeg to [concatenate/merge input videos](https://trac.ffmpeg.org/wiki/Concatenate) before processing as a workaround
* CUDA builds do not include the `CNT` option for `-b`/`--bg-subtractor`