BoundarySource2S.java

  1. /*
  2.  * Licensed to the Apache Software Foundation (ASF) under one or more
  3.  * contributor license agreements.  See the NOTICE file distributed with
  4.  * this work for additional information regarding copyright ownership.
  5.  * The ASF licenses this file to You under the Apache License, Version 2.0
  6.  * (the "License"); you may not use this file except in compliance with
  7.  * the License.  You may obtain a copy of the License at
  8.  *
  9.  *      http://www.apache.org/licenses/LICENSE-2.0
  10.  *
  11.  * Unless required by applicable law or agreed to in writing, software
  12.  * distributed under the License is distributed on an "AS IS" BASIS,
  13.  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  14.  * See the License for the specific language governing permissions and
  15.  * limitations under the License.
  16.  */
  17. package org.apache.commons.geometry.spherical.twod;

  18. import java.util.Arrays;
  19. import java.util.Collection;
  20. import java.util.List;
  21. import java.util.stream.Collectors;

  22. import org.apache.commons.geometry.core.partitioning.BoundarySource;

  23. /** Extension of the {@link BoundarySource} interface for spherical 2D
  24.  * space.
  25.  */
  26. public interface BoundarySource2S extends BoundarySource<GreatArc> {

  27.     /** Return a {@link BoundaryList2S} containing the boundaries in this instance.
  28.      * @return a {@link BoundaryList2S} containing the boundaries in this instance
  29.      */
  30.     default BoundaryList2S toList() {
  31.         final List<GreatArc> boundaries = boundaryStream()
  32.                 .collect(Collectors.toList());

  33.         return new BoundaryList2S(boundaries);
  34.     }

  35.     /** Return a BSP tree constructed from the boundaries contained in this
  36.      * instance. The default implementation creates a new, empty tree
  37.      * and inserts the boundaries from this instance.
  38.      * @return a BSP tree constructed from the boundaries in this instance
  39.      */
  40.     default RegionBSPTree2S toTree() {
  41.         final RegionBSPTree2S tree = RegionBSPTree2S.empty();
  42.         tree.insert(this);

  43.         return tree;
  44.     }

  45.     /** Return a {@link BoundarySource2S} instance containing the given boundaries.
  46.      * @param boundaries boundaries to include in the boundary source
  47.      * @return a boundary source containing the given boundaries
  48.      */
  49.     static BoundarySource2S of(final GreatArc... boundaries) {
  50.         return of(Arrays.asList(boundaries));
  51.     }

  52.     /** Return a {@link BoundarySource2S} instance containing the given boundaries. The given
  53.      * collection is used directly as the source of the line subsets; no copy is made.
  54.      * @param boundaries boundaries to include in the boundary source
  55.      * @return a boundary source containing the given boundaries
  56.      */
  57.     static BoundarySource2S of(final Collection<GreatArc> boundaries) {
  58.         return boundaries::stream;
  59.     }
  60. }