Panda3D
cullBinBackToFront.cxx
Go to the documentation of this file.
1 /**
2  * PANDA 3D SOFTWARE
3  * Copyright (c) Carnegie Mellon University. All rights reserved.
4  *
5  * All use of this software is subject to the terms of the revised BSD
6  * license. You should have received a copy of this license along
7  * with this source code in a file named "LICENSE."
8  *
9  * @file cullBinBackToFront.cxx
10  * @author drose
11  * @date 2002-02-28
12  */
13 
14 #include "cullBinBackToFront.h"
17 #include "cullableObject.h"
18 #include "cullHandler.h"
19 #include "pStatTimer.h"
20 
21 #include <algorithm>
22 
23 
24 TypeHandle CullBinBackToFront::_type_handle;
25 
26 /**
27  *
28  */
29 CullBinBackToFront::
30 ~CullBinBackToFront() {
31  Objects::iterator oi;
32  for (oi = _objects.begin(); oi != _objects.end(); ++oi) {
33  CullableObject *object = (*oi)._object;
34  delete object;
35  }
36 }
37 
38 /**
39  * Factory constructor for passing to the CullBinManager.
40  */
42 make_bin(const std::string &name, GraphicsStateGuardianBase *gsg,
43  const PStatCollector &draw_region_pcollector) {
44  return new CullBinBackToFront(name, gsg, draw_region_pcollector);
45 }
46 
47 /**
48  * Adds a geom, along with its associated state, to the bin for rendering.
49  */
51 add_object(CullableObject *object, Thread *current_thread) {
52  // Determine the center of the bounding volume.
53  CPT(BoundingVolume) volume = object->_geom->get_bounds(current_thread);
54  if (volume->is_empty()) {
55  delete object;
56  return;
57  }
58 
60  nassertv(gbv != nullptr);
61 
62  LPoint3 center = gbv->get_approx_center();
63  nassertv(object->_internal_transform != nullptr);
64  center = center * object->_internal_transform->get_mat();
65 
66  PN_stdfloat distance = _gsg->compute_distance_to(center);
67  _objects.push_back(ObjectData(object, distance));
68 }
69 
70 /**
71  * Called after all the geoms have been added, this indicates that the cull
72  * process is finished for this frame and gives the bins a chance to do any
73  * post-processing (like sorting) before moving on to draw.
74  */
76 finish_cull(SceneSetup *, Thread *current_thread) {
77  PStatTimer timer(_cull_this_pcollector, current_thread);
78  sort(_objects.begin(), _objects.end());
79 }
80 
81 /**
82  * Draws all the geoms in the bin, in the appropriate order.
83  */
85 draw(bool force, Thread *current_thread) {
86  PStatTimer timer(_draw_this_pcollector, current_thread);
87 
88  Objects::const_iterator oi;
89  for (oi = _objects.begin(); oi != _objects.end(); ++oi) {
90  CullableObject *object = (*oi)._object;
91 
92  if (object->_draw_callback == nullptr) {
93  nassertd(object->_geom != nullptr) continue;
94 
95  _gsg->set_state_and_transform(object->_state, object->_internal_transform);
96 
97  GeomPipelineReader geom_reader(object->_geom, current_thread);
98  GeomVertexDataPipelineReader data_reader(object->_munged_data, current_thread);
99  data_reader.check_array_readers();
100  geom_reader.draw(_gsg, &data_reader, force);
101  } else {
102  // It has a callback associated.
103  object->draw_callback(_gsg, force, current_thread);
104  // Now the callback has taken care of drawing.
105  }
106  }
107 }
108 
109 /**
110  * Called by CullBin::make_result_graph() to add all the geoms to the special
111  * cull result scene graph.
112  */
113 void CullBinBackToFront::
114 fill_result_graph(CullBin::ResultGraphBuilder &builder) {
115  Objects::const_iterator oi;
116  for (oi = _objects.begin(); oi != _objects.end(); ++oi) {
117  CullableObject *object = (*oi)._object;
118  builder.add_object(object);
119  }
120 }
virtual void finish_cull(SceneSetup *scene_setup, Thread *current_thread)
Called after all the geoms have been added, this indicates that the cull process is finished for this...
PANDA 3D SOFTWARE Copyright (c) Carnegie Mellon University.
virtual GeometricBoundingVolume * as_geometric_bounding_volume() final
Virtual downcast method.
PANDA 3D SOFTWARE Copyright (c) Carnegie Mellon University.
A collection of Geoms and their associated state, for a particular scene.
Definition: cullBin.h:40
PANDA 3D SOFTWARE Copyright (c) Carnegie Mellon University.
PANDA 3D SOFTWARE Copyright (c) Carnegie Mellon University.
A lightweight class that can be used to automatically start and stop a PStatCollector around a sectio...
Definition: pStatTimer.h:30
PANDA 3D SOFTWARE Copyright (c) Carnegie Mellon University.
Encapsulates the data from a Geom, pre-fetched for one stage of the pipeline.
Definition: geom.h:405
bool draw(GraphicsStateGuardianBase *gsg, const GeomVertexDataPipelineReader *data_reader, bool force) const
The implementation of Geom::draw().
Definition: geom.cxx:1849
This is an abstract class for any volume in any sense which can be said to define the locality of ref...
static CullBin * make_bin(const std::string &name, GraphicsStateGuardianBase *gsg, const PStatCollector &draw_region_pcollector)
Factory constructor for passing to the CullBinManager.
A lightweight class that represents a single element that may be timed and/or counted via stats.
This is another abstract class, for a general class of bounding volumes that actually enclose points ...
The smallest atom of cull.
A specific kind of CullBin that sorts geometry in order from furthest to nearest based on the center ...
PANDA 3D SOFTWARE Copyright (c) Carnegie Mellon University.
virtual void draw(bool force, Thread *current_thread)
Draws all the geoms in the bin, in the appropriate order.
This is a base class for the GraphicsStateGuardian class, which is itself a base class for the variou...
A thread; that is, a lightweight process.
Definition: thread.h:46
Encapsulates the data from a GeomVertexData, pre-fetched for one stage of the pipeline.
TypeHandle is the identifier used to differentiate C++ class types.
Definition: typeHandle.h:81
This object holds the camera position, etc., and other general setup information for rendering a part...
Definition: sceneSetup.h:32
virtual void add_object(CullableObject *object, Thread *current_thread)
Adds a geom, along with its associated state, to the bin for rendering.