OpenSceneGraph 3.6.5
SectorPlacer
Go to the documentation of this file.
1/* -*-c++-*- OpenSceneGraph - Copyright (C) 1998-2006 Robert Osfield
2 *
3 * This library is open source and may be redistributed and/or modified under
4 * the terms of the OpenSceneGraph Public License (OSGPL) version 0.0 or
5 * (at your option) any later version. The full license is in LICENSE file
6 * included with this distribution, and on the openscenegraph.org website.
7 *
8 * This library is distributed in the hope that it will be useful,
9 * but WITHOUT ANY WARRANTY; without even the implied warranty of
10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 * OpenSceneGraph Public License for more details.
12*/
13//osgParticle - Copyright (C) 2002 Marco Jez
14
15#ifndef OSGPARTICLE_SECTOR_PLACER
16#define OSGPARTICLE_SECTOR_PLACER 1
17
19#include <osgParticle/Particle>
20#include <osgParticle/range>
21
22#include <osg/CopyOp>
23#include <osg/Object>
24#include <osg/Vec3>
25#include <osg/Math>
26
27namespace osgParticle
28{
29
37 public:
38 inline SectorPlacer();
39 inline SectorPlacer(const SectorPlacer& copy, const osg::CopyOp& copyop = osg::CopyOp::SHALLOW_COPY);
40
42 inline const rangef& getRadiusRange() const;
43
45 inline void setRadiusRange(const rangef& r);
46
48 inline void setRadiusRange(float r1, float r2);
49
51 inline const rangef& getPhiRange() const;
52
54 inline void setPhiRange(const rangef& r);
55
57 inline void setPhiRange(float r1, float r2);
58
60
62 inline void place(Particle* P) const;
63
65 inline float volume() const;
66
68 inline osg::Vec3 getControlPosition() const;
69
70 protected:
71 virtual ~SectorPlacer() {}
72 SectorPlacer& operator=(const SectorPlacer&) { return *this; }
73
74 private:
75 rangef _rad_range;
76 rangef _phi_range;
77 };
78
79 // INLINE FUNCTIONS
80
82 : CenteredPlacer(), _rad_range(0, 1), _phi_range(0, osg::PI*2)
83 {
84 }
85
86 inline SectorPlacer::SectorPlacer(const SectorPlacer& copy, const osg::CopyOp& copyop)
87 : CenteredPlacer(copy, copyop), _rad_range(copy._rad_range), _phi_range(copy._phi_range)
88 {
89 }
90
92 {
93 return _rad_range;
94 }
95
96 inline const rangef& SectorPlacer::getPhiRange() const
97 {
98 return _phi_range;
99 }
100
102 {
103 _rad_range = r;
104 }
105
106 inline void SectorPlacer::setRadiusRange(float r1, float r2)
107 {
108 _rad_range.minimum = r1;
109 _rad_range.maximum = r2;
110 }
111
112 inline void SectorPlacer::setPhiRange(const rangef& r)
113 {
114 _phi_range = r;
115 }
116
117 inline void SectorPlacer::setPhiRange(float r1, float r2)
118 {
119 _phi_range.minimum = r1;
120 _phi_range.maximum = r2;
121 }
122
123 inline void SectorPlacer::place(Particle* P) const
124 {
125 float rad = _rad_range.get_random_sqrtf();
126 float phi = _phi_range.get_random();
127
128 osg::Vec3 pos(
129 getCenter().x() + rad * cosf(phi),
130 getCenter().y() + rad * sinf(phi),
131 getCenter().z());
132
133 P->setPosition(pos);
134 }
135
136 inline float SectorPlacer::volume() const
137 {
138 return 0.5f * (_phi_range.maximum - _phi_range.minimum) *
139 (_rad_range.maximum*_rad_range.maximum - _rad_range.minimum*_rad_range.minimum);
140 }
141
143 {
144 return getCenter();
145 }
146
147}
148
149#endif
The core osg library provides the basic scene graph classes such as Nodes, State and Drawables,...
Definition AlphaFunc:19
Vec3f Vec3
Definition Vec3:21
The osgParticle library is a NodeKit that extends the core scene graph to support particle effects.
Definition AccelOperator:27
range< float > rangef
Range of floats.
Definition range:76
Copy Op(erator) used to control whether shallow or deep copy is used during copy construction and clo...
Definition CopyOp:41
@ SHALLOW_COPY
Definition CopyOp:47
CenteredPlacer()
Definition CenteredPlacer:56
const osg::Vec3 & getCenter() const
Get the center point.
Definition CenteredPlacer:66
Implementation of a particle.
Definition Particle:47
void setPosition(const osg::Vec3 &p)
Set the position vector.
Definition Particle:483
ValueType minimum
Lower bound.
Definition range:42
virtual ~SectorPlacer()
Definition SectorPlacer:71
const rangef & getRadiusRange() const
Get the range of possible values for radius.
Definition SectorPlacer:91
void setPhiRange(const rangef &r)
Set the range of possible values for the central angle.
Definition SectorPlacer:112
void place(Particle *P) const
Place a particle. Do not call it manually.
Definition SectorPlacer:123
META_Object(osgParticle, SectorPlacer)
SectorPlacer()
Definition SectorPlacer:81
float volume() const
return the area of the sector
Definition SectorPlacer:136
SectorPlacer & operator=(const SectorPlacer &)
Definition SectorPlacer:72
osg::Vec3 getControlPosition() const
return the control position
Definition SectorPlacer:142
const rangef & getPhiRange() const
Get the range of possible values for the central angle.
Definition SectorPlacer:96
void setRadiusRange(const rangef &r)
Set the range of possible values for radius.
Definition SectorPlacer:101

osg logo
Generated at Sun Jul 27 2025 00:00:00 for the OpenSceneGraph by doxygen 1.14.0.