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

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