118 lines
3.3 KiB
C++
118 lines
3.3 KiB
C++
|
|
// -*- C++ -*-
|
|
|
|
|
|
namespace Hurricane {
|
|
|
|
/*! \class Slice
|
|
* \brief Slice description (\b API)
|
|
*
|
|
* \section secSliceIntro Introduction
|
|
*
|
|
* The slices are objects which split the layout description of
|
|
* a cell into horizontal slices grouping all objects located on
|
|
* a given layer and storing them into a fast geometrical access
|
|
* structure implemented by a quadtree.
|
|
*
|
|
*
|
|
* \section secSliceConstructionAndDestruction Construction and destruction
|
|
*
|
|
* The slices are fully managed by the cells : they are neither
|
|
* created nor destroyed by the application programmer.
|
|
*
|
|
* Components are inserted in a slice (at their creation) and
|
|
* removed from their slice (at their deletion).
|
|
*
|
|
* Empty slices being automatically deleted, you must never
|
|
* store pointers to them.
|
|
*
|
|
*
|
|
* \section secSliceExample Example
|
|
*
|
|
* The following example shows how to visit all cell components
|
|
* lying on a given basic layer and whose bounding box
|
|
* intersects some rectangular area.
|
|
\code
|
|
Cell* cell = ...; // we get the cell
|
|
|
|
BasicLayer* basicLayer = ...; // we get the basic layer
|
|
|
|
Box area = ...; // we define the rectangular area
|
|
|
|
for_each_slice(slice, cell->getSlices()) {
|
|
if (slice->getLayer()->Contains(basicLayer)) {
|
|
for_each_componant(component, slice->getComponentsUnder(area)) {
|
|
...
|
|
// here we visit all requested components
|
|
...
|
|
end_for;
|
|
}
|
|
}
|
|
end_for;
|
|
}
|
|
\endcode
|
|
*/
|
|
|
|
|
|
|
|
/*! \name Accessors
|
|
*/
|
|
// \{
|
|
|
|
/*! \function Cell* Slice::getCell() const;
|
|
* \Return the cell owning the slice.
|
|
*/
|
|
|
|
/*! \function Layer* Slice::getLayer() const;
|
|
* \Return the layer associated to the slice : all components lying in a
|
|
* cell are perforce located on that layer.
|
|
*/
|
|
|
|
/*! \function Box Slice::getBoundingBox() const;
|
|
* \Return the bounding box of the slice, that is the smallest enclosing
|
|
* rectangle of all its components.
|
|
*/
|
|
|
|
/*! \function const Gos Slice::getGos() const;
|
|
* \Return the collection of graphic objects lying on the slice.
|
|
*/
|
|
|
|
/*! \function const Components Slice::getComponents() const;
|
|
* \Return the collection of components lying on the slice.
|
|
*/
|
|
|
|
/*! \function const Components Slice::getComponentsUnder(const Box& area) const;
|
|
* \Return the collection of components of the slice whose bounding box
|
|
* intersects the rectangular region defined by \c \<area\>.
|
|
*/
|
|
|
|
// \}
|
|
|
|
|
|
|
|
/*! \name Slice Collection
|
|
*/
|
|
// \{
|
|
|
|
/*! \typedef Slices
|
|
* Collection representing a set of slices.
|
|
*/
|
|
|
|
/*! \typedef SliceLocator
|
|
* Locator for traversing a collection of slices.
|
|
*/
|
|
|
|
/*! \typedef SliceFilter
|
|
* Filter for selecting a subset of slices which match a given
|
|
* criteria.
|
|
*/
|
|
|
|
/*! \def for_each_slice(slice, slices)
|
|
* Macro for visiting the slices of a slice collection.
|
|
*/
|
|
|
|
// \}
|
|
|
|
|
|
}
|