BufferNode.js 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. import UniformNode from '../core/UniformNode.js';
  2. import { nodeObject } from '../tsl/TSLBase.js';
  3. /** @module BufferNode **/
  4. /**
  5. * A special type of uniform node which represents array-like data
  6. * as uniform buffers. The access usually happens via `element()`
  7. * which returns an instance of {@link ArrayElementNode}. For example:
  8. *
  9. * ```js
  10. * const bufferNode = buffer( array, 'mat4', count );
  11. * const matrixNode = bufferNode.element( index ); // access a matrix from the buffer
  12. * ```
  13. * In general, it is recommended to use the more managed {@link UniformArrayNode}
  14. * since it handles more input types and automatically cares about buffer paddings.
  15. *
  16. * @augments module:UniformNode~UniformNode
  17. */
  18. class BufferNode extends UniformNode {
  19. static get type() {
  20. return 'BufferNode';
  21. }
  22. /**
  23. * Constructs a new buffer node.
  24. *
  25. * @param {Array<Number>} value - Array-like buffer data.
  26. * @param {String} bufferType - The data type of the buffer.
  27. * @param {Number} [bufferCount=0] - The count of buffer elements.
  28. */
  29. constructor( value, bufferType, bufferCount = 0 ) {
  30. super( value, bufferType );
  31. /**
  32. * This flag can be used for type testing.
  33. *
  34. * @type {Boolean}
  35. * @readonly
  36. * @default true
  37. */
  38. this.isBufferNode = true;
  39. /**
  40. * The data type of the buffer.
  41. *
  42. * @type {String}
  43. */
  44. this.bufferType = bufferType;
  45. /**
  46. * The uniform node that holds the value of the reference node.
  47. *
  48. * @type {Number}
  49. * @default 0
  50. */
  51. this.bufferCount = bufferCount;
  52. }
  53. /**
  54. * The data type of the buffer elements.
  55. *
  56. * @param {NodeBuilder} builder - The current node builder.
  57. * @return {String} The element type.
  58. */
  59. getElementType( builder ) {
  60. return this.getNodeType( builder );
  61. }
  62. /**
  63. * Overwrites the default implementation to return a fixed value `'buffer'`.
  64. *
  65. * @param {NodeBuilder} builder - The current node builder.
  66. * @return {String} The input type.
  67. */
  68. getInputType( /*builder*/ ) {
  69. return 'buffer';
  70. }
  71. }
  72. export default BufferNode;
  73. /**
  74. * TSL function for creating a buffer node.
  75. *
  76. * @function
  77. * @param {Array} value - Array-like buffer data.
  78. * @param {String} type - The data type of a buffer element.
  79. * @param {Number} count - The count of buffer elements.
  80. * @returns {BufferNode}
  81. */
  82. export const buffer = ( value, type, count ) => nodeObject( new BufferNode( value, type, count ) );
粤ICP备19079148号