CurvePolygon
CurvePolygon является топологически закрытой областью, определенной внешним ограничивающим кольцом, а также нулем или более внутренних колец.
Важно! |
---|
Подробное описание и примеры использования новых возможностей обработки пространственных данных в этом выпуске, включая подтип CurvePolygon, можно получить, загрузив технический документ Новые возможности обработки пространственных данных в SQL Server 2012. |
Следующие критерии определяют атрибуты экземпляра CurvePolygon .
Границы экземпляра CurvePolygon определяются внешним кольцом и всеми внутренними кольцами.
Внутреннее пространство экземпляра CurvePolygon ― это пространство между внешним кольцом и всеми внутренними кольцами.
Экземпляр CurvePolygon отличается от экземпляра Polygon тем, что экземпляр CurvePolygon может содержать следующие сегменты дуги: CircularString и CompoundCurve.
Экземпляры CompoundCurve
На следующей иллюстрации показаны допустимые фигуры CurvePolygon.
Правильные экземпляры
Чтобы экземпляр CurvePolygon был принят, он должен быть либо пустым, либо содержать только принимаемые кольца дуги. Принимаемое кольцо дуги удовлетворяет следующим требованиям.
Является принятым экземпляром LineString, CircularString или CompoundCurve. Дополнительные сведения о принятых экземплярах см. в разделах LineString, CircularString и CompoundCurve.
Имеет минимум четыре точки.
Начальная и конечная точки имеют одинаковые координаты X и Y.
Примечание Значения Z и M пропускаются.
В следующем примере показаны принятые экземпляры CurvePolygon.
DECLARE @g1 geometry = 'CURVEPOLYGON EMPTY';
DECLARE @g2 geometry = 'CURVEPOLYGON((0 0, 0 0, 0 0, 0 0))';
DECLARE @g3 geometry = 'CURVEPOLYGON((0 0 1, 0 0 2, 0 0 3, 0 0 3))'
DECLARE @g4 geometry = 'CURVEPOLYGON(CIRCULARSTRING(1 3, 3 5, 4 7, 7 3, 1 3))';
DECLARE @g5 geography = 'CURVEPOLYGON((-122.3 47, 122.3 -47, 125.7 -49, 121 -38, -122.3 47))';
Экземпляр @g3 принимается, несмотря на то что начальная и конечная точки имеют различные значения Z, поскольку значения Z не учитываются. Экземпляр @g5 принимается, хотя экземпляр типа geography является недопустимым.
Следующие примеры вызывают исключение System.FormatException.
DECLARE @g1 geometry = 'CURVEPOLYGON((0 5, 0 0, 0 0, 0 0))';
DECLARE @g2 geometry = 'CURVEPOLYGON((0 0, 0 0, 0 0))';
Экземпляр @g1 не принимается, поскольку не совпадают значения Y для начальной и конечной точек. Экземпляр @g2 не принимается, поскольку кольцо содержит недостаточное число точек.
Допустимые экземпляры
Чтобы экземпляр CurvePolygon был допустимым, внешние и внутренние кольца должны удовлетворять следующим критериям.
Они могут соприкасаться только в одной точке касания.
Они не могут пересекать друг друга.
Каждое кольцо должно содержать минимум четыре точки.
Каждое кольцо должно принадлежать к приемлемому типу кривой.
Кроме того, экземпляры CurvePolygon должны удовлетворять особым критериям в зависимости от того, к какому типу данных они принадлежат, geometry или geography.
Тип данных Geometry
Допустимый экземпляр geometryCurvePolygon должен иметь следующие атрибуты.
Все внутренние кольца должны находиться в пределах внешнего кольца.
Могут иметь несколько внутренних колец, но при этом одно внутреннее кольцо не может содержать другое внутреннее кольцо.
Кольцо не может пересекать само себя или другое кольцо.
Кольца могут соприкасаться только в одной точке (число точек, где точки соприкасаются, должно быть конечным).
Внутренняя часть многоугольника должна быть замкнутой.
В следующем примере показаны допустимые экземпляры geometryCurvePolygon.
DECLARE @g1 geometry = 'CURVEPOLYGON EMPTY';
DECLARE @g2 geometry = 'CURVEPOLYGON(CIRCULARSTRING(1 3, 3 5, 4 7, 7 3, 1 3))';
SELECT @g1.STIsValid(), @g2.STIsValid();
К экземплярам CurvePolygon применяются такие правила определения допустимости, как и к экземплярам Polygon, за исключением того, что экземпляры CurvePolygon могут принимать новые типы сегментов дуги. Дополнительные примеры допустимых и недопустимых экземпляров приведены в разделе Polygon.
Тип данных Geography
Допустимый экземпляр geographyCurvePolygon должен иметь следующие атрибуты.
Внутреннее пространство многоугольника соединяется с использованием правила левой руки.
Кольцо не может пересекать само себя или другое кольцо.
Кольца могут соприкасаться только в одной точке (число точек, где точки соприкасаются, должно быть конечным).
Внутренняя часть многоугольника должна быть замкнутой.
В следующем примере показан допустимый экземпляр CurvePolygon типа Geography.
DECLARE @g geography = 'CURVEPOLYGON((-122.3 47, 122.3 47, 125.7 49, 121 38, -122.3 47))';
SELECT @g.STIsValid();
Примеры
А.Создание экземпляра типа Geometry с пустым CurvePolygon
В этом примере показано, как создать пустой экземпляр CurvePolygon:
DECLARE @g geometry;
SET @g = geometry::Parse('CURVEPOLYGON EMPTY');
Б.Объявление и создание экземпляра типа Geometry с CurvePolygon в одной и той же инструкции
В этом фрагменте кода показывается объявление и инициализация экземпляра типа Geometry с CurvePolygon в одной инструкции.
DECLARE @g geometry = 'CURVEPOLYGON(CIRCULARSTRING(2 4, 4 2, 6 4, 4 6, 2 4))'
В.Создание экземпляра типа Geometry с CurvePolygon
На примере следующего фрагмента кода показано объявление и создание экземпляра geography с CurvePolygon.
DECLARE @g geography = 'CURVEPOLYGON(CIRCULARSTRING(-122.358 47.653, -122.348 47.649, -122.348 47.658, -122.358 47.658, -122.358 47.653))';
Г.Сохранение CurvePolygon только с внешним ограничивающим кольцом
В этом примере показано сохранение простого круга в экземпляре CurvePolygon (для определения круга используется только внешнее ограничивающее кольцо):
DECLARE @g geometry;
SET @g = geometry::Parse('CURVEPOLYGON(CIRCULARSTRING(2 4, 4 2, 6 4, 4 6, 2 4))');
SELECT @g.STArea() AS Area;
Д.Сохранение CurvePolygon с внутренними кольцами
В этом примере в экземпляре CurvePolygon создается бублик (для определения бублика используются как внешнее ограничивающее кольцо, так и внутреннее кольцо):
DECLARE @g geometry;
SET @g = geometry::Parse('CURVEPOLYGON(CIRCULARSTRING(0 4, 4 0, 8 4, 4 8, 0 4), CIRCULARSTRING(2 4, 4 2, 6 4, 4 6, 2 4))');
SELECT @g.STArea() AS Area;
В этом примере показано, как при использовании внутренних колец экземпляр CurvePolygon может быть допустимым и недопустимым.
DECLARE @g1 geometry, @g2 geometry;
SET @g1 = geometry::Parse('CURVEPOLYGON(CIRCULARSTRING(0 5, 5 0, 0 -5, -5 0, 0 5), (-2 2, 2 2, 2 -2, -2 -2, -2 2))');
IF @g1.STIsValid() = 1
BEGIN
SELECT @g1.STArea();
END
SET @g2 = geometry::Parse('CURVEPOLYGON(CIRCULARSTRING(0 5, 5 0, 0 -5, -5 0, 0 5), (0 5, 5 0, 0 -5, -5 0, 0 5))');
IF @g2.STIsValid() = 1
BEGIN
SELECT @g2.STArea();
END
SELECT @g1.STIsValid() AS G1, @g2.STIsValid() AS G2;
Экземпляры @g1 и @g2 используют одно и то же внешнее ограничивающее кольцо: окружность радиусом 5, а внутренним кольцом обоих экземпляров служит квадрат. При этом экземпляр @g1 является допустимым, а @g2 ― нет. Причина, по которой экземпляр @g2 является недопустимым, заключается в том, что внутреннее кольцо делит внутреннее пространство, ограниченное внешним кольцом, на четыре отдельные области. На следующем чертеже показано, что произошло.
См. также
Основные понятия
Справочник по методам типа данных geometry
Основные сведения о типах пространственных данных