All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.xmlobjects.gml.model.geometry.primitives.Curve Maven / Gradle / Ivy

There is a newer version: 1.1.2
Show newest version
/*
 * gml-objects - A Java mapping for the OGC Geography Markup Language (GML)
 * https://github.com/xmlobjects/gml-objects
 *
 * Copyright 2019-2024 Claus Nagel 
 *
 * 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.
 */

package org.xmlobjects.gml.model.geometry.primitives;

import org.xmlobjects.gml.visitor.GeometryVisitor;
import org.xmlobjects.gml.visitor.ObjectVisitor;

import java.util.ArrayList;
import java.util.Collections;
import java.util.List;

public class Curve extends AbstractCurve {
    private CurveSegmentArrayProperty segments;

    public Curve() {
    }

    public Curve(CurveSegmentArrayProperty segments) {
        setSegments(segments);
    }

    public CurveSegmentArrayProperty getSegments() {
        return segments;
    }

    public void setSegments(CurveSegmentArrayProperty segments) {
        this.segments = asChild(segments);
    }

    @Override
    public List toCoordinateList3D() {
        if (segments != null && segments.isSetObjects()) {
            List coordinates = new ArrayList<>();
            for (AbstractCurveSegment segment : segments.getObjects()) {
                if (segment != null) {
                    List candidates = segment.toCoordinateList3D();
                    if (!candidates.isEmpty()) {
                        int size = coordinates.size();
                        if (size == 0)
                            coordinates.addAll(candidates);
                        else {
                            if (candidates.get(0).doubleValue() == coordinates.get(size - 3).doubleValue()
                                    && candidates.get(1).doubleValue() == coordinates.get(size - 2).doubleValue()
                                    && candidates.get(2).doubleValue() == coordinates.get(size - 1).doubleValue())
                                coordinates.addAll(candidates.subList(3, candidates.size()));
                            else
                                coordinates.addAll(candidates);
                        }
                    }
                }
            }

            return coordinates;
        } else
            return Collections.emptyList();
    }

    @Override
    public void accept(ObjectVisitor visitor) {
        visitor.visit(this);
    }

    @Override
    public void accept(GeometryVisitor visitor) {
        visitor.visit(this);
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy