1. // File:src/math/Vector3.js
  2. /**
  3. * @author mrdoob / http://mrdoob.com/
  4. * @author *kile / http://kile.stravaganza.org/
  5. * @author philogb / http://blog.thejit.org/
  6. * @author mikael emtinger / http://gomo.se/
  7. * @author egraether / http://egraether.com/
  8. * @author WestLangley / http://github.com/WestLangley
  9. */
  10. /*
  11. ///Vector3对象的构造函数.用来创建一个三维向量的对象.Vector3对象的功能函数采用
  12. ///定义构造的函数原型对象来实现.
  13. ///
  14. /// 用法: var p2d = new Vector3(5,3,2)
  15. /// 创建一个x坐标为5,y坐标为3的向量,z坐标为2的向量.
  16. /// NOTE: 参数(x,y,z)坐标为可选参数,如果不指定参数(x,y,z),将创建一个坐标为(0,0,0)的向量.
  17. */
  18. ///<summary>Vector3</summary>
  19. ///<param name ="x" type="number">x坐标</param>
  20. ///<param name ="y" type="number">y坐标</param>
  21. ///<param name ="z" type="number">z坐标</param>
  22. THREE.Vector3 = function ( x, y, z ) {
  23. this.x = x || 0;
  24. this.y = y || 0;
  25. this.z = z || 0;
  26. };
  27. /****************************************
  28. ****下面是Vector3对象提供的功能函数.
  29. ****************************************/
  30. THREE.Vector3.prototype = {
  31. constructor: THREE.Vector3, //构造器
  32. /*
  33. ///set方法用来从新设置三维向量的x,y,z坐标值.并返回新的坐标值的三维向量.
  34. */
  35. ///<summary>set</summary>
  36. ///<param name ="x" type="number">x坐标</param>
  37. ///<param name ="y" type="number">y坐标</param>
  38. ///<param name ="z" type="number">y坐标</param>
  39. ///<returns type="Vector3">返回新坐标值的三维向量</returns>
  40. set: function ( x, y, z ) {
  41. this.x = x;
  42. this.y = y;
  43. this.z = z;
  44. return this;    //返回新坐标值的三维向量
  45. },
  46. /*
  47. ///setX方法用来从新设置三维向量的x坐标值.并返回新的坐标值的三维向量.
  48. */
  49. ///<summary>setX</summary>
  50. ///<param name ="x" type="number">x坐标</param>
  51. ///<returns type="Vector3">返回新坐标值的三维向量</returns>
  52. setX: function ( x ) {
  53. this.x = x;
  54. return this;    //返回新坐标值的三维向量
  55. },
  56. /*
  57. ///setY方法用来从新设置三维向量的y坐标值.并返回新的坐标值的三维向量.
  58. */
  59. ///<summary>setY</summary>
  60. ///<param name ="y" type="number">y坐标</param>
  61. ///<returns type="Vector3">返回新坐标值的三维向量</returns>
  62. setY: function ( y ) {
  63. this.y = y;
  64. return this;    //返回新坐标值的三维向量
  65. },
  66. /*
  67. ///setZ方法用来从新设置三维向量的z坐标值.并返回新的坐标值的三维向量.
  68. */
  69. ///<summary>setZ</summary>
  70. ///<param name ="z" type="number">z坐标</param>
  71. ///<returns type="Vector3">返回新坐标值的三维向量</returns>
  72. setZ: function ( z ) {
  73. this.z = z;
  74. return this;    //返回新坐标值的三维向量
  75. },
  76. /*
  77. ///setComponent方法用来从新设置三维向量的(x,y)坐标值.并返回新的坐标值的三维向量.
  78. ///参数index取值为0,1 或者 2,取值为0,参数value设置x的坐标值,取值为1,参数value设置y的坐标,
  79. ///取值为2,参数value设置z的坐标.
  80. */
  81. ///<summary>setComponent</summary>
  82. ///<param name ="index" type="number">0,1或2</param>
  83. ///<param name ="value" type="number">x, y 或 z坐标</param>
  84. setComponent: function ( index, value ) {
  85. switch ( index ) {
  86. case 0: this.x = value; break;
  87. case 1: this.y = value; break;
  88. case 2: this.z = value; break;
  89. default: throw new Error( 'index is out of range: ' + index );
  90. }
  91. },
  92. /*
  93. ///getComponent方法用获得三维向量的(x,y,z)坐标值.
  94. ///参数index取值为0,1 或者 2,取值为0,获得x的坐标值,取值为1,获得y的坐标,
  95. ///取值为2,获得z的坐标.
  96. */
  97. ///<summary>setComponent</summary>
  98. ///<param name ="index" type="number">0,1或2</param>
  99. getComponent: function ( index ) {
  100. switch ( index ) {
  101. case 0: return this.x;
  102. case 1: return this.y;
  103. case 2: return this.z;
  104. default: throw new Error( 'index is out of range: ' + index );
  105. }
  106. },
  107. /*
  108. ///copy方法用来复制三维向量的(x,y,z)坐标值.并返回新的坐标值的三维向量.
  109. */
  110. ///<summary>copy</summary>
  111. ///<param name ="v" type="Vector3">三维向量</param>
  112. ///<returns type="Vector3">返回新坐标值的三维向量</returns>
  113. copy: function ( v ) {
  114. this.x = v.x;
  115. this.y = v.y;
  116. this.z = v.z;
  117. return this;    //返回新坐标值的三维向量
  118. },
  119. /*
  120. ///add方法用来将三维向量的(x,y,z)坐标值与参数v的(x,y,z)相加.并返回新的坐标值的三维向量.
  121. /// NOTE:add()方法虽然有两个参数,但实际上只对参数v做运算,这里的参数w,如果设置的话,调用.addVectors()方法.
  122. */
  123. ///<summary>add</summary>
  124. ///<param name ="v" type="Vector3">与当前对象(x,y,z)坐标值增加的向量</param>
  125. ///<param name ="w" type="Vector3">判断是否有第二个参数w,如果有的话,调用.addVectors()方法</param>
  126. ///<returns type="Vector2">返回新坐标值的二维向量</returns>
  127. add: function ( v, w ) {
  128. if ( w !== undefined ) {    //判断是否有第二个参数w,如果有的话,调用.addVectors()方法.
  129. //THREE.Vector3: .add()方法现在只有一个参数,如果2个参数使用.addVectors( a, b )方法来替代.
  130. console.warn( 'THREE.Vector3: .add() now only accepts one argument. Use .addVectors( a, b ) instead.' );
  131. return this.addVectors( v, w );
  132. }
  133. this.x += v.x;
  134. this.y += v.y;
  135. this.z += v.z;
  136. return this;    //返回新坐标值的三维向量
  137. },
  138. /*
  139. ///addScalar方法用来将三维向量的(x,y,z)坐标值直接与参数s相加.并返回新的坐标值的三维向量.
  140. /// NOTE:这里与add()方法不同的是,这里传递的参数s是一个标量,而add()方法的参数v是一个三维向量.
  141. */
  142. ///<summary>addScalar</summary>
  143. ///<param name ="s" type="number">(x,y,z)要增加的数值</param>
  144. ///<returns type="Vector3">返回新坐标值的三维向量</returns>
  145. addScalar: function ( s ) {
  146. this.x += s;
  147. this.y += s;
  148. this.z += s;
  149. return this;    //返回新坐标值的三维向量
  150. },
  151. /*
  152. ///addVectors方法用来将三维向量的(x,y,z)坐标值等于参数(a,b)的(x,y,z)相加.并返回新的坐标值的三维向量.
  153. /// NOTE:两个矢量组件对应相加。
  154. */
  155. ///<summary>addVectors</summary>
  156. ///<param name ="a" type="Vector3">三维向量</param>
  157. ///<param name ="b" type="Vector3">三维向量</param>
  158. ///<returns type="Vector3">返回新坐标值的三维向量</returns>
  159. addVectors: function ( a, b ) {
  160. this.x = a.x + b.x;
  161. this.y = a.y + b.y;
  162. this.z = a.z + b.z;
  163. return this;    //返回新坐标值的三维向量
  164. },
  165. /*
  166. ///sub方法用来将三维向量的(x,y,z)坐标值与参数v的(x,y,z)相减.并返回新的坐标值的三维向量.
  167. /// NOTE:sub()方法虽然有两个参数,但实际上只对参数v做运算,这里的参数w,如果设置的话,调用.subVectors()方法.
  168. */
  169. ///<summary>sub</summary>
  170. ///<param name ="v" type="Vector3">与当前对象(x,y,z)坐标值增加的三维向量</param>
  171. ///<param name ="w" type="Vector3">判断是否有第二个参数w,如果有的话,调用.subVectors()方法</param>
  172. ///<returns type="Vector3">返回新坐标值的三维向量</returns>
  173. sub: function ( v, w ) {
  174. if ( w !== undefined ) {    //判断是否有第二个参数w,如果有的话,调用.subVectors()方法.
  175. //THREE.Vector3: .sub()方法现在只有一个参数,如果2个参数使用.subVectors( a, b )方法来替代.
  176. console.warn( 'THREE.Vector3: .sub() now only accepts one argument. Use .subVectors( a, b ) instead.' );
  177. return this.subVectors( v, w );
  178. }
  179. this.x -= v.x;
  180. this.y -= v.y;
  181. this.z -= v.z;
  182. return this;    //返回新坐标值的三维向量
  183. },
  184. /*
  185. ///subVectors方法用来将三维向量的(x,y,z)坐标值分别于参数(a,b)的(x,y,z)相减.并返回新的坐标值的三维向量.
  186. */
  187. ///<summary>subVectors</summary>
  188. ///<param name ="a" type="Vector3">三维向量</param>
  189. ///<param name ="b" type="Vector3">三维向量</param>
  190. ///<returns type="Vector3">返回新坐标值的三维向量</returns>
  191. subVectors: function ( a, b ) {
  192. this.x = a.x - b.x;
  193. this.y = a.y - b.y;
  194. this.z = a.z - b.z;
  195. return this;    //返回新坐标值的三维向量
  196. },
  197. /*
  198. ///multiply方法用来将三维向量的(x,y,z)坐标值与参数v的(x,y,z)相乘.并返回新的坐标值的三维向量.
  199. */
  200. ///<summary>multiply</summary>
  201. ///<param name ="v" type="Vector3">与当前对象(x,y,z)值相乘的三维向量</param>
  202. ///<param name ="w" type="Vector3">判断是否有第二个参数w,如果有的话,调用.multiplyVectors()方法</param>
  203. ///<returns type="Vector2">返回新坐标值的三维向量</returns>
  204. multiply: function ( v, w ) {
  205. if ( w !== undefined ) {
  206. //THREE.Vector3: .multiply()方法现在只有一个参数,如果2个参数使用.multiplyVectors( a, b )方法来替代.
  207. console.warn( 'THREE.Vector3: .multiply() now only accepts one argument. Use .multiplyVectors( a, b ) instead.' );
  208. return this.multiplyVectors( v, w );
  209. }
  210. this.x *= v.x;
  211. this.y *= v.y;
  212. this.z *= v.z;
  213. return this;    //返回新坐标值的三维向量
  214. },
  215. /*
  216. ///multiplyScalar方法用来将三维向量的(x,y,z)坐标值直接与参数s相乘.并返回新的坐标值的三维向量.
  217. /// NOTE:这里与multiply()方法不同的是,这里传递的参数scalar是一个标量,而multiply()方法的参数v是一个三维向量.
  218. */
  219. ///<summary>multiplyScalar</summary>
  220. ///<param name ="scalar" type="number">与当前对象(x,y,z)值相乘的标量,数值</param>
  221. ///<returns type="Vector3">返回新坐标值的三维向量</returns>
  222. multiplyScalar: function ( scalar ) {
  223. this.x *= scalar;
  224. this.y *= scalar;
  225. this.z *= scalar;
  226. return this;    //返回新坐标值的三维向量
  227. },
  228. /*
  229. ///multiplyVectors方法用来将三维向量的(x,y,z)坐标值等于参数(a,b)的(x,y,z)相乘.并返回新的坐标值的三维向量.
  230. /// NOTE:两个矢量组件对应相乘。
  231. */
  232. ///<summary>multiplyVectors</summary>
  233. ///<param name ="a" type="Vector3">三维向量</param>
  234. ///<param name ="b" type="Vector3">三维向量</param>
  235. ///<returns type="Vector3">返回新坐标值的三维向量</returns>
  236. multiplyVectors: function ( a, b ) {
  237. this.x = a.x * b.x;
  238. this.y = a.y * b.y;
  239. this.z = a.z * b.z;
  240. return this;    //返回新坐标值的三维向量
  241. },
  242. /*
  243. ///applyEuler方法将当前向量通过参数euler(THREE.Euler对象,欧拉对象)转换成四元数,应用四元数变换.
  244. /// 实际上就是调用四元数下的.setFromEuler()方法.
  245. */
  246. ///<summary>applyEuler</summary>
  247. ///<param name ="euler" type="THREE.Euler">THREE.Euler对象,欧拉对象</param>
  248. ///<returns type="Vector3">返回变换后的三维向量</returns>
  249. applyEuler: function () {
  250. var quaternion;
  251. return function ( euler ) {
  252. if ( euler instanceof THREE.Euler === false ) {
  253. console.error( 'THREE.Vector3: .applyEuler() now expects a Euler rotation rather than a Vector3 and order.' );
  254. }
  255. if ( quaternion === undefined ) quaternion = new THREE.Quaternion();
  256. this.applyQuaternion( quaternion.setFromEuler( euler ) );
  257. return this;    //返回变换后的三维向量
  258. };
  259. }(),
  260. /*
  261. ///applyMatrix3方法将当前向量根据指定的轴(一个标准单位的向量),和角度旋转.或者说根据指定的轴和角度应用旋转.
  262. */
  263. ///<summary>applyMatrix3</summary>
  264. ///<param name ="axis" type="Vector3">三维向量</param>
  265. ///<param name ="angle" type="Matrix3">3x3矩阵</param>
  266. ///<returns type="Vector3">返回变换后的三维向量</returns>
  267. applyAxisAngle: function () {
  268. var quaternion;
  269. return function ( axis, angle ) {
  270. if ( quaternion === undefined ) quaternion = new THREE.Quaternion();
  271. this.applyQuaternion( quaternion.setFromAxisAngle( axis, angle ) ); //实际调用的四元数下面的方法.setFromAxisAngle()
  272. return this;    //返回变换后的三维向量
  273. };
  274. }(),
  275. /*
  276. ///applyMatrix3方法将当前向量乘以一个3x3的矩阵,参数m(一个Matrix3的矩阵)
  277. */
  278. ///<summary>applyMatrix3</summary>
  279. ///<param name ="m" type="Matrix3">3x3矩阵</param>
  280. ///<returns type="Vector3">返回新坐标值的三维向量</returns>
  281. applyMatrix3: function ( m ) {
  282. var x = this.x;
  283. var y = this.y;
  284. var z = this.z;
  285. var e = m.elements;
  286. this.x = e[ 0 ] * x + e[ 3 ] * y + e[ 6 ] * z;
  287. this.y = e[ 1 ] * x + e[ 4 ] * y + e[ 7 ] * z;
  288. this.z = e[ 2 ] * x + e[ 5 ] * y + e[ 8 ] * z;
  289. return this;    //返回新坐标值的三维向量
  290. },
  291. /*
  292. ///applyMatrix4方法乘以该向量和参数m(一个Matrix4投影矩阵)的4x3的子集
  293. */
  294. ///<summary>applyMatrix4</summary>
  295. ///<param name ="m" type="Matrix4">仿射矩阵</param>
  296. ///<returns type="Vector3">返回新坐标值的三维向量</returns>
  297. applyMatrix4: function ( m ) {
  298. // input: THREE.Matrix4 affine matrix
  299. var x = this.x, y = this.y, z = this.z;
  300. var e = m.elements;
  301. this.x = e[ 0 ] * x + e[ 4 ] * y + e[ 8 ]  * z + e[ 12 ];
  302. this.y = e[ 1 ] * x + e[ 5 ] * y + e[ 9 ]  * z + e[ 13 ];
  303. this.z = e[ 2 ] * x + e[ 6 ] * y + e[ 10 ] * z + e[ 14 ];
  304. return this;    //返回新坐标值的三维向量
  305. },
  306. /*
  307. ///applyProjection方法乘以该向量和参数m(一个Matrix4投影矩阵),然后除以视角.
  308. */
  309. ///<summary>applyProjection</summary>
  310. ///<param name ="m" type="Matrix4">投影矩阵</param>
  311. ///<returns type="Vector3">返回新坐标值的三维向量</returns>
  312. applyProjection: function ( m ) {
  313. // input: THREE.Matrix4 projection matrix
  314. var x = this.x, y = this.y, z = this.z;
  315. var e = m.elements;
  316. var d = 1 / ( e[ 3 ] * x + e[ 7 ] * y + e[ 11 ] * z + e[ 15 ] ); // perspective divide
  317. this.x = ( e[ 0 ] * x + e[ 4 ] * y + e[ 8 ]  * z + e[ 12 ] ) * d;
  318. this.y = ( e[ 1 ] * x + e[ 5 ] * y + e[ 9 ]  * z + e[ 13 ] ) * d;
  319. this.z = ( e[ 2 ] * x + e[ 6 ] * y + e[ 10 ] * z + e[ 14 ] ) * d;
  320. return this;
  321. },
  322. /*
  323. ///applyQuaternion方法应用一个四元数变换到当前三维向量.
  324. */
  325. ///<summary>applyQuaternion</summary>
  326. ///<param name ="q" type="Quaternion">四元数</param>
  327. ///<returns type="Vector3">返回新坐标值的三维向量</returns>
  328. applyQuaternion: function ( q ) {
  329. var x = this.x;
  330. var y = this.y;
  331. var z = this.z;
  332. var qx = q.x;
  333. var qy = q.y;
  334. var qz = q.z;
  335. var qw = q.w;
  336. // calculate quat * vector
  337. var ix =  qw * x + qy * z - qz * y;
  338. var iy =  qw * y + qz * x - qx * z;
  339. var iz =  qw * z + qx * y - qy * x;
  340. var iw = - qx * x - qy * y - qz * z;
  341. // calculate result * inverse quat
  342. this.x = ix * qw + iw * - qx + iy * - qz - iz * - qy;
  343. this.y = iy * qw + iw * - qy + iz * - qx - ix * - qz;
  344. this.z = iz * qw + iw * - qz + ix * - qy - iy * - qx;
  345. return this;    //返回新坐标值的三维向量
  346. },
  347. /*
  348. ///transformDirection方法通过参数m(一个Matrix4投射矩阵的3x3子集)转换这个向量的方向
  349. */
  350. ///<summary>transformDirection</summary>
  351. ///<param name ="m" type="Matrix4">仿射矩阵</param>
  352. ///<returns type="Vector3">返回新坐标值的三维向量</returns>
  353. transformDirection: function ( m ) {
  354. // input: THREE.Matrix4 affine matrix
  355. // vector interpreted as a direction
  356. var x = this.x, y = this.y, z = this.z;
  357. var e = m.elements;
  358. this.x = e[ 0 ] * x + e[ 4 ] * y + e[ 8 ]  * z;
  359. this.y = e[ 1 ] * x + e[ 5 ] * y + e[ 9 ]  * z;
  360. this.z = e[ 2 ] * x + e[ 6 ] * y + e[ 10 ] * z;
  361. this.normalize();   //返回单位量
  362. return this;    //返回新的三维向量
  363. },
  364. /*
  365. ///divide方法用来将三维向量的(x,y,z)坐标值与参数v的(x,y,z)相除.并返回新的坐标值的三维向量.
  366. */
  367. ///<summary>divide</summary>
  368. ///<param name ="v" type="Vector3">与当前对象(x,y,z)值相除的三维向量</param>
  369. ///<returns type="Vector3">返回新坐标值的三维向量</returns>
  370. divide: function ( v ) {
  371. this.x /= v.x;
  372. this.y /= v.y;
  373. this.z /= v.z;
  374. return this;    //返回新坐标值的三维向量
  375. },
  376. /*
  377. ///divideScalar方法用来将三维向量的(x,y,z)坐标值直接与参数scalar相除.并返回新的坐标值的三维向量.
  378. /// NOTE:1. 参数scalar如果为0,当前对象(x,y,z)值直接设置为0!!
  379. /// NOTE:2. 这里与divide()方法不同的是,这里传递的参数scalar是一个标量,而divide()方法的参数v是一个三维向量.
  380. */
  381. ///<summary>divideScalar</summary>
  382. ///<param name ="scalar" type="number">与当前对象(x,y,z)值相除的标量,数值</param>
  383. ///<returns type="Vector3">返回新坐标值的三维向量</returns>
  384. divideScalar: function ( scalar ) {
  385. if ( scalar !== 0 ) {
  386. var invScalar = 1 / scalar;     //将被除数换算成小数
  387. this.x *= invScalar;
  388. this.y *= invScalar;
  389. this.z *= invScalar;
  390. } else {
  391. //参数scalar如果为0,当前对象(x,y,z)值直接设置为0!!
  392. this.x = 0;
  393. this.y = 0;
  394. this.z = 0;
  395. }
  396. return this;    //返回新坐标值的三维向量
  397. },
  398. /*
  399. ///min方法用来将三维向量的(x,y,z)坐标值直接与参数v的(x,y)比较,如果当前三维向量的值大于参数v的(x,y,z),
  400. ///将参数v的(x,y,z)赋值给当前向量,并返回(x,y,z)值最小的三维向量.
  401. */
  402. ///<summary>min</summary>
  403. ///<param name ="v" type="Vector3">与当前对象(x,y)值参数v的(x,y,z)比较,并返回(x,y)值最小的三维向量.</param>
  404. ///<returns type="Vector3">返回新坐标值的三维向量</returns>
  405. min: function ( v ) {
  406. if ( this.x > v.x ) {        //如果当前三维向量的x值大于参数v.x
  407. this.x = v.x;   //将参数v的x值赋值给当前向量
  408. }
  409. if ( this.y > v.y ) {        //如果当前三维向量的y值大于参数v.y
  410. this.y = v.y;   //将参数v的y值赋值给当前向量
  411. }
  412. if ( this.z > v.z ) {        //如果当前三维向量的x值大于参数v.z
  413. this.z = v.z;   //将参数v的z值赋值给当前向量
  414. }
  415. return this;    //返回新坐标值的三维向量
  416. },
  417. /*
  418. ///max方法用来将三维向量的(x,y,z)坐标值直接与参数v的(x,y,z)比较,如果当前三维向量的值小于参数v的(x,y,z),
  419. ///将参数v的(x,y,z)赋值给当前向量,并返回(x,y,z)值最大的三维向量.
  420. */
  421. ///<summary>min</summary>
  422. ///<param name ="v" type="Vector3">与当前对象(x,y,z)值参数v的(x,y,z)比较,并返回(x,y,z)值最大的三维向量.</param>
  423. ///<returns type="Vector3">返回新坐标值的三维向量</returns>
  424. max: function ( v ) {
  425. if ( this.x < v.x ) {        //如果当前三维向量的x值小于参数v.x
  426. this.x = v.x;   //将参数v的x值赋值给当前向量
  427. }
  428. if ( this.y < v.y ) {        //如果当前三维向量的x值小于参数v.y
  429. this.y = v.y;   //将参数v的y值赋值给当前向量
  430. }
  431. if ( this.z < v.z ) {        //如果当前三维向量的x值小于参数v.z
  432. this.z = v.z;   //将参数v的z值赋值给当前向量
  433. }
  434. return this;    //返回新坐标值的三维向量
  435. },
  436. /*
  437. ///clamp方法用来将三维向量的(x,y)坐标值直接与参数min,参数max的(x,y,z)比较,如果当前三维向量的值小于参数min的(x,y,z)
  438. ///或者大于参数max的(x,y,z),对应的将参数min或max的(x,y,z)赋值给当前三维向量,
  439. /// NOTE:保持当前三维向量在min,max所组成的三维空间的之内,最大不超过max的(x,y,z)值,最小不小于min的(x,y,z)值.
  440. */
  441. ///<summary>clamp</summary>
  442. ///<param name ="min" type="Vector3">三维向量.</param>
  443. ///<param name ="max" type="Vector3">三维向量.</param>
  444. ///<returns type="Vector2">返回指定界限内的三维向量</returns>
  445. clamp: function ( min, max ) {
  446. // This function assumes min < max, if this assumption isn't true it will not operate correctly
  447. // 这个方法用来获得三维向量的最小值于最大值,如果没有获取到,说明函数运行错误.
  448. if ( this.x < min.x ) {              //如果当前三维向量的x值小于参数min的x值
  449. this.x = min.x;             //将参数min的x值赋值给当前向量
  450. } else if ( this.x > max.x ) {           //如果当前三维向量的x值大于参数max的x值
  451. this.x = max.x;             //将参数max的x值赋值给当前向量
  452. }
  453. if ( this.y < min.y ) {              //如果当前三维向量的x值小于参数min的y值
  454. this.y = min.y;             //将参数min的y值赋值给当前向量
  455. } else if ( this.y > max.y ) {           //如果当前三维向量的y值大于参数max的y值
  456. this.y = max.y;             //将参数max的y值赋值给当前向量
  457. }
  458. if ( this.z < min.z ) {              //如果当前三维向量的x值小于参数min的z值
  459. this.z = min.z;             //将参数min的z值赋值给当前向量
  460. } else if ( this.z > max.z ) {           //如果当前三维向量的x值大于参数max的z值
  461. this.z = max.z;             //将参数max的z值赋值给当前向量
  462. }
  463. return this;    //返回指定界限内的三维向量
  464. },
  465. /*
  466. ///clampScalar方法用来将三维向量的(x,y)坐标值直接与参数minVal,参数maxVal比较,如果当前三维向量的值小于参数minVal
  467. ///或者大于参数maxVal,将参数minVal或maxVal赋值给当前三维向量,
  468. /// NOTE: 1. 保持当前三维向量在minVal,maxVal所组成的三维空间的之内,最大不超过maxVal值,最小不小于minVal值.
  469. /// NOTE: 2. 这里与clamp()方法不同的是,这里传递的参数minVal,maxVal是一个标量,而clamp()方法的参数min,参数max是两个三维向量.
  470. */
  471. ///<summary>clampScalar</summary>
  472. ///<param name ="minVal" type="number">下限.</param>
  473. ///<param name ="maxVal" type="number">上限.</param>
  474. ///<returns type="Vector3">返回指定界限内的三维向量</returns>
  475. clampScalar: ( function () {    //外侧括号是一种特殊的用法,似乎代表立即执行.小白,请见谅!
  476. var min, max;
  477. return function ( minVal, maxVal ) {    //创建匿名函数
  478. if ( min === undefined ) {
  479. min = new THREE.Vector3();
  480. max = new THREE.Vector3();
  481. }
  482. min.set( minVal, minVal, minVal );
  483. max.set( maxVal, maxVal, maxVal );
  484. return this.clamp( min, max );  //调用clamp()方法,返回指定界限内的三维向量
  485. };
  486. } )(),
  487. /*
  488. ///floor方法用来返回小于或等于三维向量的(x,y,z)坐标值的最大整数
  489. /// NOTE:去掉小数部分
  490. */
  491. ///<summary>floor</summary>
  492. ///<returns type="Vector3">返回圆整后的三维向量</returns>
  493. floor: function () {
  494. this.x = Math.floor( this.x );
  495. this.y = Math.floor( this.y );
  496. this.z = Math.floor( this.z );
  497. return this;    //返回圆整后的三维向量
  498. },
  499. /*
  500. ///ceil方法用来返回大于或等于三维向量的(x,y,z)坐标值的最小整数
  501. /// NOTE:将小数部分去掉加1.
  502. */
  503. ///<summary>ceil</summary>
  504. ///<returns type="Vector3">返回圆整后的三维向量</returns>
  505. ceil: function () {
  506. this.x = Math.ceil( this.x );
  507. this.y = Math.ceil( this.y );
  508. this.z = Math.ceil( this.z );
  509. return this;    //返回圆整后的三维向量
  510. },
  511. /*
  512. ///round方法用来返回最接近三维向量的(x,y,z)坐标值的整数
  513. /// NOTE:也就是四舍五入
  514. */
  515. ///<summary>round</summary>
  516. ///<returns type="Vector3">返回圆整后的三维向量</returns>
  517. round: function () {
  518. this.x = Math.round( this.x );
  519. this.y = Math.round( this.y );
  520. this.z = Math.round( this.z );
  521. return this;    //返回圆整后的三维向量
  522. },
  523. /*
  524. ///roundToZero方法将当前三维向量的(x,y,z)坐标值若为负数时,返回大于或等于三维向量的(x,y,z)坐标值的最小整数
  525. /// 而当前三维向量的(x,y,z)坐标值若为正数时,返回小于或等于三维向量的(x,y,z)坐标值的最大整数
  526. */
  527. ///<summary>roundToZero</summary>
  528. ///<returns type="Vector3">返回圆整后的三维向量</returns>
  529. roundToZero: function () {
  530. this.x = ( this.x < 0 ) ? Math.ceil( this.x ) : Math.floor( this.x );
  531. this.y = ( this.y < 0 ) ? Math.ceil( this.y ) : Math.floor( this.y );
  532. this.z = ( this.z < 0 ) ? Math.ceil( this.z ) : Math.floor( this.z );
  533. return this;    //返回圆整后的三维向量
  534. },
  535. /*
  536. ///negate方法将当前三维向量的(x,y,z)坐标值若为负数时,返回正数.
  537. /// 而当前三维向量的(x,y,z)坐标值若为正数时,返回负数.
  538. /// NOTE:取当前三维向量的(x,y,z)坐标值相反数
  539. */
  540. ///<summary>negate</summary>
  541. ///<returns type="Vector3">返回取相反数后的三维向量</returns>
  542. negate: function () {
  543. this.x = - this.x;
  544. this.y = - this.y;
  545. this.z = - this.z;
  546. return this;    //返回取相反数后的三维向量
  547. },
  548. /*
  549. ///dot方法将返回两个向量的点乘积(点乘,数量积).
  550. /// NOTE:1. 关于点积的介绍参考维基百科:http://zh.wikipedia.org/wiki/%E6%95%B0%E9%87%8F%E7%A7%AF, 常用来进行方向性判断,如两向量点积大于0,则它们的方向朝向相近;如果小于0,则方向相反。
  551. /// NOTE:2. Vector3.Dot也叫点积,它返回1个-1.0~1.0之间的一个值。网上确实也这么说。但是这个值表示什么呢?恩,表示返回进行Dot计算的两个向量之间的夹角的余弦值(Cos弧度角).要注意的是能进行Dot计算的前提是两个向量首先要变成单位向量!
  552. */
  553. ///<summary>dot</summary>
  554. ///<param name ="v" type="Vector3">三维向量</param>
  555. ///<returns type="number">返回点乘积(点乘,数量积)</returns>
  556. dot: function ( v ) {
  557. return this.x * v.x + this.y * v.y + this.z * v.z;  //返回点乘积(点乘,数量积)
  558. },
  559. /*
  560. ///lengthSq方法将返回这个三维向量的长度的平方(只读).
  561. /// NOTE:勾股定理a^2 + b^2 +c^2= d^2,这里返回的是d^2.
  562. */
  563. ///<summary>lengthSq</summary>
  564. ///<returns type="number">返回三维向量的长度的平方(只读)</returns>
  565. lengthSq: function () {
  566. return this.x * this.x + this.y * this.y + this.z * this.z; //返回三维向量的长度的平方(只读)
  567. },
  568. /*
  569. ///length方法将返回三维向量的长度(只读).
  570. /// NOTE:勾股定理a^2 + b^2 + c^2=d^2,d=Math.sqrt(a^2 + b^2+c^2),这里返回的是d.
  571. */
  572. ///<summary>length</summary>
  573. ///<returns type="number">返回三维向量的长度(只读)</returns>
  574. length: function () {
  575. return Math.sqrt( this.x * this.x + this.y * this.y + this.z * this.z );        //返回三维向量的长度(只读)
  576. },
  577. /*
  578. ///lengthManhattan方法将返回三维向量(x,y,z)值的和(只读).
  579. ///曼哈顿距离——两点在南北方向上的距离加上在东西方向上的距离,即d(i,j)=|xi-xj|+|yi-yj|。对于一个具有
  580. ///正南正北、正东正西方向规则布局的城镇街道,从一点到达另一点的距离正是在南北方向上旅行的距离加上在东西方向
  581. ///上旅行的距离,因此曼哈顿距离又称为出租车距离,曼哈顿距离不是距离不变量,当坐标轴变动时,点间的距离就会不同。
  582. ///维基百科上的内容:http://zh.wikipedia.org/zh/%E6%9B%BC%E5%93%88%E9%A0%93%E8%B7%9D%E9%9B%A2
  583. /// NOTE:曼哈顿距离,this.x + this.y + this.z.
  584. /// TODO:曼哈顿距离,这个功能应该二维向量中增加这个方法呀?计算路径的时候很常用呀.
  585. */
  586. ///<summary>lengthManhattan</summary>
  587. ///<returns type="number">返回三维向量的长度(只读)</returns>
  588. lengthManhattan: function () {
  589. return Math.abs( this.x ) + Math.abs( this.y ) + Math.abs( this.z );
  590. },
  591. /*
  592. ///normalize方法将返回向量的长度为1(只读).
  593. /// 复习一下初中的几何吧,三角恒等式,给你准备好了 :) ,见维基百科:
  594. /// http://zh.wikipedia.org/wiki/%E4%B8%89%E8%A7%92%E5%87%BD%E6%95%B0#.E4.B8.89.E8.A7.92.E6.81.92.E7.AD.89.E5.BC.8F
  595. */
  596. ///<summary>normalize</summary>
  597. ///<returns type="number">返回三维向量(x,y,z)值的和(只读)</returns>
  598. normalize: function () {
  599. return this.divideScalar( this.length() );  //返回三维向量(x,y,z)值的和(只读)
  600. },
  601. /*
  602. ///setLength方法用来按照参数l(长度)设置新的三维向量(x,y,z)值.
  603. /// NOTE:将以原点到当前向量的线段等比例缩放到参数l所指定的长度.
  604. */
  605. ///<summary>setLength</summary>
  606. ///<param name ="l" type="number">指定的长度</param>
  607. ///<returns type="Vector3">返回按照参数l(长度)设置新的三维向量(x,y,z)值.</returns>
  608. setLength: function ( l ) {
  609. var oldLength = this.length();
  610. if ( oldLength !== 0 && l !== oldLength  ) {        //做个判断,如果原长度与新长度不相等,并且原长度不为0.
  611. this.multiplyScalar( l / oldLength );       //调用.multiplyScalar()方法,传递新长度与原长度的比.
  612. }
  613. return this;        //返回按照参数l(长度)设置新的三维向量(x,y,z)值.
  614. },
  615. /*lerp方法
  616. ///lerp方法在将当前三维向量(x,y,z)设置为下限和参数v(x,y,z)设为上限 之间进行线性插值,
  617. /// alpha 表示权值。从下限当前三维向量(x,y,z)到上限参数v(x,y,z)乘以百分比alpha(0.0-1.0),加上当前三维向量(x,y,z)
  618. ///当前二维向量(x,y,z)的和赋值给当前三维向量(x,y,z),返回当前三维向量(x,y,z).
  619. /// NOTE:注意,如果 当前三维向量(x,y,z) 和 参数v(x,y,z)是向量,则权值 alpha 必须是标量,取值范围是0.0-1.0.
  620. */
  621. ///<summary>lerp</summary>
  622. ///<param name ="v" type="Vector3">三维向量</param>
  623. ///<param name ="alpha" type="number">百分比权值(0.0-1.0)</param>
  624. ///<returns type="Vector3">三维向量</returns>
  625. lerp: function ( v, alpha ) {
  626. this.x += ( v.x - this.x ) * alpha;
  627. this.y += ( v.y - this.y ) * alpha;
  628. this.z += ( v.z - this.z ) * alpha;
  629. return this;    //返回三维向量
  630. },
  631. /*cross方法
  632. ///cross方法将返回两个交叉乘积,调用者本身与v的叉乘。叉乘是一个向量,垂直于参与叉乘的两个向量并呈右手螺旋法则。
  633. /// 返回为同时垂直于两个参数向量的向量,方向可朝上也可朝下,由两向量夹角的方向决定。
  634. /// NOTE:借助右手定则辅助判断方向。
  635. /// 叉乘是一种在向量空间中向量的二元运算。与点乘不同,它的运算结果是一个伪向量而不是一个标量。
  636. /// 叉乘的运算结果叫叉积(即交叉乘积)、外积或向量积。叉积与原来的两个向量都垂直。
  637. 1、理论知识
  638. 数学上的定义:c=axb【注:粗体小写字母表示向量】其中a,b,c均为向量。即两个向量的叉积得到的还是向量!
  639. 性质1:c⊥a,c⊥b,即向量c垂直与向量a,b所在的平面。
  640. 性质2:模长|c|=|a||b|sin<a,b>
  641. 性质3:满足右手法则。从这点我们有axb ≠ bxa,而axb = - bxa。所以我们可以使用叉积的正负值来判断向量a,b的相对
  642. 位置,即向量b是处于向量a的顺时针方向还是逆时针方向。
  643. */
  644. ///<summary>cross</summary>
  645. ///<param name ="v" type="Vector3">三维向量</param>
  646. ///<param name ="w" type="Vector3">三维向量</param>
  647. ///<returns type="Vector3">三维向量</returns>
  648. cross: function ( v, w ) {
  649. if ( w !== undefined ) {
  650. console.warn( 'THREE.Vector3: .cross() now only accepts one argument. Use .crossVectors( a, b ) instead.' );
  651. return this.crossVectors( v, w );   //如果存在第二个参数,将调用.crossVectors()方法.
  652. }
  653. var x = this.x, y = this.y, z = this.z;
  654. this.x = y * v.z - z * v.y;
  655. this.y = z * v.x - x * v.z;
  656. this.z = x * v.y - y * v.x;
  657. return this;    //返回三维向量
  658. },
  659. /*crossVectors方法
  660. ///crossVectors方法将返回两个交叉乘积,调用者变为a,b的叉乘。叉乘是一个向量,垂直于参与叉乘的两个向量并呈右手螺旋法则。
  661. /// 返回为同时垂直于两个参数向量的向量,方向可朝上也可朝下,由两向量夹角的方向决定。
  662. /// NOTE:借助右手定则辅助判断方向。参考:http://zh.wikipedia.org/zh/%E5%90%91%E9%87%8F%E7%A7%AF
  663. /// 叉乘是一种在向量空间中向量的二元运算。与点乘不同,它的运算结果是一个伪向量而不是一个标量。
  664. /// 叉乘的运算结果叫叉积(即交叉乘积)、外积或向量积。叉积与原来的两个向量都垂直。
  665. 1、理论知识
  666. 数学上的定义:c=axb【注:粗体小写字母表示向量】其中a,b,c均为向量。即两个向量的叉积得到的还是向量!
  667. 性质1:c⊥a,c⊥b,即向量c垂直与向量a,b所在的平面。
  668. 性质2:模长|c|=|a||b|sin<a,b>
  669. 性质3:满足右手法则。从这点我们有axb ≠ bxa,而axb = - bxa。所以我们可以使用叉积的正负值来判断向量a,b的相对位置,
  670. 即向量b是处于向量a的顺时针方向还是逆时针方向。
  671. */
  672. ///<summary>crossVectors</summary>
  673. ///<param name ="a" type="Vector3">三维向量</param>
  674. ///<param name ="b" type="Vector3">三维向量</param>
  675. ///<returns type="Vector3">三维向量</returns>
  676. crossVectors: function ( a, b ) {
  677. var ax = a.x, ay = a.y, az = a.z;
  678. var bx = b.x, by = b.y, bz = b.z;
  679. this.x = ay * bz - az * by;
  680. this.y = az * bx - ax * bz;
  681. this.z = ax * by - ay * bx;
  682. return this;    //返回三维向量
  683. },
  684. /*projectOnVector方法
  685. ///projectOnVector方法在将当前三维向量(x,y,z)投影一个向量到另一个向量,参数vector(x,y,z).
  686. /// NOTE:进行Dot计算的前提是两个向量首先要变成单位向量,这里通过调用.normalize()得到单位向量.
  687. */
  688. ///<summary>projectOnVector</summary>
  689. ///<param name ="vector" type="Vector3">三维向量</param>
  690. ///<returns type="Vector3">三维向量</returns>
  691. projectOnVector: function () {
  692. var v1, dot;
  693. return function ( vector ) {
  694. if ( v1 === undefined ) v1 = new THREE.Vector3();
  695. v1.copy( vector ).normalize();      //NOTE:进行Dot计算的前提是两个向量首先要变成单位向量,这里通过调用.normalize()得到单位向量.
  696. dot = this.dot( v1 );   //dot常用来进行方向性判断,如两向量点积大于0,则它们的方向朝向相近;如果小于0,则方向相反。
  697. return this.copy( v1 ).multiplyScalar( dot );   //投影一个向量到另一个向量。
  698. };
  699. }(),
  700. /*projectOnPlane方法
  701. ///projectOnPlane方法在将当前三维向量(x,y,z)投影一个向量到一个平面(用一个向量表示,参数planeNormal(x,y,z)),然后当前向量减去
  702. ///从这个向量到这个向量到平面法线的投影.
  703. */
  704. ///<summary>projectOnPlane</summary>
  705. ///<param name ="planeNormal" type="Vector3">三维向量</param>
  706. ///<returns type="Vector3">三维向量</returns>
  707. projectOnPlane: function () {
  708. var v1;
  709. return function ( planeNormal ) {
  710. if ( v1 === undefined ) v1 = new THREE.Vector3();
  711. v1.copy( this ).projectOnVector( planeNormal );     //调用.projectVector方法.
  712. return this.sub( v1 );
  713. }
  714. }(),
  715. /*reflect方法
  716. ///reflect方法沿着法线(参数normal)反射向量.
  717. /// NOTE:reflect方法其实就是对一个向量进行镜像.
  718. */
  719. ///<summary>reflect</summary>
  720. ///<param name ="normal" type="Vector3">三维向量</param>
  721. ///<returns type="Vector3">返回一个反射过后的向量.</returns>
  722. reflect: function () {
  723. // reflect incident vector off plane orthogonal to normal
  724. // normal is assumed to have unit length
  725. var v1;
  726. return function ( normal ) {
  727. if ( v1 === undefined ) v1 = new THREE.Vector3();
  728. return this.sub( v1.copy( normal ).multiplyScalar( 2 * this.dot( normal ) ) );  //返回一个反射过后的向量.
  729. }
  730. }(),
  731. /*angleTo方法
  732. ///angleTo方法返回当前向量与另一个向量的夹角.
  733. */
  734. ///<summary>angleTo</summary>
  735. ///<param name ="v" type="Vector3">三维向量</param>
  736. ///<returns type="number">返回当前向量与另一个向量的夹角</returns>
  737. angleTo: function ( v ) {
  738. var theta = this.dot( v ) / ( this.length() * v.length() );
  739. // clamp, to handle numerical problems
  740. return Math.acos( THREE.Math.clamp( theta, - 1, 1 ) );  //返回当前向量与另一个向量的
  741. },
  742. /*
  743. ///distanceTo方法将返回当前三维向量到参数v的距离(只读).
  744. */
  745. ///<summary>distanceTo</summary>
  746. ///<param name ="v" type="Vector3">三维向量</param>
  747. ///<returns type="Vector3">返回当前三维向量到参数v的距离(只读).</returns>
  748. distanceTo: function ( v ) {
  749. return Math.sqrt( this.distanceToSquared( v ) );    //返回当前三维向量到参数v的距离(只读).
  750. },
  751. /*
  752. ///distanceToSquared方法将返回当前三维向量到参数v的距离的点积(点乘,数量积)(只读).
  753. /// NOTE:关于点积的介绍参考维基百科:http://zh.wikipedia.org/wiki/%E6%95%B0%E9%87%8F%E7%A7%AF
  754. */
  755. ///<summary>distanceToSquared</summary>
  756. ///<param name ="v" type="Vector3">三维向量</param>
  757. ///<returns type="Vector3">返回当前三维向量到参数v的距离的点积(点乘,数量积)(只读)</returns>
  758. distanceToSquared: function ( v ) {
  759. var dx = this.x - v.x;
  760. var dy = this.y - v.y;
  761. var dz = this.z - v.z;
  762. return dx * dx + dy * dy + dz * dz;         //当前三维向量到参数v的距离的点积(点乘,数量积)(只读).
  763. },
  764. /// NOTE:setEulerFromRotationMatrix()方法已经删除,使用Euler.setFromRotationMatrix()替换,此处保留函数为了向下兼容.
  765. setEulerFromRotationMatrix: function ( m, order ) {
  766. console.error( 'THREE.Vector3: .setEulerFromRotationMatrix() has been removed. Use Euler.setFromRotationMatrix() instead.' );
  767. },
  768. /// NOTE:setEulerFromQuaternion()方法已经删除,使用Euler.setFromQuaternion()替换,此处保留函数为了向下兼容.
  769. setEulerFromQuaternion: function ( q, order ) {
  770. console.error( 'THREE.Vector3: .setEulerFromQuaternion() has been removed. Use Euler.setFromQuaternion() instead.' );
  771. },
  772. /*
  773. ///getPositionFromMatrix方法将返回从矩阵中的元素得到的新的向量值的向量.
  774. /// NOTE:getPositionFromMatrix()方法已经删除,使用.setFromMatrixPosition()替换,此处保留函数为了向下兼容.
  775. */
  776. ///<summary>getPositionFromMatrix</summary>
  777. ///<param name ="m" type="Matrix">矩阵</param>
  778. ///<returns type="Vector3">返回三维向量</returns>
  779. getPositionFromMatrix: function ( m ) {
  780. console.warn( 'THREE.Vector3: .getPositionFromMatrix() has been renamed to .setFromMatrixPosition().' );
  781. return this.setFromMatrixPosition( m );     //返回三维向量
  782. },
  783. /*
  784. ///getScaleFromMatrix方法将返回从矩阵中的元素的长度赋值给当前向量.
  785. /// NOTE:getScaleFromMatrix()方法已经删除,使用.setFromMatrixScale()替换,此处保留函数为了向下兼容.
  786. */
  787. ///<summary>getScaleFromMatrix</summary>
  788. ///<param name ="m" type="Matrix">矩阵</param>
  789. ///<returns type="Vector3">返回三维向量</returns>
  790. getScaleFromMatrix: function ( m ) {
  791. console.warn( 'THREE.Vector3: .getScaleFromMatrix() has been renamed to .setFromMatrixScale().' );
  792. return this.setFromMatrixScale( m );    //返回三维向量
  793. },
  794. /*
  795. ///getColumnFromMatrix方法将矩阵指定的列中的元素的向量值赋值给给当前的向量.
  796. /// NOTE:getColumnFromMatrix()方法已经删除,使用.setFromMatrixColumn()替换,此处保留函数为了向下兼容.
  797. */
  798. ///<summary>getColumnFromMatrix</summary>
  799. ///<param name ="index" type="number">列数,列的下标.</param>
  800. ///<param name ="matrix" type="Matrix">矩阵</param>
  801. ///<returns type="Vector3">返回三维向量</returns>
  802. getColumnFromMatrix: function ( index, matrix ) {
  803. console.warn( 'THREE.Vector3: .getColumnFromMatrix() has been renamed to .setFromMatrixColumn().' );
  804. return this.setFromMatrixColumn( index, matrix );   //返回三维向量
  805. },
  806. /*
  807. ///setFromMatrixPosition方法将返回从矩阵中的元素得到的新的向量值的向量.
  808. */
  809. ///<summary>setFromMatrixPosition</summary>
  810. ///<param name ="m" type="Matrix">矩阵</param>
  811. ///<returns type="Vector3">返回三维向量</returns>
  812. setFromMatrixPosition: function ( m ) {
  813. this.x = m.elements[ 12 ];
  814. this.y = m.elements[ 13 ];
  815. this.z = m.elements[ 14 ];
  816. return this;    //返回三维向量
  817. },
  818. /*
  819. ///setFromMatrixScale方法将返回从矩阵中的元素的长度赋值给当前向量.
  820. */
  821. ///<summary>setFromMatrixScale</summary>
  822. ///<param name ="m" type="Matrix">矩阵</param>
  823. ///<returns type="Vector3">返回三维向量</returns>
  824. setFromMatrixScale: function ( m ) {
  825. var sx = this.set( m.elements[ 0 ], m.elements[ 1 ], m.elements[  2 ] ).length();
  826. var sy = this.set( m.elements[ 4 ], m.elements[ 5 ], m.elements[  6 ] ).length();
  827. var sz = this.set( m.elements[ 8 ], m.elements[ 9 ], m.elements[ 10 ] ).length();
  828. this.x = sx;
  829. this.y = sy;
  830. this.z = sz;
  831. return this;    //返回三维向量
  832. },
  833. /*
  834. ///setFromMatrixColumn方法将矩阵指定的列中的元素的向量值赋值给给当前的向量.
  835. */
  836. ///<summary>setFromMatrixColumn</summary>
  837. ///<param name ="index" type="number">列数,列的下标.</param>
  838. ///<param name ="matrix" type="Matrix">矩阵</param>
  839. ///<returns type="Vector3">返回三维向量</returns>
  840. setFromMatrixColumn: function ( index, matrix ) {
  841. var offset = index * 4;
  842. var me = matrix.elements;
  843. this.x = me[ offset ];
  844. this.y = me[ offset + 1 ];
  845. this.z = me[ offset + 2 ];
  846. return this;    //返回三维向量
  847. },
  848. /*equals方法
  849. ///equals方法相当于比较运算符===,将当前三维向量和参数v中的(x,y,z)值进行对比,返回bool型值.
  850. */
  851. ///<summary>equals</summary>
  852. ///<param name ="v" type="Vector3">三维向量(x,y,z)</param>
  853. ///<returns type="bool">返回true or false</returns
  854. equals: function ( v ) {
  855. return ( ( v.x === this.x ) && ( v.y === this.y ) && ( v.z === this.z ) );  //返回true or false
  856. },
  857. /*fromArray方法
  858. ///fromArray方法将存储三维向量(x,y)值的数组赋值给当前三维向量对象
  859. */
  860. ///<summary>fromArray</summary>
  861. ///<param name ="array" type="Array">三维向量(x,y,z)值数组array[x,y,z]</param>
  862. ///<returns type="Vector3">返回新的三维向量</returns>
  863. fromArray: function ( array ) {
  864. this.x = array[ 0 ];
  865. this.y = array[ 1 ];
  866. this.z = array[ 2 ];
  867. return this;    //返回新的三维向量
  868. },
  869. /*toArray方法
  870. ///toArray方法将当前三维向量对象的属性赋值给数组array[0.5,0.5,0.5].返回一个数组对象.
  871. */
  872. ///<summary>toArray</summary>
  873. ///<returns type="Array">三维向量(x,y,z)值数组array[x,y,z]</returns>
  874. toArray: function () {
  875. return [ this.x, this.y, this.z ];  //三维向量(x,y)值数组array[x,y]
  876. },
  877. /*clone方法
  878. ///clone方法克隆一个三维向量对象.
  879. */
  880. ///<summary>clone</summary>
  881. ///<returns type="Vector3">返回三维向量对象</returns>
  882. clone: function () {
  883. return new THREE.Vector3( this.x, this.y, this.z );     //返回三维向量
  884. }
  885. };

