/*
* Copyright 2007 (c) Tim Knip, ascollada.org.
*
* Permission is hereby granted, free of charge, to any person
* obtaining a copy of this software and associated documentation
* files (the "Software"), to deal in the Software without
* restriction, including without limitation the rights to use,
* copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the
* Software is furnished to do so, subject to the following
* conditions:
*
* The above copyright notice and this permission notice shall be
* included in all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
* OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
* HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
* WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
* OTHER DEALINGS IN THE SOFTWARE.
*/
package org.ascollada.core
{
import org.ascollada.ASCollada;
import org.ascollada.core.DaeEntity;
import org.ascollada.utils.Logger;
/**
*
*/
public class student_ar_org_ascollada_core_DaeVertexWeights extends DaeEntity
{
/** */
public var count:int;
/** */
public var inputs:Array;
/** */
public var v:Array;
/** */
public var vcounts:Array;
/**
*
* @param node
* @return
*/
public function student_ar_org_ascollada_core_DaeVertexWeights( node:XML = null ):void
{
super( node );
}
/**
*
* @param node
* @return
*/
override public function read( node:XML ):void
{
this.inputs = new Array();
if( node.localName() != ASCollada.DAE_WEIGHTS_ELEMENT )
throw new Error( "not a <" + ASCollada.DAE_WEIGHTS_ELEMENT + "> element!" );
super.read( node );
this.count = getAttributeAsInt(node,ASCollada.DAE_COUNT_ATTRIBUTE);
Logger.log( " => reading vertex_weights" );
// require 2 or more elements
var inputList:XMLList = getNodeList(node, ASCollada.DAE_INPUT_ELEMENT);
if( inputList.length() < 2 )
throw new Error( " requires at least 2 elements!" );
// parse elements
for( var i:int = 0; i < inputList.length(); i++ )
{
var input:DaeInput = new DaeInput(inputList[i]);
this.inputs.push( input);
}
this.v = new Array();
this.vcounts = new Array();
var vNode:XML = getNode(node, ASCollada.DAE_VERTEX_ELEMENT);
var vcountNode:XML = getNode(node, ASCollada.DAE_VERTEXCOUNT_ELEMENT);
if( !vNode || !vcountNode )
return;
// Describes which bones and attributes are associated with each
// vertex. An index of -1 into the array of joints refers to the bind shape.
// Weights should be normalized before use.
this.v = getInts( vNode );
// Describes the number of bones associated with each vertex.
this.vcounts = getInts( vcountNode );
}
}
}