Package for controlling PTZ IP cameras that support ONVIF
Project description
Overview
Package of tools for interfacing with PTZ network surveillance cameras and controlling them in responsive and programmatic ways.
Hardware
-
a Pan-Tilt-Zoom networked surveillance camera that has good compliance with the ONVIF protocol. ptzipcam has been the most tested with Hikvision cameras.
-
a computer to run the software (tested on a few x86_64 systems and on Raspberry Pi 4 Model B devices)
-
ethernet cable to connect the camera to the computer
-
power source for the camera
Operating System
Currently, ptzipcam has been tested on Ubuntu 18.04 and 20.04 on x86_64 machines and Raspian Buster on Pis (ARM CPU)
Installation instructions
From PyPI
pip install ptzipcam
Note you probably still will need to install the WSDL files as outlined below. However, the instructions below do assume you have installed ptzipcam in a virtual environment and that you have some WSDL files to work with (some are included in the package code repo itself)
From GitHub repo
Clone the ptzipcam repository
git clone git@github.com:iingram/ptzipcam.git
Set up a virtual environment
It is recommended to create a virtual environment to work within.
Install the virtualenv packages we need:
sudo pip3 install virtualenv virtualenvwrapper
Setup virtual environment tools:
echo -e "\n# Virtual environment setup" >> ~/.bashrc
echo "export WORKON_HOME=$HOME/.virtualenvs" >> ~/.bashrc
echo "export VIRTUALENVWRAPPER_PYTHON=/usr/bin/python3" >> ~/.bashrc
echo "source /usr/local/bin/virtualenvwrapper.sh" >> ~/.bashrc
source ~/.bashrc
Create a virtual environment for the ptzipcam project:
mkvirtualenv ptzipcam_env
Note that ptzipcam requires Python 3 so if the default on your system is Python 2, make sure the virtual environment will use Python 3:
mkvirtualenv ptzipcam_env -p python3
Activate virtual environment (not necessary if you just made it)
workon ptzipcam_env
Run install script
./install.sh
Testing
To verify everything is configured properly you can try one of the example applications. Some of these require more hardware and packages so a good one to test with is this one:
./look_around_randomly.py cfgs/CONFIG_FILE.yaml
You'll notice the example takes a YAML configuration file as its only
CLI argument. An example configuration file is provided in cfgs/
Some elements have to be configured for your particular setup
(e.g. the IP of the camera and user credentials for an account on the
camera (the account must have ONVIF privileges)). For now it is
assumed that these are well-enough self-documented in the example
config file but when that turns out not to be the case, we'll provide
better documentation here, plus some documentation of the other
configuration parameters that should work with most cameras without
adjustment but that you might want to tune for your application.
Installing WSDL files
For the ONVIF connection to the camera to work, WSDL files must be placed in the appropriate place in the virtual environment files.
If you are installing from the repository, for convenience a set of WSDL files are currently included in the repo so the following steps should put them in the correct location (assuming you are still inside of the local ptzipcam repo directory):
cp wsdl/wsdl.tar.gz ~/.virtualenvs/ptzipcam_env/lib/python3.7/site-packages/
cd ~/.virtualenvs/ptzipcam_env/lib/python3.7/site-packages/
tar xzf wsdl.tar.gz
rm wsdl.tar.gz
cd -
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file ptzipcam-0.0.3.tar.gz.
File metadata
- Download URL: ptzipcam-0.0.3.tar.gz
- Upload date:
- Size: 12.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.8.0 pkginfo/1.9.5 readme-renderer/34.0 requests/2.27.1 requests-toolbelt/0.9.1 urllib3/1.26.10 tqdm/4.64.1 importlib-metadata/4.2.0 keyring/23.4.1 rfc3986/1.5.0 colorama/0.4.5 CPython/3.6.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a70cd6d9434debc6c3081093842976dcba6b4f93c714701c024a52fdedb80093
|
|
| MD5 |
e23ae5aeb01b1f9fae71d02ae3181d98
|
|
| BLAKE2b-256 |
45cc5959f571be65fd9343cf9d392325f373a196d357f9193921350c5af17b7e
|
File details
Details for the file ptzipcam-0.0.3-py3-none-any.whl.
File metadata
- Download URL: ptzipcam-0.0.3-py3-none-any.whl
- Upload date:
- Size: 14.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.8.0 pkginfo/1.9.5 readme-renderer/34.0 requests/2.27.1 requests-toolbelt/0.9.1 urllib3/1.26.10 tqdm/4.64.1 importlib-metadata/4.2.0 keyring/23.4.1 rfc3986/1.5.0 colorama/0.4.5 CPython/3.6.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
efbad475c4ee0a857ab6ccf9490ec76c62b8bb8934a743ea3b6eb2f2c1ee6a51
|
|
| MD5 |
4b2acbb07550757114d3e26cd774598d
|
|
| BLAKE2b-256 |
46f1158ae924a6e216794349c462d4898ebadd92e4e98616f0d05f6c7813f2db
|