WorkerRunner.js 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  1. /**
  2. * @author Kai Salmen / www.kaisalmen.de
  3. */
  4. import { ObjectManipulator } from "../../utils/ObjectManipulator.js";
  5. const DefaultWorkerPayloadHandler = function ( parser ) {
  6. this.parser = parser;
  7. this.logging = {
  8. enabled: false,
  9. debug: false
  10. };
  11. };
  12. DefaultWorkerPayloadHandler.prototype = {
  13. constructor: DefaultWorkerPayloadHandler,
  14. handlePayload: function ( payload ) {
  15. if ( payload.logging ) {
  16. this.logging.enabled = payload.logging.enabled === true;
  17. this.logging.debug = payload.logging.debug === true;
  18. }
  19. if ( payload.cmd === 'parse' ) {
  20. let scope = this;
  21. let callbacks = {
  22. callbackOnAssetAvailable: function ( payload ) {
  23. self.postMessage( payload );
  24. },
  25. callbackOnProgress: function ( text ) {
  26. if ( scope.logging.enabled && scope.logging.debug ) console.debug( 'WorkerRunner: progress: ' + text );
  27. }
  28. };
  29. let parser = this.parser;
  30. if ( typeof parser[ 'setLogging' ] === 'function' ) {
  31. parser.setLogging( this.logging.enabled, this.logging.debug );
  32. }
  33. ObjectManipulator.applyProperties( parser, payload.params );
  34. ObjectManipulator.applyProperties( parser, payload.materials );
  35. ObjectManipulator.applyProperties( parser, callbacks );
  36. let arraybuffer;
  37. if ( payload.params && payload.params.index !== undefined && payload.params.index !== null) {
  38. arraybuffer = this.resourceDescriptors[ payload.params.index ].content;
  39. } else {
  40. arraybuffer = payload.data.input;
  41. }
  42. let parseFunctionName = 'parse';
  43. if ( typeof parser.getParseFunctionName === 'function' ) parseFunctionName = parser.getParseFunctionName();
  44. if ( payload.usesMeshDisassembler ) {
  45. // TODO: Allow to plug and use generic MeshDisassembler
  46. } else {
  47. parser[ parseFunctionName ] ( arraybuffer, payload.data.options );
  48. }
  49. if ( this.logging.enabled ) console.log( 'WorkerRunner: Run complete!' );
  50. self.postMessage( {
  51. cmd: 'completeOverall',
  52. msg: 'WorkerRunner completed run.'
  53. } );
  54. } else {
  55. console.error( 'WorkerRunner: Received unknown command: ' + payload.cmd );
  56. }
  57. }
  58. };
  59. /**
  60. * Default implementation of the WorkerRunner responsible for creation and configuration of the parser within the worker.
  61. * @constructor
  62. */
  63. const WorkerRunner = function ( payloadHandler ) {
  64. this.resourceDescriptors = [];
  65. this.payloadHandler = payloadHandler;
  66. let scope = this;
  67. let scopedRunner = function( event ) {
  68. scope.processMessage( event.data );
  69. };
  70. self.addEventListener( 'message', scopedRunner, false );
  71. };
  72. WorkerRunner.prototype = {
  73. constructor: WorkerRunner,
  74. /**
  75. * Configures the Parser implementation according the supplied configuration object.
  76. *
  77. * @param {Object} payload Raw mesh description (buffers, params, materials) used to build one to many meshes.
  78. */
  79. processMessage: function ( payload ) {
  80. if ( payload.data.resourceDescriptors && this.resourceDescriptors.length === 0 ) {
  81. for ( let name in payload.data.resourceDescriptors ) {
  82. this.resourceDescriptors.push( payload.data.resourceDescriptors[ name ] );
  83. }
  84. }
  85. this.payloadHandler.handlePayload( payload );
  86. }
  87. };
  88. export {
  89. WorkerRunner,
  90. DefaultWorkerPayloadHandler
  91. }