threejs里面的vector3源码解析的更多相关文章

  1. Retrofit2 源码解析

    原文链接:http://bxbxbai.github.io/2015/12/13/retrofit2-analysis/ 公司里最近做的项目中网络框架用的就是Retrofit,用的多了以后觉得这个框架 ...

  2. wsgiref 源码解析

    Web Server Gateway Interface(wsgi),即Web服务器网关接口,是Web服务器软件和用Python编写的Web应用程序之间的标准接口. 想了解更多关于WSGI请前往: h ...

  3. Retrofit源码解析(下)

    接着上一章继续分析上一章主要简单说了一下基本使用和注解,这一章,我们主要看源码,废话不多说了,直接上.先上一张图 从网络上拿来的 前面一章说了一下Retrofit的简单使用https://www.cn ...

  4. 【原】Android热更新开源项目Tinker源码解析系列之三:so热更新

    本系列将从以下三个方面对Tinker进行源码解析: Android热更新开源项目Tinker源码解析系列之一:Dex热更新 Android热更新开源项目Tinker源码解析系列之二:资源文件热更新 A ...

  5. 【原】Android热更新开源项目Tinker源码解析系列之一:Dex热更新

    [原]Android热更新开源项目Tinker源码解析系列之一:Dex热更新 Tinker是微信的第一个开源项目,主要用于安卓应用bug的热修复和功能的迭代. Tinker github地址:http ...

  6. 多线程爬坑之路-Thread和Runable源码解析之基本方法的运用实例

    前面的文章:多线程爬坑之路-学习多线程需要来了解哪些东西?(concurrent并发包的数据结构和线程池,Locks锁,Atomic原子类) 多线程爬坑之路-Thread和Runable源码解析 前面 ...

  7. jQuery2.x源码解析(缓存篇)

    jQuery2.x源码解析(构建篇) jQuery2.x源码解析(设计篇) jQuery2.x源码解析(回调篇) jQuery2.x源码解析(缓存篇) 缓存是jQuery中的又一核心设计,jQuery ...

  8. Spring IoC源码解析——Bean的创建和初始化

    Spring介绍 Spring(http://spring.io/)是一个轻量级的Java 开发框架,同时也是轻量级的IoC和AOP的容器框架,主要是针对JavaBean的生命周期进行管理的轻量级容器 ...

  9. jQuery2.x源码解析(设计篇)

    jQuery2.x源码解析(构建篇) jQuery2.x源码解析(设计篇) jQuery2.x源码解析(回调篇) jQuery2.x源码解析(缓存篇) 这一篇笔者主要以设计的角度探索jQuery的源代 ...

随机推荐

  1. VR全景智慧城市:360全景市场需要背景及其优势~

    VR元年已过,VR项目.VR创业潮转为理性,VR行业分为两个方向:硬件和内容. VR全景,又被称为3D实景,是一种新兴的富媒体技术,其与视频,声音,图片等传统的流媒体大的区别是"可操作,可交 ...

  2. 热部署环境下,dubbo序列化的bug和优化

    一.问题的发现与解决 (1)     在热部署下,使用dubbo的序列化一个pojo对象,反序列化时报错:ClassNotFoundException. 最后发现原因是我们的框架选择使用了java序列 ...

  3. threading多线程总结

    threading用于提供线程相关的操作,线程是应用程序中工作的最小单元.python当前版本的多线程库没有实现优先级.线程组,线程也不能被停止.暂停.恢复.中断. threading模块提供的类:  ...

  4. python之numpy库[2]

    python-numpy csv文件的写入和存取 写入csv文件 CSV (Comma‐Separated Value, 逗号分隔值),是一种常见的文件格式,用来存储批量数据. 写入csv文件 np. ...

  5. JVM高级特性-三、垃圾收集之判断对象存活算法

    一.概述 运行时数据区中,程序计数器.虚拟机栈.本地方法栈都是随线程而生随线程而灭的 因此,他们的内存分配和回收是确定的,在方法或线程结束时就回收.而Java堆和方 法区则是不确定的,程序运行过程中创 ...

  6. Solr集群搭建

    SolrCloud需要solr基于zookeeper部署,zookeeper是一个集群管理软件,由于SolrCloud需要由多台服务器组成.由zookeeper来进行协调管理.Zookeeper是一个 ...

  7. 有关SQL模糊查询

    执行 数据库查询时,有完整查询和模糊查询之分. 一般模糊语句如下: SELECT 字段 FROM 表 WHERE 某字段 Like 条件 其中关于条件,SQL提供了四种匹配模式: 1,%:表示任意0个 ...

  8. docker 汇总

    整理中 ... 一. docker 基础 配置参数最佳实践 二. docker 编排工具 docker swarm mesos kubernetes AWS ECS 三. docker 生态 dock ...

  9. 基于Mac制作iPhone铃声教程,iTunes定制铃声

    前言: 网上太多制作方法了,不管是借助第三方软件还是基于iTunes的,不过这些方法都太旧了,有时看起来 ,界面的变化或其他原因,导致很不爽. 正好记录下我最近使用的一种方法: 正文: 一.下载你需要 ...

  10. Visual Studio 2017 for Mac 体验之Android.Form

    微软官方说明: Visual Studio 2017 for Mac Last Update: 2017/6/16 我们非常荣幸地宣布 Visual Studio 2017 for Mac 现已推出. ...