![JAR search and dependency download from the Maven repository](/logo.png)
org.bimserver.serializers.binarygeometry.Bounds Maven / Gradle / Ivy
package org.bimserver.serializers.binarygeometry;
/******************************************************************************
* Copyright (C) 2009-2019 BIMserver.org
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see {@literal }.
*****************************************************************************/
import java.io.IOException;
import org.bimserver.interfaces.objects.SBounds;
import org.bimserver.interfaces.objects.SVector3f;
import org.bimserver.models.geometry.Vector3f;
import com.google.common.io.LittleEndianDataOutputStream;
public class Bounds {
public Double3 min;
public Double3 max;
public Bounds(Double3 min, Double3 max) {
this.min = min;
this.max = max;
}
public Bounds() {
this.min = new Double3(Float.MAX_VALUE, Float.MAX_VALUE, Float.MAX_VALUE);
this.max = new Double3(-Float.MAX_VALUE, -Float.MAX_VALUE, -Float.MAX_VALUE);
}
public Bounds(Vector3f minBounds, Vector3f maxBounds) {
this.min = new Double3(minBounds.getX(), minBounds.getY(), minBounds.getZ());
this.max = new Double3(maxBounds.getX(), maxBounds.getY(), maxBounds.getZ());
}
public Bounds(SVector3f minBounds, SVector3f maxBounds) {
this.min = new Double3(minBounds.getX(), minBounds.getY(), minBounds.getZ());
this.max = new Double3(maxBounds.getX(), maxBounds.getY(), maxBounds.getZ());
}
public Bounds(org.bimserver.models.geometry.Bounds bounds) {
this(new Double3(
bounds.getMin().getX(),
bounds.getMin().getY(),
bounds.getMin().getZ()),
new Double3(
bounds.getMax().getX(),
bounds.getMax().getY(),
bounds.getMax().getZ()));
}
public Bounds(SBounds bounds) {
this(bounds.getMin(), bounds.getMax());
}
public void integrate(Bounds objectBounds) {
this.min.min(objectBounds.min);
this.max.max(objectBounds.max);
}
public void writeTo(LittleEndianDataOutputStream dataOutputStream) throws IOException {
min.writeTo(dataOutputStream);
max.writeTo(dataOutputStream);
}
public boolean in(float[] vertex) {
return vertex[0] >= min.x && vertex[0] <= max.x && vertex[1] >= min.y && vertex[1] <= max.y && vertex[2] >= min.z && vertex[2] <= max.z;
}
@Override
public String toString() {
return "[" + min.x + ", " + min.y + ", " + min.z + "] [" + max.x + ", " + max.y + ", " + max.z + "]";
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy