x
Yes
No
Do you want to visit DriveHQ English website?
首页
产品服务
价格
免费试用
下载客户端
关于我们
云文件服务
|
云备份服务
|
FTP服务
|
企业邮箱服务
|
网站托管
|
客户端软件
云文件服务
云备份服务
FTP服务
企业级邮箱服务
网站托管
客户端软件
daeMetaChoice.cpp - Hosted on DriveHQ Cloud IT Platform
返回上层目录
上传
下载
共享
发布
新建文件夹
新建文件
复制
剪切
删除
粘贴
评论
升级服务
路径: \\game3dprogramming\materials\DarkPuzzle\libs\bullet_sdk\Extras\COLLADA_DOM\src\dae\daeMetaChoice.cpp
旋转
特效
属性
历史版本
/* * Copyright 2006 Sony Computer Entertainment Inc. * * Licensed under the SCEA Shared Source License, Version 1.0 (the "License"); you may not use this * file except in compliance with the License. You may obtain a copy of the License at: * http://research.scea.com/scea_shared_source_license.html * * Unless required by applicable law or agreed to in writing, software distributed under the License * is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or * implied. See the License for the specific language governing permissions and limitations under the * License. */ #include
daeMetaChoice::daeMetaChoice( daeMetaElement *container, daeMetaCMPolicy *parent, daeUInt ordinal, daeInt minO, daeInt maxO) : daeMetaCMPolicy( container, parent, ordinal, minO, maxO ) {} daeMetaChoice::~daeMetaChoice() {} daeElement *daeMetaChoice::placeElement( daeElement *parent, daeElement *child, daeUInt &ordinal, daeInt offset, daeElement* before, daeElement *after ) { (void)offset; if ( _maxOccurs == -1 ) { //Needed to prevent infinate loops. If unbounded check to see if you have the child before just trying to place daeString nm = child->getElementName(); if ( nm == NULL ) { nm = child->getTypeName(); } if ( findChild( nm ) == NULL ) { return NULL; } } daeElement *retVal = NULL; size_t cnt = _children.getCount(); for ( daeInt i = 0; ( i < _maxOccurs || _maxOccurs == -1 ); i++ ) { for ( size_t x = 0; x < cnt; x++ ) { if ( _children[x]->placeElement( parent, child, ordinal, i, before, after ) != NULL ) { retVal = child; ordinal = ordinal + _ordinalOffset; break; } } if ( retVal != NULL ) break; } /*if ( retVal && _maxOccurs != -1 ) { //check if the place was valid - only if we aren't unbounded. unbounded is always valid daeInt cnt = 0; daeElementRefArray array; size_t arrayCnt = 0; //saves us from having to clear the array every child for ( size_t x = 0; x < _children.getCount(); x++ ) { _children[x]->getChildren( parent, array ); if ( array.getCount() != arrayCnt ) { //this part of the content model has children. cnt++; if ( cnt > _maxOccurs ) { //picked too many choices - remove element and return false removeElement( parent, child ); return false; } arrayCnt = array.getCount(); } } }*/ return retVal; } daeBool daeMetaChoice::removeElement( daeElement *parent, daeElement *child ) { size_t cnt = _children.getCount(); for ( size_t x = 0; x < cnt; x++ ) { if ( _children[x]->removeElement( parent, child ) ) { return true; } } return false; } daeMetaElement * daeMetaChoice::findChild( daeString elementName ) { daeMetaElement *me = NULL; size_t cnt = _children.getCount(); for ( size_t x = 0; x < cnt; x++ ) { me = _children[x]->findChild( elementName ); if ( me != NULL ) { return me; } } return NULL; } void daeMetaChoice::getChildren( daeElement *parent, daeElementRefArray &array ) { (void)parent; (void)array; //this is taken care of by the _contents in metaElement }
daeMetaChoice.cpp
网页地址
文件地址
上一页
14/24
下一页
下载
( 3 KB )
Comments
Total ratings:
0
Average rating:
无评论
of 10
Would you like to comment?
Join now
, or
Logon
if you are already a member.