CUGL 2.5
Cornell University Game Library
|
#include <CUWireNode.h>
Public Member Functions | |
WireNode () | |
~WireNode () | |
bool | initWithPoly (const Poly2 &poly) |
bool | initWithPoly (const Rect rect) |
bool | initWithPath (const Path2 &path) |
bool | initWithPath (const Rect rect) |
bool | initWithPath (const std::vector< Vec2 > &vertices) |
bool | initWithTraversal (const Poly2 &poly, poly2::Traversal traversal) |
bool | initWithTraversal (const std::vector< Vec2 > &vertices, const std::vector< Uint32 > &indices) |
bool | initWithTraversal (Vec2 *vertices, size_t vsize, Uint32 *indices, size_t isize) |
bool | initWithData (const Scene2Loader *loader, const std::shared_ptr< JsonValue > &data) override |
virtual std::shared_ptr< SceneNode > | copy (const std::shared_ptr< SceneNode > &dst) const override |
void | setPolygon (const Poly2 &poly) |
const Poly2 & | getPolygon () const |
void | setPolygon (const Rect rect) |
void | setPath (const Path2 &path) |
void | setPath (const Rect rect) |
void | setPath (const std::vector< Vec2 > &vertices) |
void | setTraversal (poly2::Traversal traversal) |
void | setTraversal (const std::vector< Uint32 > &indices) |
void | setTraversal (Uint32 *indices, size_t isize) |
poly2::Traversal | getTraversal () const |
const std::vector< Vec2 > & | getVertices () const |
const std::vector< Uint32 > & | getIndices () const |
virtual void | draw (const std::shared_ptr< SpriteBatch > &batch, const Affine2 &transform, Color4 tint) override |
Public Member Functions inherited from cugl::scene2::TexturedNode | |
TexturedNode () | |
~TexturedNode () | |
virtual void | dispose () override |
virtual bool | init () override |
virtual bool | initWithFile (const std::string filename) |
virtual bool | initWithTexture (const std::shared_ptr< Texture > &texture) |
virtual bool | initWithData (const Scene2Loader *loader, const std::shared_ptr< JsonValue > &data) override |
virtual std::shared_ptr< SceneNode > | copy (const std::shared_ptr< SceneNode > &dst) const override |
void | setTexture (const std::string &filename) |
void | setTexture (const std::shared_ptr< Texture > &texture) |
std::shared_ptr< Texture > & | getTexture () |
const std::shared_ptr< Texture > & | getTexture () const |
const std::shared_ptr< Gradient > & | getGradient () const |
void | setGradient (const std::shared_ptr< Gradient > &gradient) |
void | shiftTexture (float dx, float dy) |
void | setBlendFunc (GLenum srcFactor, GLenum dstFactor) |
GLenum | getSourceBlendFactor () const |
GLenum | getDestinationBlendFactor () const |
void | setBlendEquation (GLenum equation) |
GLenum | getBlendEquation () const |
void | flipHorizontal (bool flag) |
bool | isFlipHorizontal () const |
void | flipVertical (bool flag) |
bool | isFlipVertical () const |
virtual std::string | toString (bool verbose=false) const override |
bool | isAbsolute () const |
void | setAbsolute (bool flag) |
virtual void | setAnchor (const Vec2 anchor) override |
virtual void | setAnchor (float x, float y) override |
virtual void | setContentSize (const Size size) override |
virtual void | setContentSize (float width, float height) override |
virtual void | draw (const std::shared_ptr< SpriteBatch > &batch, const Affine2 &transform, Color4 tint) override=0 |
void | refresh () |
Public Member Functions inherited from cugl::scene2::SceneNode | |
SceneNode () | |
~SceneNode () | |
virtual void | dispose () |
virtual bool | init () |
virtual bool | initWithPosition (const Vec2 pos) |
bool | initWithPosition (float x, float y) |
virtual bool | initWithBounds (const Size size) |
virtual bool | initWithBounds (float width, float height) |
virtual bool | initWithBounds (const Rect rect) |
virtual bool | initWithBounds (float x, float y, float width, float height) |
virtual bool | initWithData (const Scene2Loader *loader, const std::shared_ptr< JsonValue > &data) |
virtual std::shared_ptr< SceneNode > | copy (const std::shared_ptr< SceneNode > &dst) const |
unsigned int | getTag () const |
void | setTag (unsigned int tag) |
const std::string | getName () const |
void | setName (const std::string name) |
const std::string | getClassName () const |
virtual std::string | toString (bool verbose=false) const |
operator std::string () const | |
const Vec2 | getPosition () const |
void | setPosition (const Vec2 &position) |
void | setPosition (float x, float y) |
float | getPositionX (void) const |
void | setPositionX (float x) |
float | getPositionY (void) const |
void | setPositionY (float y) |
Vec2 | getWorldPosition () const |
const Size | getContentSize () const |
virtual void | setContentSize (const Size size) |
virtual void | setContentSize (float width, float height) |
float | getContentWidth () const |
void | setContentWidth (float width) |
float | getContentHeight () const |
void | setContentHeight (float height) |
virtual Rect | getLayoutBounds () const |
Size | getSize () const |
float | getWidth () const |
float | getHeight () const |
Rect | getBoundingBox () const |
virtual bool | inContentBounds (const Vec2 point) |
bool | inContentBounds (float x, float y) |
virtual void | setAnchor (const Vec2 anchor) |
virtual void | setAnchor (float x, float y) |
const Vec2 | getAnchor () const |
Vec2 | getAnchorInPixels () |
Color4 | getColor () const |
virtual void | setColor (Color4 color) |
Color4 | getAbsoluteColor () |
bool | isVisible () const |
void | setVisible (bool visible) |
bool | hasRelativeColor () const |
void | setRelativeColor (bool flag) |
std::shared_ptr< Scissor > | getScissor () const |
void | setScissor (const std::shared_ptr< Scissor > &scissor) |
void | setScissor () |
const Vec2 | getScale () const |
float | getScaleX () const |
float | getScaleY () const |
void | setScale (float scale) |
void | setScale (const Vec2 vec) |
void | setScale (float sx, float sy) |
float | getAngle () |
void | setAngle (float angle) |
const Affine2 & | getTransform () const |
const Affine2 & | getAlternateTransform () const |
void | setAlternateTransform (const Affine2 &transform) |
bool | withAlternateTransform () |
void | chooseAlternateTransform (bool active) |
const Affine2 & | getNodeToParentTransform () const |
Affine2 | getParentToNodeTransform () const |
virtual Affine2 | getNodeToWorldTransform () const |
Affine2 | getWorldToNodeTransform () const |
Vec2 | screenToNodeCoords (const Vec2 screenPoint) const |
Vec2 | worldToNodeCoords (const Vec2 worldPoint) const |
Vec2 | nodeToScreenCoords (const Vec2 nodePoint) const |
Vec2 | nodeToWorldCoords (const Vec2 nodePoint) const |
Vec2 | parentToNodeCoords (const Vec2 parentPoint) const |
Vec2 | nodeToParentCoords (const Vec2 nodePoint) const |
size_t | getChildCount () const |
std::shared_ptr< SceneNode > | getChild (unsigned int pos) |
const std::shared_ptr< SceneNode > & | getChild (unsigned int pos) const |
template<typename T > | |
std::shared_ptr< T > | getChild (unsigned int pos) const |
std::shared_ptr< SceneNode > | getChildByTag (unsigned int tag) const |
template<typename T > | |
std::shared_ptr< T > | getChildByTag (unsigned int tag) const |
std::shared_ptr< SceneNode > | getChildByName (const std::string name) const |
template<typename T > | |
std::shared_ptr< T > | getChildByName (const std::string name) const |
std::vector< std::shared_ptr< SceneNode > > | getChildren () |
const std::vector< std::shared_ptr< SceneNode > > & | getChildren () const |
void | addChild (const std::shared_ptr< SceneNode > &child) |
void | addChildWithTag (const std::shared_ptr< SceneNode > &child, unsigned int tag) |
void | addChildWithName (const std::shared_ptr< SceneNode > &child, const std::string name) |
void | swapChild (const std::shared_ptr< SceneNode > &child1, const std::shared_ptr< SceneNode > &child2, bool inherit=false) |
SceneNode * | getParent () |
const SceneNode * | getParent () const |
Scene2 * | getScene () |
const Scene2 * | getScene () const |
void | removeFromParent () |
virtual void | removeChild (unsigned int pos) |
void | removeChild (const std::shared_ptr< SceneNode > &child) |
void | removeChildByTag (unsigned int tag) |
void | removeChildByName (const std::string name) |
virtual void | removeAllChildren () |
void | setPriority (float priority) |
float | getPriority () |
virtual void | render (const std::shared_ptr< SpriteBatch > &batch, const Affine2 &transform, Color4 tint) |
virtual void | render (const std::shared_ptr< SpriteBatch > &batch) |
virtual void | draw (const std::shared_ptr< SpriteBatch > &batch, const Affine2 &transform, Color4 tint) |
const std::shared_ptr< Layout > & | getLayout () const |
void | setLayout (const std::shared_ptr< Layout > &layout) |
virtual void | doLayout () |
Static Public Member Functions | |
static std::shared_ptr< WireNode > | alloc () |
static std::shared_ptr< WireNode > | allocWithPoly (const Poly2 &poly) |
static std::shared_ptr< WireNode > | allocWithPoly (const Rect rect) |
static std::shared_ptr< WireNode > | allocWithPath (const Path2 &path) |
static std::shared_ptr< WireNode > | allocWithPath (const Rect rect) |
static std::shared_ptr< WireNode > | allocWithPath (const std::vector< Vec2 > &vertices) |
static std::shared_ptr< WireNode > | allocWithTraversal (const Poly2 &poly, poly2::Traversal traversal) |
static std::shared_ptr< WireNode > | allocWithTraversal (const std::vector< Vec2 > &vertices, const std::vector< Uint32 > &indices) |
static std::shared_ptr< WireNode > | allocWithTraversal (Vec2 *vertices, size_t vsize, Uint32 *indices, size_t isize) |
static std::shared_ptr< SceneNode > | allocWithData (const Scene2Loader *loader, const std::shared_ptr< JsonValue > &data) |
Static Public Member Functions inherited from cugl::scene2::SceneNode | |
static std::shared_ptr< SceneNode > | alloc () |
static std::shared_ptr< SceneNode > | allocWithPosition (const Vec2 pos) |
static std::shared_ptr< SceneNode > | allocWithPosition (float x, float y) |
static std::shared_ptr< SceneNode > | allocWithBounds (const Size size) |
static std::shared_ptr< SceneNode > | allocWithBounds (float width, float height) |
static std::shared_ptr< SceneNode > | allocWithBounds (const Rect rect) |
static std::shared_ptr< SceneNode > | allocWithBounds (float x, float y, float width, float height) |
static std::shared_ptr< SceneNode > | allocWithData (const Scene2Loader *loader, const std::shared_ptr< JsonValue > &data) |
Protected Attributes | |
Poly2 | _polygon |
std::vector< Uint32 > | _indices |
poly2::Traversal | _traversal |
Protected Attributes inherited from cugl::scene2::TexturedNode | |
std::shared_ptr< Texture > | _texture |
std::shared_ptr< Gradient > | _gradient |
bool | _absolute |
Vec2 | _offset |
bool | _rendered |
Mesh< SpriteVertex2 > | _mesh |
GLenum | _blendEquation |
GLenum | _srcFactor |
GLenum | _dstFactor |
bool | _flipHorizontal |
bool | _flipVertical |
Protected Attributes inherited from cugl::scene2::SceneNode | |
Vec2 | _position |
Vec2 | _anchor |
Size | _contentSize |
Color4 | _tintColor |
bool | _hasParentColor |
bool | _isVisible |
std::shared_ptr< Scissor > | _scissor |
Vec2 | _scale |
float | _angle |
Affine2 | _transform |
bool | _useTransform |
Affine2 | _combined |
std::vector< std::shared_ptr< SceneNode > > | _children |
SceneNode * | _parent |
Scene2 * | _graph |
std::shared_ptr< Layout > | _layout |
int | _childOffset |
unsigned int | _tag |
std::string | _name |
size_t | _hashOfName |
std::string | _classname |
float | _priority |
std::shared_ptr< JsonValue > | _json |
Additional Inherited Members | |
Protected Member Functions inherited from cugl::scene2::TexturedNode | |
virtual void | generateRenderData ()=0 |
virtual void | updateTextureCoords ()=0 |
virtual void | clearRenderData () |
CU_DISALLOW_COPY_AND_ASSIGN (TexturedNode) | |
This is a scene graph node to represent a wireframe
The wireframes are lines, but they can still be textured. However, generally you will only want to create a wireframe with the degenerate texture (to draw a solid, colored line). Hence, none of the static constructors take a texture. You are free to update the texture after creation, if you wish.
The node shape is stored as polygon. The wireframe shape is determined by the polygon traversal. There are three options, defined in poly2::Traversal
.
OPEN: The traversal is in order, but does not close the ends. CLOSED: The traversal is in order, and closes the ends. INTERIOR: The traverse will outline the default triangulation.
The default is traversal is CLOSED.
The wireframe can be textured (as lines can be textured). The wireframe is specified in image coordinates. Image coordinates are different from texture coordinates. Their origin is at the bottom-left corner of the file, and each pixel is one unit. This makes specifying to polygon more natural for irregular shapes.
This means that a wireframe with vertices (0,0), (width,0), (width,height), and (0,height) would be the border of a sprite node. However, a wireframe with vertices (0,0), (2*width,0), (2*width,2*height), and (0,2*height) would tile the sprite texture (given the wrap settings) twice both horizontally and vertically.
The content size of this node is defined by the size (but not the offset) of the bounding box. The anchor point is relative to this content size. The default anchor point in a TexturedNode is (0.5, 0.5). This means that a uniform translation of the polygon (in contrast to the node itself) will not move the shape on the the screen. Instead, it will just change the part of the texture it uses.
For example, suppose the texture has given width and height. We have one polygon with vertices (0,0), (width/2,0), (width/2,height/2), and (0,height/2). We have another polygon with vertices (width/2,height/2), (width,height/2), (width,height), and (width/2,height). Both polygons would create a rectangle of size (width/2,height/2). centered at the node position. However, the first would use the bottom left part of the texture, while the second would use the top right.
You can disable these features at any time by setting the attribute absolute to true. Do this will place the polygon vertices in their absolute positions in Node space. This will also disable anchor functions (setting the anchor as the bottom left corner), since anchors do not make sense when we are drawing vertices directly into the coordinate space.
|
inline |
Creates an empty wire frame with the degenerate texture.
You must initialize this WireNode before use.
NEVER USE A CONSTRUCTOR WITH NEW. If you want to allocate an object on the heap, use one of the static constructors instead.
|
inline |
Releases all resources allocated with this node.
This will release, but not necessarily delete the associated texture. However, the polygon and drawing commands will be deleted and no longer safe to use.
|
inlinestatic |
Returns an empty wire frame.
The underlying polygon is empty, and must be set via setPolygon.
|
inlinestatic |
Returns a newly allocated wire frame with the given JSON specificaton.
This initializer is designed to receive the "data" object from the JSON passed to Scene2Loader
. This JSON format supports all of the attribute values of its parent class. In addition, it supports the following additional attributes:
"traversal": One of 'none', 'open', 'closed', or 'interior' "polygon": A JSON object defining a polygon. See {@link Poly2}. "wireframe": An even array of numbers defining the wireframe indices.
All attributes are optional. If the polygon is not specified, the node will use a rectangle with the dimensions of the texture. For more information, see TexturedNode#initWithData
.
If you do specify the wire frame, the traversal algorithm will be ignored. If both the wireframe and the traversal algorithm are omitted, this will perform an INTERIOR traversal on the polygon.
loader | The scene loader passing this JSON file |
data | The JSON object specifying the node |
|
inlinestatic |
Returns a newly allocated wire frame with the given path.
This wireframe will perform a traversal of the path. The traversal will either be OPEN or CLOSED depending upon the properties of the path.
You do not need to set the texture; rendering this into a SpriteBatch will simply use the blank texture. Hence the wireframe will have a solid color.
path | The path to traverse |
|
inlinestatic |
Returns a newly allocated wire frame with the given rectangle (outline).
This wireframe will perform a CLOSED traversal of the rectangle.
You do not need to set the texture; rendering this into a SpriteBatch will simply use the blank texture. Hence the wireframe will have a solid color.
rect | The rectangle to traverse |
|
inlinestatic |
Returns a newly allocated wire frame with the given path.
This wireframe will perform a CLOSED traversal of the given path.
You do not need to set the texture; rendering this into a SpriteBatch will simply use the blank texture. Hence the wireframe will have a solid color.
vertices | The path to traverse |
|
inlinestatic |
Returns a newly allocated wire frame with the given polygon.
This wireframe will perform an INTERIOR traversal of the given polygon. This assumes that the polygon has been triangulated previously.
You do not need to set the texture; rendering this into a SpriteBatch will simply use the blank texture. Hence the wireframe will have a solid color.
poly | The polygon to traverse |
|
inlinestatic |
Returns a newly allocated wire frame with the given (solid) rectangle.
This wireframe will perform an INTERIOR traversal of the standard triangulation of this rectangle.
You do not need to set the texture; rendering this into a SpriteBatch will simply use the blank texture. Hence the wireframe will have a solid color.
rect | The rectangle to traverse |
|
inlinestatic |
Returns a newly allocated wire frame with the given polygon and traversal.
The provided polygon will be used as the source for the traversal. The traversal will be defined exactly as the one provided by PathFactory#makeTraversal
.
You do not need to set the texture; rendering this into a SpriteBatch will simply use the blank texture. Hence the wireframe will have a solid color.
poly | The triangulated polygon |
traversal | The path traversal for index generation |
|
inlinestatic |
Returns a newly allocated wire frame with the given vertices and indices
This initializer will set the given vertices to of the polygon to be the one specified. However, it will not triangulate the polygon, or attempt to traverse it. Instead, it will use the provided indices as the final traversal. Hence this is a way of creating a custom traversal. To work properly, the indices should have an even number of elements and define a sequence of line segments.
You do not need to set the texture; rendering this into a SpriteBatch will simply use the blank texture. Hence the wireframe will have a solid color.
vertices | The vertices to texture (expressed in image space) |
indices | The traversal indices |
|
inlinestatic |
Returns a newly allocated wire frame with the given vertices and indices
This initializer will set the given vertices to of the polygon to be the one specified. However, it will not triangulate the polygon, or attempt to traverse it. Instead, it will use the provided indices as the final traversal. Hence this is a way of creating a custom traversal. To work properly, the indices should have an even number of elements and define a sequence of line segments.
You do not need to set the texture; rendering this into a SpriteBatch will simply use the blank texture. Hence the wireframe will have a solid color.
vertices | The vertices to texture (expressed in image space) |
vsize | The number of vertices |
indices | The traversal indices |
isize | The number of indices |
|
overridevirtual |
Performs a shallow copy of this Node into dst.
No children from this node are copied, and no children of dst are modified. In addition, the parents of both Nodes are unchanged. However, all other attributes of this node are copied.
dst | The Node to copy into |
Reimplemented from cugl::scene2::TexturedNode.
|
overridevirtual |
Draws this wireframe via the given SpriteBatch.
This method only worries about drawing the current node. It does not attempt to render the children.
batch | The SpriteBatch to draw with. |
transform | The global transformation matrix. |
tint | The tint to blend with the Node color. |
Implements cugl::scene2::TexturedNode.
|
inline |
Returns the traversal indices of this wire frame.
|
inline |
Returns the wire frame polygon.
The provided polygon will be used as the source for the traversal. The polygon itself may or may not have any indices, as the polygon indices are not the same as the traversal indices.
The polygon is specified in image coordinates. The origin is at the bottom-left corner of the image, and each pixel is one unit. If no texture is specified, this node will draw the wire frame with a solid color.
|
inline |
Returns the current traversal algorithm of this path.
If the traversal was defined by a custom set of indices, this method returns NONE.
|
inline |
Returns the current vertices of this wire frame.
|
overridevirtual |
Initializes a wire frame with the given JSON specificaton.
This initializer is designed to receive the "data" object from the JSON passed to Scene2Loader
. This JSON format supports all of the attribute values of its parent class. In addition, it supports the following additional attributes:
"traversal": One of 'none', 'open', 'closed', or 'interior' "polygon": A JSON object defining a polygon. See {@link Poly2}. "wireframe": An even array of numbers defining the wireframe indices.
All attributes are optional. If the polygon is not specified, the node will use a rectangle with the dimensions of the texture. For more information, see TexturedNode#initWithData
.
If you do specify the wire frame, the traversal algorithm will be ignored. If both the wireframe and the traversal algorithm are omitted, this will perform an INTERIOR traversal on the polygon.
loader | The scene loader passing this JSON file |
data | The JSON object specifying the node |
Reimplemented from cugl::scene2::TexturedNode.
bool cugl::scene2::WireNode::initWithPath | ( | const Path2 & | path | ) |
Initializes a wire frame with the given path.
This wireframe will perform a traversal of the path. The traversal will either be OPEN or CLOSED depending upon the properties of the path.
You do not need to set the texture; rendering this into a SpriteBatch will simply use the blank texture. Hence the wireframe will have a solid color.
path | The path to traverse |
bool cugl::scene2::WireNode::initWithPath | ( | const Rect | rect | ) |
Initializes a wire frame with the given rectangle (outline).
This wireframe will perform a CLOSED traversal of the rectangle.
You do not need to set the texture; rendering this into a SpriteBatch will simply use the blank texture. Hence the wireframe will have a solid color.
rect | The rectangle to traverse |
bool cugl::scene2::WireNode::initWithPath | ( | const std::vector< Vec2 > & | vertices | ) |
Initializes a wire frame with the given path.
This wireframe will perform a CLOSED traversal of the given path.
You do not need to set the texture; rendering this into a SpriteBatch will simply use the blank texture. Hence the wireframe will have a solid color.
vertices | The path to traverse |
bool cugl::scene2::WireNode::initWithPoly | ( | const Poly2 & | poly | ) |
Initializes a wire frame with the given polygon.
This wireframe will perform an INTERIOR traversal of the given polygon. This assumes that the polygon has been triangulated previously.
You do not need to set the texture; rendering this into a SpriteBatch will simply use the blank texture. Hence the wireframe will have a solid color.
poly | The polygon to traverse |
bool cugl::scene2::WireNode::initWithPoly | ( | const Rect | rect | ) |
Initializes a wire frame with the given (solid) rectangle.
This wireframe will perform an INTERIOR traversal of the standard triangulation of this rectangle.
You do not need to set the texture; rendering this into a SpriteBatch will simply use the blank texture. Hence the wireframe will have a solid color.
rect | The rectangle to traverse |
bool cugl::scene2::WireNode::initWithTraversal | ( | const Poly2 & | poly, |
poly2::Traversal | traversal | ||
) |
Intializes a wire frame with the given polygon and traversal
The provided polygon will be used as the source for the traversal. The traversal will be applied to the vertices (and potentially indices) of thei polygon.
You do not need to set the texture; rendering this into a SpriteBatch will simply use the blank texture. Hence the wireframe will have a solid color.
poly | The triangulated polygon |
traversal | The path traversal for index generation |
bool cugl::scene2::WireNode::initWithTraversal | ( | const std::vector< Vec2 > & | vertices, |
const std::vector< Uint32 > & | indices | ||
) |
Intializes a wire frame with the given vertices and indices
This initializer will set the given vertices to of the polygon to be the one specified. However, it will not triangulate the polygon, or attempt to traverse it. Instead, it will use the provided indices as the final traversal. Hence this is a way of creating a custom traversal. To work properly, the indices should have an even number of elements and define a sequence of line segments.
You do not need to set the texture; rendering this into a SpriteBatch will simply use the blank texture. Hence the wireframe will have a solid color.
vertices | The vertices to texture (expressed in image space) |
indices | The traversal indices |
bool cugl::scene2::WireNode::initWithTraversal | ( | Vec2 * | vertices, |
size_t | vsize, | ||
Uint32 * | indices, | ||
size_t | isize | ||
) |
Intializes a wire frame with the given vertices and indices
This initializer will set the given vertices to of the polygon to be the one specified. However, it will not triangulate the polygon, or attempt to traverse it. Instead, it will use the provided indices as the final traversal. Hence this is a way of creating a custom traversal. To work properly, the indices should have an even number of elements and define a sequence of line segments.
You do not need to set the texture; rendering this into a SpriteBatch will simply use the blank texture. Hence the wireframe will have a solid color.
vertices | The vertices to texture (expressed in image space) |
vsize | The number of vertices |
indices | The traversal indices |
isize | The number of indices |
void cugl::scene2::WireNode::setPath | ( | const Path2 & | path | ) |
Sets the wire frame polygon to the given path.
The resulting polygon will not have an triangulation vertices, so any INTERIOR travesal will fail (generate no indices). However, any other traversal will work normally. In addition, setting this value will change the traversal algorithm to either OPEN or CLOSED, depending on the nature of the path.
The path is specified in image coordinates. The origin is at the bottom-left corner of the image, and each pixel is one unit. If no texture is specified, this node will draw the wire frame with a solid color.
path | The wire frame path |
void cugl::scene2::WireNode::setPath | ( | const Rect | rect | ) |
Sets the wire frame polygon to the given rect (outline).
The resulting polygon will not have an triangulation vertices, so any INTERIOR travesal will fail (generate no indices). However, any other traversal will work normally. In addition, setting this value will change the traversal algorithm to CLOSED.
The rectangle is specified in image coordinates. The origin is at the bottom-left corner of the image, and each pixel is one unit. If no texture is specified, this node will draw the wire frame with a solid color.
rect | The wire frame rectangle |
void cugl::scene2::WireNode::setPath | ( | const std::vector< Vec2 > & | vertices | ) |
Sets the wire frame polygon to the given path.
The resulting polygon will not have an triangulation vertices, so any INTERIOR travesal will fail (generate no indices). However, any other traversal will work normally.
The path is specified in image coordinates. The origin is at the bottom-left corner of the image, and each pixel is one unit. If no texture is specified, this node will draw the wire frame with a solid color.
vertices | The wire frame path |
void cugl::scene2::WireNode::setPolygon | ( | const Poly2 & | poly | ) |
Sets the wire frame polygon to the given one.
The provided polygon will be used as the source for the traversal. If the traversal algorithm is not NONE, setting this value will generate a new set of traversal indices.
The polygon is specified in image coordinates. The origin is at the bottom-left corner of the image, and each pixel is one unit. If no texture is specified, this node will draw the wire frame with a solid color.
It is not necessary for this polygon to be triangulated (e.g. have indices). A triangulation is only necessary for an INTERIOR traversal.
poly | The wire frame polygon |
void cugl::scene2::WireNode::setPolygon | ( | const Rect | rect | ) |
Sets the wire frame polygon to the given (solid) rect.
The rectangle will be converted into a Poly2, with the traditional two-element triagulation. If the traversal algorithm is not NONE, setting this value will generate a new set of traversal indices. traversal method.
The rectangle is specified in image coordinates. The origin is at the bottom-left corner of the image, and each pixel is one unit. If no texture is specified, this node will draw the wire frame with a solid color.
rect | The wire frame rectangle |
void cugl::scene2::WireNode::setTraversal | ( | const std::vector< Uint32 > & | indices | ) |
Sets the traversal indices of this path.
The indices are a manual traversal of the underlying polygon. The argument should contain an even number of indices, defining a sequence of line segments. In addition, the indices should all represent valid vertices in the polygon. However, this method provides no validation, so violating these requirements causes undefined behavior.
Setting indices manually will cause the underlying traveral algorithm to be NONE.
indices | A custom traversal of the polygon. |
void cugl::scene2::WireNode::setTraversal | ( | poly2::Traversal | traversal | ) |
Sets the traversal algorithm of this wire frame.
If the traversal algorithm is different from the current one, it will recompute the traversal indices.
traversal | The new traversal algorithm |
void cugl::scene2::WireNode::setTraversal | ( | Uint32 * | indices, |
size_t | isize | ||
) |
Sets the traversal indices of this path.
The indices are a manual traversal of the underlying polygon. The argument should contain an even number of indices, defining a sequence of line segments. In addition, the indices should all represent valid vertices in the polygon. However, this method provides no validation, so violating these requirements causes undefined behavior.
Setting indices manually will cause the underlying traveral algorithm to be NONE.
indices | A custom traversal of the polygon. |
isize | The number of indices |
|
protected |
The wireframe indices
|
protected |
The wireframe vertices
|
protected |
The current (known) traversal of this wireframe