3 * Copyright (C) 2006-2007 Mathias Froehlich
5 * This program is free software; you can redistribute it and/or
6 * modify it under the terms of the GNU General Public License as
7 * published by the Free Software Foundation; either version 2 of the
8 * License, or (at your option) any later version.
10 * This program is distributed in the hope that it will be useful, but
11 * WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 * General Public License for more details.
15 * You should have received a copy of the GNU General Public License
16 * along with this program; if not, write to the Free Software
17 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
23 # include <simgear_config.h>
26 #include "SGEnlargeBoundingBox.hxx"
28 #include <osg/Drawable>
29 #include <osg/Version>
31 SGEnlargeBoundingBox::SGEnlargeBoundingBox(float offset) :
36 SGEnlargeBoundingBox::SGEnlargeBoundingBox(const SGEnlargeBoundingBox& cb,
37 const osg::CopyOp& copyOp) :
38 osg::Drawable::ComputeBoundingBoxCallback(cb, copyOp),
44 SGEnlargeBoundingBox::computeBound(const osg::Drawable& drawable) const
46 osg::BoundingBox bound =
47 #if OSG_VERSION_LESS_THAN(3,3,2)
48 drawable.computeBound();
50 drawable.computeBoundingBox();
55 return osg::BoundingBox(bound._min - osg::Vec3(_offset, _offset, _offset),
56 bound._max + osg::Vec3(_offset, _offset, _offset));