本文整理汇总了C++中TreeTemplate::nodeNumber方法的典型用法代码示例。如果您正苦于以下问题:C++ TreeTemplate::nodeNumber方法的具体用法?C++ TreeTemplate::nodeNumber怎么用?C++ TreeTemplate::nodeNumber使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类TreeTemplate
的用法示例。
在下文中一共展示了TreeTemplate::nodeNumber方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1:
Tree::Tree( const TreeTemplate& tmpl ) :
mPosition( 0.0, 0.0, 0.0 ),
mAngle( 0.0, 0.0, 0.0 ),
mScale( 1.0, 1.0, 1.0 ),
mNodes( 0 ),
mNodeNumber( 0 ),
mTime( 0.0 ){
mNodeNumber = tmpl.nodeNumber();
mNodes = new Node[ mNodeNumber ];
for ( int i = 0; i < mNodeNumber; ++i ){
Node& dst = mNodes[ i ];
const NodeTemplate* src = tmpl.node( i );
//パラメータを移す
dst.setTranslation( *src->translation() );
dst.setRotation( *src->rotation() );
dst.setScale( *src->scale() );
dst.setName( src->name()->c_str() );
dst.setBatch( src->batch() );
//[長男-兄弟形式から子配列形式への変換]
//子の数を数える
int child = src->child();
int childNumber = 0;
while ( child >= 0 ){
++childNumber;
child = tmpl.node( child )->brother();
}
//子をアロケート
dst.setChildNumber( childNumber );
//子を充填する
child = src->child();
int j = 0;
while ( child >= 0 ){
dst.setChild( j, mNodes + child );
child = tmpl.node( child )->brother();
++j;
}
}
}