105 lines
2.9 KiB
Python
105 lines
2.9 KiB
Python
"""
|
|
Component that performs OpenCV classification on images.
|
|
|
|
For more details about this component, please refer to the documentation at
|
|
https://home-assistant.io/components/image_processing.opencv/
|
|
"""
|
|
from datetime import timedelta
|
|
import logging
|
|
|
|
from homeassistant.core import split_entity_id
|
|
from homeassistant.components.image_processing import (
|
|
ImageProcessingEntity, PLATFORM_SCHEMA)
|
|
from homeassistant.components.opencv import (
|
|
ATTR_MATCHES, CLASSIFIER_GROUP_CONFIG, CONF_CLASSIFIER, CONF_ENTITY_ID,
|
|
CONF_NAME, process_image)
|
|
|
|
_LOGGER = logging.getLogger(__name__)
|
|
|
|
DEPENDENCIES = ['opencv']
|
|
|
|
DEFAULT_TIMEOUT = 10
|
|
|
|
SCAN_INTERVAL = timedelta(seconds=2)
|
|
|
|
PLATFORM_SCHEMA = PLATFORM_SCHEMA.extend(CLASSIFIER_GROUP_CONFIG)
|
|
|
|
|
|
def _create_processor_from_config(hass, camera_entity, config):
|
|
"""Create an OpenCV processor from configuration."""
|
|
classifier_config = config[CONF_CLASSIFIER]
|
|
name = '{} {}'.format(
|
|
config[CONF_NAME], split_entity_id(camera_entity)[1].replace('_', ' '))
|
|
|
|
processor = OpenCVImageProcessor(
|
|
hass, camera_entity, name, classifier_config)
|
|
|
|
return processor
|
|
|
|
|
|
def setup_platform(hass, config, add_devices, discovery_info=None):
|
|
"""Set up the OpenCV image processing platform."""
|
|
if discovery_info is None:
|
|
return
|
|
|
|
devices = []
|
|
for camera_entity in discovery_info[CONF_ENTITY_ID]:
|
|
devices.append(
|
|
_create_processor_from_config(hass, camera_entity, discovery_info))
|
|
|
|
add_devices(devices)
|
|
|
|
|
|
class OpenCVImageProcessor(ImageProcessingEntity):
|
|
"""Representation of an OpenCV image processor."""
|
|
|
|
def __init__(self, hass, camera_entity, name, classifier_configs):
|
|
"""Initialize the OpenCV entity."""
|
|
self.hass = hass
|
|
self._camera_entity = camera_entity
|
|
self._name = name
|
|
self._classifier_configs = classifier_configs
|
|
self._matches = {}
|
|
self._last_image = None
|
|
|
|
@property
|
|
def last_image(self):
|
|
"""Return the last image."""
|
|
return self._last_image
|
|
|
|
@property
|
|
def matches(self):
|
|
"""Return the matches it found."""
|
|
return self._matches
|
|
|
|
@property
|
|
def camera_entity(self):
|
|
"""Return camera entity id from process pictures."""
|
|
return self._camera_entity
|
|
|
|
@property
|
|
def name(self):
|
|
"""Return the name of the image processor."""
|
|
return self._name
|
|
|
|
@property
|
|
def state(self):
|
|
"""Return the state of the entity."""
|
|
total_matches = 0
|
|
for group in self._matches.values():
|
|
total_matches += len(group)
|
|
return total_matches
|
|
|
|
@property
|
|
def state_attributes(self):
|
|
"""Return device specific state attributes."""
|
|
return {
|
|
ATTR_MATCHES: self._matches
|
|
}
|
|
|
|
def process_image(self, image):
|
|
"""Process the image."""
|
|
self._last_image = image
|
|
self._matches = process_image(
|
|
image, self._classifier_configs, False)
|