Source code for google.cloud.vision.entity

# Copyright 2016 Google Inc.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
#     http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

"""Entity class for holding information returned from annotating an image."""


from google.cloud.vision.geometry import Bounds
from google.cloud.vision.geometry import LocationInformation


[docs]class EntityAnnotation(object): """Representation of an entity returned from the Vision API. :type bounds: dict :param bounds: Dictionary of bounary information of detected entity. :type description: str :param description: Description of entity detected in an image. :type locale: str :param locale: The language code for the locale in which the entity textual description (next field) is expressed. :type locations: list of :class:`~google.cloud.vision.geometry.LocationInformation`. :param locations: List of ``LocationInformation`` instances. :type mid: str :param mid: Opaque entity ID. :type score: float :param score: Overall score of the result. Range [0, 1]. """ def __init__(self, bounds, description, locale, locations, mid, score): self._bounds = bounds self._description = description self._locale = locale self._locations = locations self._mid = mid self._score = score @classmethod
[docs] def from_api_repr(cls, response): """Factory: construct entity from Vision API response. :type response: dict :param response: Dictionary response from Vision API with entity data. :rtype: :class:`~google.cloud.vision.entity.EntityAnnotation` :returns: Instance of ``EntityAnnotation``. """ bounds = Bounds.from_api_repr(response.get('boundingPoly')) description = response['description'] locale = response.get('locale', None) locations = [LocationInformation.from_api_repr(location) for location in response.get('locations', [])] mid = response.get('mid', None) score = response.get('score', None) return cls(bounds, description, locale, locations, mid, score)
@property def bounds(self): """Bounding polygon of detected image feature. :rtype: :class:`~google.cloud.vision.geometry.Bounds` :returns: Instance of ``Bounds`` with populated vertices. """ return self._bounds @property def description(self): """Description of feature detected in image. :rtype: str :returns: String description of feature detected in image. """ return self._description @property def locale(self): """The language code for text discovered in an image. :rtype: str :returns: String language code of text found in the image. """ return self._locale @property def locations(self): """Location coordinates landmarks detected. :rtype: :class:`~google.cloud.vision.geometry.LocationInformation` :returns: ``LocationInformation`` populated with latitude and longitude of object detected in an image. """ return self._locations @property def mid(self): """MID of feature detected in image. :rtype: str :returns: String MID of feature detected in image. """ return self._mid @property def score(self): """Overall score of the result. Range [0, 1]. :rtype: float :returns: Overall score of the result. Range [0, 1]. """ return self._score