亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? daetransform.as

?? flash 360全景瀏覽
?? AS
字號:
/*
 * 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.types 
{
	import org.ascollada.ASCollada;
	import org.ascollada.core.DaeChannel;
	import org.ascollada.utils.Logger;
	import org.papervision3d.core.math.Matrix3D;
	import org.papervision3d.core.math.Number3D;
	
	/**
	 * @author	Tim Knip 
	 */
	public class DaeTransform 
	{
		/** type - required */
		public var type:String;
		
		/** sid - optional */
		public var sid:String;
		
		/** */
		public var values:Array;
		
		/** matrix created from type and values */
		public var matrix:Array;
		
		/**
		 * 
		 * @param	type
		 * @param	values
		 * @return
		 */	
		public function DaeTransform( type:String, sid:String, values:Array, yUp:Boolean = false ):void
		{
			this.type = type;
			this.sid = sid;
			this.values = values;
			
			_yUp = yUp;
			
			if( !validateValues() )
			{
				Logger.trace( "[ERROR] invalid values for this transform!" );
				throw new Error( "[ERROR] invalid values for this transform!" );
			}
			
			this.matrix = buildMatrix();
		}
		
		/**
		 * 
		 * @param	channel	the animation channel. @see org.ascollada.core.DaeChannel
		 * 
		 * @return
		 */
		public function buildAnimatedMatrices( channel:DaeChannel ):Array
		{
			var output:Array = channel.output;
			var matrices:Array = new Array();
			var i:int;
			
			switch( this.type )
			{
				case ASCollada.DAE_ROTATE_ELEMENT:
					if(channel.syntax.member == "ANGLE")
					{
						for( i = 0; i < output.length; i++ )
							matrices.push( rotationMatrix(values[0], values[1], values[2], output[i]) );
					}
					else
						Logger.trace( " => => " + this.type + " " + channel.syntax );
					break;
				case ASCollada.DAE_TRANSLATE_ELEMENT:
					if( channel.syntax.isFullAccess )
					{
						for( i = 0; i < output.length; i++ )
							matrices.push( translationMatrix(output[i][0], output[i][1], output[i][2]) );
					}
					else if( channel.syntax.member == "X" )
					{
						for( i = 0; i < output.length; i++ )
							matrices.push( translationMatrix(output[i], 0, 0) );						
					}
					else if( channel.syntax.member == "Y" )
					{
						for( i = 0; i < output.length; i++ )
							matrices.push( translationMatrix(0, output[i], 0) );						
					}
					else if( channel.syntax.member == "Z" )
					{
						for( i = 0; i < output.length; i++ )
							matrices.push( translationMatrix(0, 0, output[i]) );						
					}
					else
					{
						Logger.trace( " => => " + this.type + " " + channel.syntax );
					}
					break;
				case ASCollada.DAE_SCALE_ELEMENT:
					Logger.trace( " => buildAnimatedMatrices " + this.type );
					break;
				case ASCollada.DAE_MATRIX_ELEMENT:
					if( channel.syntax.isFullAccess )
					{
						for( i = 0; i < channel.output.length; i++ )
							matrices.push( bakedMatrix(channel.output[i]) );
					}
					break;
				default:
					Logger.trace( " => unknown type " + this.type );
					break;
			}
			
			return matrices;
		}
		
		/**
		 * 
		 * @return
		 */
		public function buildMatrix():Array
		{
			var matrix:Array = null;
			
			switch( this.type )
			{
				case ASCollada.DAE_ROTATE_ELEMENT:
					matrix = rotationMatrix(values[0], values[1], values[2], values[3]);
					break;
				case ASCollada.DAE_TRANSLATE_ELEMENT:
					matrix = translationMatrix(values[0], values[1], values[2]);
					break;
				case ASCollada.DAE_SCALE_ELEMENT:
					matrix = scaleMatrix(values[0], values[1], values[2]);
					break;
				case ASCollada.DAE_MATRIX_ELEMENT:
					matrix = bakedMatrix(values);
					break;
				default:
					Logger.trace( "[ERROR] don't know how to create a matrix with type=" + this.type );
					throw new Error( "don't know how to create a matrix with type=" + this.type );
					break;
			}
			
			return matrix;
		}
		
		/**
		 * 
		 * @return
		 */
		public function validateValues():Boolean
		{
			var valid:Boolean = false;
			
			if( !this.values || !this.values.length )
				return false;
				
			switch( this.type )
			{
				case ASCollada.DAE_ROTATE_ELEMENT:
					valid = (this.values.length == 4);
					break;
				case ASCollada.DAE_TRANSLATE_ELEMENT:
					valid = (this.values.length == 3);
					break;
				case ASCollada.DAE_SCALE_ELEMENT:
					valid = (this.values.length == 3);
					break;
				case ASCollada.DAE_MATRIX_ELEMENT:
					valid = (this.values.length == 16);
					break;
				default:
					break;
			}
			
			return valid;
		}
		
		/**
		 * 
		 * @param	values
		 * @return
		 */
		private function bakedMatrix( values:Array ):Array
		{
			return values;
			if(!this._yUp)
			{
				var m : Matrix3D = new Matrix3D(values);
				
				var neg : Boolean = (m.det < 0);
				
				var tx:Number = m.n14;
				var ty:Number = m.n24;
				var tz:Number = m.n34;
				
				var sx:Number3D = new Number3D(m.n11, m.n12, m.n13);
				var sy:Number3D = new Number3D(m.n21, m.n22, m.n23);
				var sz:Number3D = new Number3D(m.n31, m.n32, m.n33);
				
				var rot : Number3D = Matrix3D.matrix2euler(m);
				rot.x *= (Math.PI/180);
				rot.y *= (Math.PI/180); 
				rot.z *= (Math.PI/180);  
				
			//	rot.x = neg ? -rot.x : rot.x;
			//	rot.y = neg ? -rot.y : rot.y;
			//	rot.z = neg ? -rot.z : rot.z;
				var q:Object = Matrix3D.euler2quaternion( rot.x, rot.y, rot.z ); // Swappe
				
				m = Matrix3D.quaternion2matrix( q.x, q.y, q.z, q.w );
				
				var sm : Matrix3D = Matrix3D.scaleMatrix(sx.modulo, sy.modulo, sz.modulo);
				
				if(neg)
				{
					//sm.n11 = -sm.n11;
					//sm.n22 = -sm.n22;
					//sm.n33 = -sm.n33;
				}
				
				m.calculateMultiply(m, sm);
				
				values = [
					m.n11, m.n12, m.n13, tx,
					m.n21, m.n22, m.n23, ty,
					m.n31, m.n32, m.n33, tz,
					m.n41, m.n42, m.n43, 0];
			}
			return values;
		}

		/**
		 * 
		 * @param	x
		 * @param	y
		 * @param	z
		 * @param	rad
		 * @return
		 */
		private function rotationMatrix( x:Number, y:Number, z:Number, deg:Number ):Array
		{
			var m:Array = [
				1, 0, 0, 0,
				0, 1, 0, 0,
				0, 0, 1, 0
			];
			
			var rad:Number = deg * (Math.PI/180);
			var nCos:Number	= Math.cos( rad );
			var nSin:Number	= Math.sin( rad );
			var scos:Number	= 1 - nCos;

			var sxy	:Number = x * y * scos;
			var syz	:Number = y * z * scos;
			var sxz	:Number = x * z * scos;
			var sz	:Number = nSin * z;
			var sy	:Number = nSin * y;
			var sx	:Number = nSin * x;

			m[0] =  nCos + x * x * scos;
			m[1] = -sz   + sxy;
			m[2] =  sy   + sxz;

			m[4] =  sz   + sxy;
			m[5] =  nCos + y * y * scos;
			m[6] = -sx   + syz;

			m[8] = -sy   + sxz;
			m[9] =  sx   + syz;
			m[10] =  nCos + z * z * scos;
			
			return m;			
		}

		/**
		 * 
		 * @param	x
		 * @param	y
		 * @param	z
		 * @return
		 */
		private function scaleMatrix( x:Number, y:Number, z:Number ):Array
		{
			var m:Array = [
				x, 0, 0, 0,
				0, y, 0, 0,
				0, 0, z, 0,
				0, 0, 0, 1
			];

			return m;
		}
		
		/**
		 * 
		 * @param	x
		 * @param	y
		 * @param	z
		 * @return
		 */
		private function translationMatrix( x:Number, y:Number, z:Number ):Array
		{
			var m:Array = [
				1, 0, 0, x,
				0, 1, 0, y,
				0, 0, 1, z,
				0, 0, 0, 1
			];
			return m;
		}
			
		private var _yUp:Boolean;

		static private var toDEGREES :Number = 180/Math.PI;
		static private var toRADIANS :Number = Math.PI/180;
	}
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品一区二区在线看| 亚洲视频一二区| 国产精品入口麻豆九色| 亚洲欧洲国产日韩| 一区二区三区资源| 美女性感视频久久| 国产成人免费在线| 在线观看三级视频欧美| 日韩欧美自拍偷拍| 国产精品女人毛片| 视频在线观看一区| 成人av在线影院| 777午夜精品视频在线播放| 国产亚洲欧美日韩在线一区| 亚洲国产裸拍裸体视频在线观看乱了 | 欧美mv日韩mv国产网站app| 国产欧美精品一区| 亚洲一区二区欧美日韩 | 欧美国产日韩亚洲一区| 亚洲国产精品一区二区尤物区| 国产一区二区三区免费看 | 亚洲国产欧美日韩另类综合| 国产在线播放一区| 欧美色老头old∨ideo| 日本一区二区三区dvd视频在线| 亚洲综合免费观看高清完整版在线 | 91丨porny丨首页| 日韩欧美电影在线| 亚洲精品国产成人久久av盗摄| 久久不见久久见免费视频7| 在线这里只有精品| 国产午夜精品理论片a级大结局| 亚洲妇女屁股眼交7| 白白色 亚洲乱淫| 亚洲精品在线电影| 亚洲成国产人片在线观看| 成人教育av在线| 亚洲精品在线一区二区| 亚洲国产成人91porn| 不卡一区二区中文字幕| 日韩欧美国产一区二区三区| 亚洲一区二三区| a在线欧美一区| 久久久国产精华| 老色鬼精品视频在线观看播放| 在线视频一区二区三| 国产精品视频麻豆| 国内精品久久久久影院薰衣草| 91麻豆精品国产无毒不卡在线观看| 亚洲啪啪综合av一区二区三区| 国产盗摄女厕一区二区三区| 欧美成人猛片aaaaaaa| 婷婷开心激情综合| 欧美日韩欧美一区二区| 亚洲久草在线视频| proumb性欧美在线观看| 国产欧美日韩三级| 国产一区二区久久| 精品99久久久久久| 国内精品写真在线观看| 欧美不卡一区二区| 久久综合综合久久综合| 欧美一级专区免费大片| 三级欧美在线一区| 2020国产精品久久精品美国| 日本伊人色综合网| 欧美精品亚洲一区二区在线播放| 亚洲最大成人网4388xx| 91麻豆成人久久精品二区三区| 国产精品久久午夜夜伦鲁鲁| 丁香啪啪综合成人亚洲小说 | 国产成人欧美日韩在线电影| 久久久久久久国产精品影院| 国产精品影视天天线| 久久久久久久久岛国免费| 国产黄色精品视频| 欧美激情一区二区| 91在线观看美女| 亚洲欧美偷拍三级| 色婷婷亚洲一区二区三区| 亚洲欧美成aⅴ人在线观看| 91麻豆文化传媒在线观看| 亚洲人快播电影网| 欧美午夜精品久久久久久超碰 | 欧美日韩亚洲综合一区| 亚洲成av人片一区二区梦乃| 欧美羞羞免费网站| 午夜影院在线观看欧美| 欧美一区二区视频观看视频| 精品无码三级在线观看视频| 久久久久久综合| 成a人片亚洲日本久久| 亚洲欧美日韩国产手机在线| 欧美亚洲一区三区| 青娱乐精品视频| 26uuu国产电影一区二区| 成人av资源下载| 亚洲一区日韩精品中文字幕| 欧美一区2区视频在线观看| 国产成人午夜99999| 亚洲欧美日韩国产另类专区| 欧美高清一级片在线| 国产曰批免费观看久久久| 自拍av一区二区三区| 欧美日韩高清一区二区三区| 韩国毛片一区二区三区| 国产精品久99| 欧美日韩精品欧美日韩精品一| 老司机一区二区| 亚洲欧洲韩国日本视频| 91麻豆精品国产91久久久久久| 国产一区二区三区在线观看免费 | 91麻豆免费在线观看| 午夜电影网亚洲视频| 久久人人超碰精品| 日本黄色一区二区| 久久99精品视频| 亚洲欧美成人一区二区三区| 日韩欧美高清dvd碟片| av在线综合网| 麻豆一区二区三| 一区在线观看视频| 国产欧美一区二区精品性| 91搞黄在线观看| 国产自产v一区二区三区c| 亚洲精品国产精华液| 精品日韩一区二区三区免费视频| 99久久精品久久久久久清纯| 日韩电影免费一区| 国产精品国产三级国产普通话99| 欧美日韩国产大片| voyeur盗摄精品| 精品一区二区在线播放| 亚洲在线成人精品| 中文字幕乱码亚洲精品一区| 91精品国产综合久久精品app| 成人免费黄色在线| 久久国产精品无码网站| 夜夜爽夜夜爽精品视频| 久久久www免费人成精品| 欧美日韩国产区一| 99久久综合国产精品| 精品无码三级在线观看视频| 日韩精品一二三四| 亚洲男女一区二区三区| 久久亚洲精品小早川怜子| 欧美视频中文字幕| 99热这里都是精品| 国产高清亚洲一区| 免费不卡在线视频| 亚洲国产一区在线观看| 国产精品福利影院| 国产喂奶挤奶一区二区三区| 欧美一级午夜免费电影| 欧美日韩一区二区在线观看视频| 91丨porny丨首页| 99久久久无码国产精品| 国产福利精品一区二区| 久久不见久久见免费视频7| 日韩精品一二三| 亚洲成a天堂v人片| 亚洲动漫第一页| 一区二区三区在线高清| 国产精品久久久久久久久搜平片| 久久亚洲综合av| 欧美成人综合网站| 日韩你懂的在线播放| 日韩午夜在线观看| 日韩午夜激情av| 91精品国产综合久久福利| 欧美巨大另类极品videosbest| 91激情五月电影| 色久优优欧美色久优优| 91看片淫黄大片一级在线观看| caoporm超碰国产精品| www.久久精品| 一本色道久久综合精品竹菊 | 亚洲成av人片在www色猫咪| 一区二区日韩av| 亚洲综合成人在线| 一区二区高清在线| 亚洲自拍另类综合| 亚洲一区二区三区小说| 亚洲成人动漫在线观看| 午夜av一区二区三区| 日韩电影一区二区三区| 日韩电影一区二区三区四区| 麻豆精品视频在线观看| 久久精品国产77777蜜臀| 精品一区免费av| 国产大片一区二区| av电影在线观看完整版一区二区| 成人av网站免费| 色综合一区二区| 欧美性大战久久| 51精品秘密在线观看| 精品久久久久久综合日本欧美| 精品对白一区国产伦| 国产欧美一区二区三区网站| 亚洲视频一二三|