mirror of
https://github.com/google/earthengine-api.git
synced 2025-12-08 19:26:12 +00:00
173 lines
5.7 KiB
Python
173 lines
5.7 KiB
Python
"""A wrapper for Projections."""
|
|
from __future__ import annotations
|
|
|
|
from collections.abc import Sequence
|
|
from typing import Any, Union
|
|
|
|
from ee import _arg_types
|
|
from ee import apifunction
|
|
from ee import computedobject
|
|
from ee import ee_number
|
|
from ee import ee_string
|
|
|
|
_NumberSequenceType = Union[Sequence['_arg_types.Number']]
|
|
|
|
|
|
class Projection(computedobject.ComputedObject):
|
|
"""An object to represent an Earth Engine Projection.
|
|
|
|
Examples:
|
|
# Construct a variety of projections.
|
|
# crs: EPSG:4326, transform: identity
|
|
ee.Projection('EPSG:4326')
|
|
# crs: EPSG:4326, transform: projection.scale(2, 3)
|
|
ee.Projection('EPSG:4326', [2, 0, 0, 0, 3, 0])
|
|
# crs: EPSG:4326, transform wkt:
|
|
ee.Projection(
|
|
'EPSG:4326',
|
|
transformWkt=(
|
|
'GEOGCS["WGS 84",'
|
|
' DATUM["WGS_1984",'
|
|
' SPHEROID["WGS 84",6378137,298.257223563,'
|
|
' AUTHORITY["EPSG","7030"]],'
|
|
' AUTHORITY["EPSG","6326"]],'
|
|
' PRIMEM["Greenwich",0,'
|
|
' AUTHORITY["EPSG","8901"]],'
|
|
' UNIT["degree",0.0174532925199433,'
|
|
' AUTHORITY["EPSG","9122"]],'
|
|
' AXIS["Longitude",EAST],'
|
|
' AXIS["Latitude",NORTH]]'
|
|
),
|
|
)
|
|
"""
|
|
|
|
_initialized: bool = False
|
|
|
|
def __init__(
|
|
self,
|
|
crs: _arg_types.String,
|
|
transform: _NumberSequenceType | None = None,
|
|
# pylint: disable-next=invalid-name
|
|
transformWkt: _arg_types.String | None = None,
|
|
):
|
|
"""Creates a Projection wrapper.
|
|
|
|
Returns a Projection with the given base coordinate system and the given
|
|
transform between projected coordinates and the base.
|
|
|
|
Args:
|
|
crs: The base coordinate reference system of this Projection, given as a
|
|
well-known authority code (e.g., 'EPSG:4326') or a WKT string.
|
|
transform: The transform between projected coordinates and the base
|
|
coordinate system, specified as a 2x3 affine transform matrix in
|
|
row-major order: [xScale, xShearing, xTranslation, yShearing, yScale,
|
|
yTranslation]. May not specify both this and 'transformWkt'.
|
|
transformWkt: The transform between projected coordinates and the base
|
|
coordinate system, specified as a WKT string. May not specify both this
|
|
and 'transform'.
|
|
"""
|
|
self.initialize()
|
|
|
|
if (
|
|
isinstance(crs, computedobject.ComputedObject)
|
|
and transform is None
|
|
and transformWkt is None
|
|
):
|
|
# Handles cases where a user wants to manually cast a projection. Examples
|
|
# include: `ee.Projection(ee.Image(...).projection())` and
|
|
# `ee.Projection(ee.Projection(...))`.
|
|
if self.is_func_returning_same(crs):
|
|
# If it is a call that is already returning a Projection, just cast.
|
|
super().__init__(crs.func, crs.args, crs.varName)
|
|
return
|
|
|
|
args: dict[str, Any] = {'crs': crs}
|
|
if transform is not None:
|
|
args['transform'] = transform
|
|
if transformWkt is not None:
|
|
args['transformWkt'] = transformWkt
|
|
|
|
func = apifunction.ApiFunction(self.name())
|
|
super().__init__(func, func.promoteArgs(args))
|
|
|
|
@classmethod
|
|
def initialize(cls) -> None:
|
|
"""Imports API functions to this class."""
|
|
if not cls._initialized:
|
|
apifunction.ApiFunction.importApi(cls, cls.name(), cls.name())
|
|
cls._initialized = True
|
|
|
|
@classmethod
|
|
def reset(cls) -> None:
|
|
"""Removes imported API functions from this class."""
|
|
apifunction.ApiFunction.clearApi(cls)
|
|
cls._initialized = False
|
|
|
|
@staticmethod
|
|
def name() -> str:
|
|
return 'Projection'
|
|
|
|
def atScale(self, meters: _arg_types.Number) -> Projection:
|
|
"""Returns an ee.Projection scaled to the given scale in linear meters.
|
|
|
|
Returns the projection scaled such that its units have the given scale in
|
|
linear meters, as measured at the point of true scale.
|
|
|
|
Args:
|
|
meters: The scale in linear meters.
|
|
"""
|
|
|
|
return apifunction.ApiFunction.call_(self.name() + '.atScale', self, meters)
|
|
|
|
def crs(self) -> ee_string.String:
|
|
"""Returns the coordinate reference system (crs) of this projection.
|
|
|
|
Returns the authority code (e.g., 'EPSG:4326') for the base coordinate
|
|
system of this projection, or null if the base coordinate system is not
|
|
found in any available database.
|
|
"""
|
|
|
|
return apifunction.ApiFunction.call_(self.name() + '.crs', self)
|
|
|
|
def nominalScale(self) -> ee_number.Number:
|
|
"""Returns the linear scale in meters of the units of this projection.
|
|
|
|
Done as measured at the point of true scale.
|
|
"""
|
|
|
|
return apifunction.ApiFunction.call_(self.name() + '.nominalScale', self)
|
|
|
|
def scale(self, x: _arg_types.Number, y: _arg_types.Number) -> Projection:
|
|
"""Returns an ee.Projection scaled by the given amount in each axis.
|
|
|
|
Args:
|
|
x: The amount to scale by in the x axis.
|
|
y: The amount to scale by in the y axis.
|
|
"""
|
|
|
|
return apifunction.ApiFunction.call_(self.name() + '.scale', self, x, y)
|
|
|
|
def transform(self) -> ee_string.String:
|
|
"""Returns a WKT representation of the transform of this Projection.
|
|
|
|
This is the transform that converts from projected coordinates to the base
|
|
coordinate system.
|
|
"""
|
|
|
|
return apifunction.ApiFunction.call_(self.name() + '.transform', self)
|
|
|
|
def translate(self, x: _arg_types.Number, y: _arg_types.Number) -> Projection:
|
|
"""Returns an ee.Projection translated by the given amount in each axis.
|
|
|
|
Args:
|
|
x: The amount to translate by in the x axis.
|
|
y: The amount to translate by in the y axis.
|
|
"""
|
|
|
|
return apifunction.ApiFunction.call_(self.name() + '.translate', self, x, y)
|
|
|
|
def wkt(self) -> ee_string.String:
|
|
"""Returns a WKT representation of the base coordinate system of this Projection."""
|
|
|
|
return apifunction.ApiFunction.call_(self.name() + '.wkt', self)
|