aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/llmath/llbboxlocal.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'linden/indra/llmath/llbboxlocal.cpp')
-rw-r--r--linden/indra/llmath/llbboxlocal.cpp56
1 files changed, 56 insertions, 0 deletions
diff --git a/linden/indra/llmath/llbboxlocal.cpp b/linden/indra/llmath/llbboxlocal.cpp
new file mode 100644
index 0000000..b197241
--- /dev/null
+++ b/linden/indra/llmath/llbboxlocal.cpp
@@ -0,0 +1,56 @@
1/**
2 * @file llbboxlocal.cpp
3 * @brief General purpose bounding box class (Not axis aligned).
4 *
5 * Copyright (c) 2001-2007, Linden Research, Inc.
6 *
7 * The source code in this file ("Source Code") is provided by Linden Lab
8 * to you under the terms of the GNU General Public License, version 2.0
9 * ("GPL"), unless you have obtained a separate licensing agreement
10 * ("Other License"), formally executed by you and Linden Lab. Terms of
11 * the GPL can be found in doc/GPL-license.txt in this distribution, or
12 * online at http://secondlife.com/developers/opensource/gplv2
13 *
14 * There are special exceptions to the terms and conditions of the GPL as
15 * it is applied to this Source Code. View the full text of the exception
16 * in the file doc/FLOSS-exception.txt in this software distribution, or
17 * online at http://secondlife.com/developers/opensource/flossexception
18 *
19 * By copying, modifying or distributing this software, you acknowledge
20 * that you have read and understood your obligations described above,
21 * and agree to abide by those obligations.
22 *
23 * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO
24 * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY,
25 * COMPLETENESS OR PERFORMANCE.
26 */
27
28#include "linden_common.h"
29
30#include "llbboxlocal.h"
31#include "m4math.h"
32
33void LLBBoxLocal::addPoint(const LLVector3& p)
34{
35 mMin.mV[VX] = llmin( p.mV[VX], mMin.mV[VX] );
36 mMin.mV[VY] = llmin( p.mV[VY], mMin.mV[VY] );
37 mMin.mV[VZ] = llmin( p.mV[VZ], mMin.mV[VZ] );
38 mMax.mV[VX] = llmax( p.mV[VX], mMax.mV[VX] );
39 mMax.mV[VY] = llmax( p.mV[VY], mMax.mV[VY] );
40 mMax.mV[VZ] = llmax( p.mV[VZ], mMax.mV[VZ] );
41}
42
43void LLBBoxLocal::expand( F32 delta )
44{
45 mMin.mV[VX] -= delta;
46 mMin.mV[VY] -= delta;
47 mMin.mV[VZ] -= delta;
48 mMax.mV[VX] += delta;
49 mMax.mV[VY] += delta;
50 mMax.mV[VZ] += delta;
51}
52
53LLBBoxLocal operator*(const LLBBoxLocal &a, const LLMatrix4 &b)
54{
55 return LLBBoxLocal( a.mMin * b, a.mMax * b );
56}