@omnimedia/omnitool 1.1.0-8 → 1.1.0-81

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (436) hide show
  1. package/README.md +293 -76
  2. package/package.json +19 -17
  3. package/s/context.ts +0 -7
  4. package/s/demo/demo.bundle.ts +104 -43
  5. package/s/demo/demo.css +244 -14
  6. package/s/demo/routines/export-test.ts +16 -0
  7. package/s/demo/routines/filmstrip-test.ts +22 -18
  8. package/s/demo/routines/load-video.ts +2 -3
  9. package/s/demo/routines/playback-test.ts +61 -0
  10. package/s/demo/routines/timeline-setup.ts +50 -0
  11. package/s/demo/routines/transcode-test.ts +19 -5
  12. package/s/demo/routines/transitions-test.ts +2 -2
  13. package/s/demo/routines/waveform-test.ts +35 -8
  14. package/s/driver/driver-worker.ts +9 -0
  15. package/s/driver/driver.test.ts +1 -1
  16. package/s/driver/driver.ts +43 -42
  17. package/s/driver/fns/schematic.ts +26 -6
  18. package/s/driver/fns/work.ts +65 -189
  19. package/s/driver/parts/compositor.ts +316 -0
  20. package/s/driver/parts/machina.ts +19 -20
  21. package/s/driver/utils/find-pixi-filter.ts +24 -0
  22. package/s/index.html.ts +103 -25
  23. package/s/index.ts +1 -0
  24. package/s/tests.bundle.ts +11 -0
  25. package/s/tests.html.ts +28 -0
  26. package/s/timeline/index.ts +8 -2
  27. package/s/timeline/parts/animations.ts +56 -0
  28. package/s/timeline/parts/filmstrip.ts +43 -16
  29. package/s/timeline/parts/filters.ts +453 -0
  30. package/s/timeline/parts/item.ts +70 -7
  31. package/s/timeline/parts/media.ts +12 -2
  32. package/s/timeline/parts/resource-pool.ts +8 -5
  33. package/s/timeline/parts/resource.ts +3 -0
  34. package/s/timeline/parts/waveform/parts/collect.ts +72 -0
  35. package/s/timeline/parts/waveform/parts/render.ts +45 -0
  36. package/s/timeline/parts/waveform/parts/types.ts +24 -0
  37. package/s/timeline/parts/waveform/waveform.ts +161 -0
  38. package/s/timeline/renderers/export/parts/audio-gain.ts +17 -0
  39. package/s/timeline/renderers/export/parts/audio-mix.ts +133 -0
  40. package/s/timeline/renderers/export/parts/cursor.ts +129 -0
  41. package/s/timeline/renderers/export/parts/produce-audio.ts +64 -0
  42. package/s/timeline/renderers/export/parts/produce-video.ts +49 -0
  43. package/s/timeline/renderers/export/parts/resamplers.ts +48 -0
  44. package/s/timeline/renderers/export/produce.ts +28 -0
  45. package/s/timeline/renderers/parts/handy.ts +377 -0
  46. package/s/timeline/renderers/parts/samplers/audio/parts/find.ts +19 -0
  47. package/s/timeline/renderers/parts/samplers/audio/parts/init.ts +60 -0
  48. package/s/timeline/renderers/parts/samplers/audio/parts/sink.ts +38 -0
  49. package/s/timeline/renderers/parts/samplers/audio/parts/types.ts +16 -0
  50. package/s/timeline/renderers/parts/samplers/audio/sampler.ts +35 -0
  51. package/s/timeline/renderers/parts/samplers/visual/parts/defaults.ts +16 -0
  52. package/s/timeline/renderers/parts/samplers/visual/parts/sample.ts +69 -0
  53. package/s/timeline/renderers/parts/samplers/visual/parts/sequence.ts +111 -0
  54. package/s/timeline/renderers/parts/samplers/visual/parts/sink.ts +38 -0
  55. package/s/timeline/renderers/parts/samplers/visual/parts/transition.ts +28 -0
  56. package/s/timeline/renderers/parts/samplers/visual/parts/types.ts +10 -0
  57. package/s/timeline/renderers/parts/samplers/visual/sampler.ts +28 -0
  58. package/s/timeline/renderers/parts/schedulers.ts +96 -0
  59. package/s/timeline/renderers/player/parts/playback.ts +159 -0
  60. package/s/timeline/renderers/player/player.ts +77 -0
  61. package/s/timeline/renderers/renderers.test.ts +403 -0
  62. package/s/timeline/sugar/helpers.ts +190 -0
  63. package/s/timeline/sugar/o.ts +271 -59
  64. package/s/timeline/sugar/omni.test.ts +210 -0
  65. package/s/timeline/sugar/omni.ts +35 -12
  66. package/s/timeline/types.ts +28 -3
  67. package/s/timeline/utils/anim.ts +72 -0
  68. package/s/timeline/utils/checksum.ts +3 -1
  69. package/s/timeline/utils/datafile.ts +15 -4
  70. package/s/timeline/utils/dummy-data.ts +3 -3
  71. package/s/timeline/utils/matrix.ts +21 -0
  72. package/s/timeline/utils/terps.ts +81 -0
  73. package/s/units/fps.ts +8 -0
  74. package/s/units/ms.ts +8 -0
  75. package/s/units/seconds.ts +8 -0
  76. package/x/WebGLRenderer-4CHIZDHY.js +2 -0
  77. package/x/WebGLRenderer-4CHIZDHY.js.map +7 -0
  78. package/x/WebGPURenderer-O6WXU2QR.js +2 -0
  79. package/x/WebGPURenderer-O6WXU2QR.js.map +7 -0
  80. package/x/browserAll-WNIOTNNP.js +2 -0
  81. package/x/browserAll-WNIOTNNP.js.map +7 -0
  82. package/x/chunk-23FOBGX6.js +2 -0
  83. package/x/chunk-23FOBGX6.js.map +7 -0
  84. package/x/chunk-73XOWA4F.js +393 -0
  85. package/x/chunk-73XOWA4F.js.map +7 -0
  86. package/x/chunk-IAWJKNX5.js +42 -0
  87. package/x/chunk-IAWJKNX5.js.map +7 -0
  88. package/x/chunk-KCMVLWBS.js +157 -0
  89. package/x/chunk-KCMVLWBS.js.map +7 -0
  90. package/x/chunk-MR32SQ27.js +2 -0
  91. package/x/chunk-MR32SQ27.js.map +7 -0
  92. package/x/chunk-VCUJJYRJ.js +327 -0
  93. package/x/chunk-VCUJJYRJ.js.map +7 -0
  94. package/x/chunk-XNIZ4L5W.js +269 -0
  95. package/x/chunk-XNIZ4L5W.js.map +7 -0
  96. package/x/chunk-ZLGNQFUI.js +15 -0
  97. package/x/chunk-ZLGNQFUI.js.map +7 -0
  98. package/x/context.d.ts +1 -4
  99. package/x/context.js +1 -5
  100. package/x/context.js.map +1 -1
  101. package/x/demo/WebGLRenderer-RSJAHIG2.js +2 -0
  102. package/x/demo/WebGLRenderer-RSJAHIG2.js.map +7 -0
  103. package/x/demo/WebGPURenderer-MGFAJCYY.js +2 -0
  104. package/x/demo/WebGPURenderer-MGFAJCYY.js.map +7 -0
  105. package/x/demo/browserAll-PTRBXBRP.js +2 -0
  106. package/x/demo/browserAll-PTRBXBRP.js.map +7 -0
  107. package/x/demo/chunk-CUYOGHWU.js +42 -0
  108. package/x/demo/chunk-CUYOGHWU.js.map +7 -0
  109. package/x/demo/chunk-DGTDNJ7W.js +2 -0
  110. package/x/demo/chunk-DGTDNJ7W.js.map +7 -0
  111. package/x/demo/chunk-FZ5BYF63.js +15 -0
  112. package/x/demo/chunk-FZ5BYF63.js.map +7 -0
  113. package/x/demo/chunk-KWN4NNES.js +269 -0
  114. package/x/demo/chunk-KWN4NNES.js.map +7 -0
  115. package/x/demo/chunk-OJ3FPXW7.js +157 -0
  116. package/x/demo/chunk-OJ3FPXW7.js.map +7 -0
  117. package/x/demo/chunk-PSLUOGTZ.js +393 -0
  118. package/x/demo/chunk-PSLUOGTZ.js.map +7 -0
  119. package/x/demo/chunk-VLCVEIFU.js +327 -0
  120. package/x/demo/chunk-VLCVEIFU.js.map +7 -0
  121. package/x/demo/chunk-ZWCPT5FR.js +2 -0
  122. package/x/demo/chunk-ZWCPT5FR.js.map +7 -0
  123. package/x/demo/demo.bundle.js +94 -40
  124. package/x/demo/demo.bundle.js.map +1 -1
  125. package/x/demo/demo.bundle.min.js +7340 -90
  126. package/x/demo/demo.bundle.min.js.map +4 -4
  127. package/x/demo/demo.css +244 -14
  128. package/x/demo/routines/export-test.d.ts +2 -0
  129. package/x/demo/routines/export-test.js +10 -0
  130. package/x/demo/routines/export-test.js.map +1 -0
  131. package/x/demo/routines/filmstrip-test.d.ts +1 -1
  132. package/x/demo/routines/filmstrip-test.js +20 -17
  133. package/x/demo/routines/filmstrip-test.js.map +1 -1
  134. package/x/demo/routines/load-video.d.ts +1 -1
  135. package/x/demo/routines/load-video.js +1 -2
  136. package/x/demo/routines/load-video.js.map +1 -1
  137. package/x/demo/routines/playback-test.d.ts +2 -0
  138. package/x/demo/routines/playback-test.js +51 -0
  139. package/x/demo/routines/playback-test.js.map +1 -0
  140. package/x/demo/routines/timeline-setup.d.ts +6 -0
  141. package/x/demo/routines/timeline-setup.js +32 -0
  142. package/x/demo/routines/timeline-setup.js.map +1 -0
  143. package/x/demo/routines/transcode-test.js +15 -5
  144. package/x/demo/routines/transcode-test.js.map +1 -1
  145. package/x/demo/routines/transitions-test.js +2 -2
  146. package/x/demo/routines/transitions-test.js.map +1 -1
  147. package/x/demo/routines/waveform-test.d.ts +2 -1
  148. package/x/demo/routines/waveform-test.js +29 -8
  149. package/x/demo/routines/waveform-test.js.map +1 -1
  150. package/x/demo/webworkerAll-JENRT6BT.js +2 -0
  151. package/x/demo/webworkerAll-JENRT6BT.js.map +7 -0
  152. package/x/driver/driver-worker.d.ts +1 -0
  153. package/x/driver/driver-worker.js +6 -0
  154. package/x/driver/driver-worker.js.map +1 -0
  155. package/x/driver/driver.d.ts +25 -8
  156. package/x/driver/driver.js +43 -39
  157. package/x/driver/driver.js.map +1 -1
  158. package/x/driver/driver.test.js +1 -1
  159. package/x/driver/driver.test.js.map +1 -1
  160. package/x/driver/driver.worker.bundle.min.js +117 -3506
  161. package/x/driver/driver.worker.bundle.min.js.map +4 -4
  162. package/x/driver/fns/host.d.ts +3 -2
  163. package/x/driver/fns/schematic.d.ts +25 -4
  164. package/x/driver/fns/work.d.ts +4 -4
  165. package/x/driver/fns/work.js +55 -155
  166. package/x/driver/fns/work.js.map +1 -1
  167. package/x/driver/parts/compositor.d.ts +39 -0
  168. package/x/driver/parts/compositor.js +261 -0
  169. package/x/driver/parts/compositor.js.map +1 -0
  170. package/x/driver/parts/machina.d.ts +0 -20
  171. package/x/driver/parts/machina.js +6 -10
  172. package/x/driver/parts/machina.js.map +1 -1
  173. package/x/driver/utils/find-pixi-filter.d.ts +5 -0
  174. package/x/driver/utils/find-pixi-filter.js +13 -0
  175. package/x/driver/utils/find-pixi-filter.js.map +1 -0
  176. package/x/features/speech/transcribe/parts/prep-audio.d.ts +1 -1
  177. package/x/features/speech/transcribe/worker.bundle.min.js +899 -899
  178. package/x/features/speech/transcribe/worker.bundle.min.js.map +4 -4
  179. package/x/index.d.ts +1 -0
  180. package/x/index.html +347 -38
  181. package/x/index.html.js +103 -24
  182. package/x/index.html.js.map +1 -1
  183. package/x/index.js +1 -0
  184. package/x/index.js.map +1 -1
  185. package/x/tests.bundle.js +8 -0
  186. package/x/tests.bundle.js.map +1 -0
  187. package/x/tests.bundle.min.js +7374 -0
  188. package/x/tests.bundle.min.js.map +7 -0
  189. package/x/tests.html +316 -0
  190. package/x/tests.html.d.ts +2 -0
  191. package/x/tests.html.js +22 -0
  192. package/x/tests.html.js.map +1 -0
  193. package/x/timeline/index.d.ts +7 -1
  194. package/x/timeline/index.js +7 -1
  195. package/x/timeline/index.js.map +1 -1
  196. package/x/timeline/parts/animations.d.ts +105 -0
  197. package/x/timeline/parts/animations.js +28 -0
  198. package/x/timeline/parts/animations.js.map +1 -0
  199. package/x/timeline/parts/filmstrip.d.ts +4 -3
  200. package/x/timeline/parts/filmstrip.js +29 -10
  201. package/x/timeline/parts/filmstrip.js.map +1 -1
  202. package/x/timeline/parts/filters.d.ts +108 -0
  203. package/x/timeline/parts/filters.js +340 -0
  204. package/x/timeline/parts/filters.js.map +1 -0
  205. package/x/timeline/parts/item.d.ts +56 -4
  206. package/x/timeline/parts/item.js +5 -1
  207. package/x/timeline/parts/item.js.map +1 -1
  208. package/x/timeline/parts/media.d.ts +2 -0
  209. package/x/timeline/parts/media.js +11 -2
  210. package/x/timeline/parts/media.js.map +1 -1
  211. package/x/timeline/parts/resource-pool.d.ts +3 -0
  212. package/x/timeline/parts/resource-pool.js +7 -4
  213. package/x/timeline/parts/resource-pool.js.map +1 -1
  214. package/x/timeline/parts/resource.d.ts +3 -0
  215. package/x/timeline/parts/waveform/parts/collect.d.ts +11 -0
  216. package/x/timeline/parts/waveform/parts/collect.js +56 -0
  217. package/x/timeline/parts/waveform/parts/collect.js.map +1 -0
  218. package/x/timeline/parts/waveform/parts/render.d.ts +5 -0
  219. package/x/timeline/parts/waveform/parts/render.js +29 -0
  220. package/x/timeline/parts/waveform/parts/render.js.map +1 -0
  221. package/x/timeline/parts/waveform/parts/types.d.ts +21 -0
  222. package/x/timeline/parts/waveform/parts/types.js.map +1 -0
  223. package/x/timeline/parts/waveform/waveform.d.ts +19 -0
  224. package/x/timeline/parts/waveform/waveform.js +133 -0
  225. package/x/timeline/parts/waveform/waveform.js.map +1 -0
  226. package/x/timeline/renderers/export/parts/audio-gain.d.ts +1 -0
  227. package/x/timeline/renderers/export/parts/audio-gain.js +13 -0
  228. package/x/timeline/renderers/export/parts/audio-gain.js.map +1 -0
  229. package/x/timeline/renderers/export/parts/audio-mix.d.ts +21 -0
  230. package/x/timeline/renderers/export/parts/audio-mix.js +89 -0
  231. package/x/timeline/renderers/export/parts/audio-mix.js.map +1 -0
  232. package/x/timeline/renderers/export/parts/cursor.d.ts +18 -0
  233. package/x/timeline/renderers/export/parts/cursor.js +99 -0
  234. package/x/timeline/renderers/export/parts/cursor.js.map +1 -0
  235. package/x/timeline/renderers/export/parts/produce-audio.d.ts +6 -0
  236. package/x/timeline/renderers/export/parts/produce-audio.js +41 -0
  237. package/x/timeline/renderers/export/parts/produce-audio.js.map +1 -0
  238. package/x/timeline/renderers/export/parts/produce-video.d.ts +10 -0
  239. package/x/timeline/renderers/export/parts/produce-video.js +26 -0
  240. package/x/timeline/renderers/export/parts/produce-video.js.map +1 -0
  241. package/x/timeline/renderers/export/parts/resamplers.d.ts +12 -0
  242. package/x/timeline/renderers/export/parts/resamplers.js +29 -0
  243. package/x/timeline/renderers/export/parts/resamplers.js.map +1 -0
  244. package/x/timeline/renderers/export/produce.d.ts +13 -0
  245. package/x/timeline/renderers/export/produce.js +15 -0
  246. package/x/timeline/renderers/export/produce.js.map +1 -0
  247. package/x/timeline/renderers/parts/handy.d.ts +36 -0
  248. package/x/timeline/renderers/parts/handy.js +221 -0
  249. package/x/timeline/renderers/parts/handy.js.map +1 -0
  250. package/x/timeline/renderers/parts/samplers/audio/parts/find.d.ts +6 -0
  251. package/x/timeline/renderers/parts/samplers/audio/parts/find.js +15 -0
  252. package/x/timeline/renderers/parts/samplers/audio/parts/find.js.map +1 -0
  253. package/x/timeline/renderers/parts/samplers/audio/parts/init.d.ts +5 -0
  254. package/x/timeline/renderers/parts/samplers/audio/parts/init.js +40 -0
  255. package/x/timeline/renderers/parts/samplers/audio/parts/init.js.map +1 -0
  256. package/x/timeline/renderers/parts/samplers/audio/parts/sink.d.ts +8 -0
  257. package/x/timeline/renderers/parts/samplers/audio/parts/sink.js +24 -0
  258. package/x/timeline/renderers/parts/samplers/audio/parts/sink.js.map +1 -0
  259. package/x/timeline/renderers/parts/samplers/audio/parts/types.d.ts +14 -0
  260. package/x/timeline/renderers/parts/samplers/audio/parts/types.js +2 -0
  261. package/x/timeline/renderers/parts/samplers/audio/parts/types.js.map +1 -0
  262. package/x/timeline/renderers/parts/samplers/audio/sampler.d.ts +11 -0
  263. package/x/timeline/renderers/parts/samplers/audio/sampler.js +22 -0
  264. package/x/timeline/renderers/parts/samplers/audio/sampler.js.map +1 -0
  265. package/x/timeline/renderers/parts/samplers/visual/parts/defaults.d.ts +5 -0
  266. package/x/timeline/renderers/parts/samplers/visual/parts/defaults.js +10 -0
  267. package/x/timeline/renderers/parts/samplers/visual/parts/defaults.js.map +1 -0
  268. package/x/timeline/renderers/parts/samplers/visual/parts/sample.d.ts +6 -0
  269. package/x/timeline/renderers/parts/samplers/visual/parts/sample.js +48 -0
  270. package/x/timeline/renderers/parts/samplers/visual/parts/sample.js.map +1 -0
  271. package/x/timeline/renderers/parts/samplers/visual/parts/sequence.d.ts +6 -0
  272. package/x/timeline/renderers/parts/samplers/visual/parts/sequence.js +75 -0
  273. package/x/timeline/renderers/parts/samplers/visual/parts/sequence.js.map +1 -0
  274. package/x/timeline/renderers/parts/samplers/visual/parts/sink.d.ts +8 -0
  275. package/x/timeline/renderers/parts/samplers/visual/parts/sink.js +24 -0
  276. package/x/timeline/renderers/parts/samplers/visual/parts/sink.js.map +1 -0
  277. package/x/timeline/renderers/parts/samplers/visual/parts/transition.d.ts +3 -0
  278. package/x/timeline/renderers/parts/samplers/visual/parts/transition.js +18 -0
  279. package/x/timeline/renderers/parts/samplers/visual/parts/transition.js.map +1 -0
  280. package/x/timeline/renderers/parts/samplers/visual/parts/types.d.ts +8 -0
  281. package/x/timeline/renderers/parts/samplers/visual/parts/types.js +2 -0
  282. package/x/timeline/renderers/parts/samplers/visual/parts/types.js.map +1 -0
  283. package/x/timeline/renderers/parts/samplers/visual/sampler.d.ts +7 -0
  284. package/x/timeline/renderers/parts/samplers/visual/sampler.js +17 -0
  285. package/x/timeline/renderers/parts/samplers/visual/sampler.js.map +1 -0
  286. package/x/timeline/renderers/parts/schedulers.d.ts +17 -0
  287. package/x/timeline/renderers/parts/schedulers.js +64 -0
  288. package/x/timeline/renderers/parts/schedulers.js.map +1 -0
  289. package/x/timeline/renderers/player/parts/playback.d.ts +36 -0
  290. package/x/timeline/renderers/player/parts/playback.js +113 -0
  291. package/x/timeline/renderers/player/parts/playback.js.map +1 -0
  292. package/x/timeline/renderers/player/player.d.ts +25 -0
  293. package/x/timeline/renderers/player/player.js +56 -0
  294. package/x/timeline/renderers/player/player.js.map +1 -0
  295. package/x/timeline/renderers/renderers.test.d.ts +33 -0
  296. package/x/timeline/renderers/renderers.test.js +321 -0
  297. package/x/timeline/renderers/renderers.test.js.map +1 -0
  298. package/x/timeline/sugar/helpers.d.ts +56 -0
  299. package/x/timeline/sugar/helpers.js +104 -0
  300. package/x/timeline/sugar/helpers.js.map +1 -0
  301. package/x/timeline/sugar/o.d.ts +48 -14
  302. package/x/timeline/sugar/o.js +213 -54
  303. package/x/timeline/sugar/o.js.map +1 -1
  304. package/x/timeline/sugar/omni.d.ts +11 -6
  305. package/x/timeline/sugar/omni.js +28 -8
  306. package/x/timeline/sugar/omni.js.map +1 -1
  307. package/x/timeline/sugar/omni.test.d.ts +27 -0
  308. package/x/timeline/sugar/omni.test.js +128 -0
  309. package/x/timeline/sugar/omni.test.js.map +1 -0
  310. package/x/timeline/types.d.ts +12 -2
  311. package/x/timeline/utils/anim.d.ts +5 -0
  312. package/x/timeline/utils/anim.js +44 -0
  313. package/x/timeline/utils/anim.js.map +1 -0
  314. package/x/timeline/utils/checksum.d.ts +3 -2
  315. package/x/timeline/utils/checksum.js.map +1 -1
  316. package/x/timeline/utils/datafile.d.ts +5 -3
  317. package/x/timeline/utils/datafile.js +18 -5
  318. package/x/timeline/utils/datafile.js.map +1 -1
  319. package/x/timeline/utils/dummy-data.d.ts +1 -2
  320. package/x/timeline/utils/dummy-data.js +4 -2
  321. package/x/timeline/utils/dummy-data.js.map +1 -1
  322. package/x/timeline/utils/matrix.d.ts +9 -0
  323. package/x/timeline/utils/matrix.js +10 -0
  324. package/x/timeline/utils/matrix.js.map +1 -1
  325. package/x/timeline/utils/terps.d.ts +11 -0
  326. package/x/timeline/utils/terps.js +57 -0
  327. package/x/timeline/utils/terps.js.map +1 -0
  328. package/x/units/fps.d.ts +6 -0
  329. package/x/units/fps.js +2 -0
  330. package/x/units/fps.js.map +1 -0
  331. package/x/units/ms.d.ts +6 -0
  332. package/x/units/ms.js +2 -0
  333. package/x/units/ms.js.map +1 -0
  334. package/x/units/seconds.d.ts +6 -0
  335. package/x/units/seconds.js +2 -0
  336. package/x/units/seconds.js.map +1 -0
  337. package/x/webworkerAll-RLCTMSDD.js +2 -0
  338. package/x/webworkerAll-RLCTMSDD.js.map +7 -0
  339. package/s/tests.test.ts +0 -8
  340. package/s/timeline/parts/compositor/export.ts +0 -77
  341. package/s/timeline/parts/compositor/parts/html-tree.ts +0 -37
  342. package/s/timeline/parts/compositor/parts/schedulers.ts +0 -85
  343. package/s/timeline/parts/compositor/parts/tree-builder.ts +0 -184
  344. package/s/timeline/parts/compositor/parts/webcodecs-tree.ts +0 -30
  345. package/s/timeline/parts/compositor/playback.ts +0 -81
  346. package/s/timeline/parts/compositor/samplers/html.ts +0 -115
  347. package/s/timeline/parts/compositor/samplers/webcodecs.ts +0 -60
  348. package/s/timeline/parts/waveform.ts +0 -62
  349. package/s/timeline/sugar/builders.ts +0 -102
  350. package/s/timeline/sugar/omni-test.ts +0 -38
  351. package/s/timeline/timeline.ts +0 -22
  352. package/s/timeline/utils/audio-stream.ts +0 -15
  353. package/s/timeline/utils/video-cursor.ts +0 -40
  354. package/s/tools/common/loader.ts +0 -26
  355. package/s/tools/common/transformer-pipeline.ts +0 -26
  356. package/s/tools/speech-recognition/common/model.ts +0 -26
  357. package/s/tools/speech-recognition/whisper/fns/host.ts +0 -25
  358. package/s/tools/speech-recognition/whisper/fns/schematic.ts +0 -23
  359. package/s/tools/speech-recognition/whisper/fns/work.ts +0 -91
  360. package/s/tools/speech-recognition/whisper/parts/types.ts +0 -38
  361. package/s/tools/speech-recognition/whisper/parts/worker.bundle.ts +0 -7
  362. package/s/tools/speech-recognition/whisper/tool.ts +0 -70
  363. package/x/tests.test.js +0 -6
  364. package/x/tests.test.js.map +0 -1
  365. package/x/timeline/parts/compositor/export.d.ts +0 -9
  366. package/x/timeline/parts/compositor/export.js +0 -64
  367. package/x/timeline/parts/compositor/export.js.map +0 -1
  368. package/x/timeline/parts/compositor/parts/html-tree.d.ts +0 -3
  369. package/x/timeline/parts/compositor/parts/html-tree.js +0 -40
  370. package/x/timeline/parts/compositor/parts/html-tree.js.map +0 -1
  371. package/x/timeline/parts/compositor/parts/schedulers.d.ts +0 -15
  372. package/x/timeline/parts/compositor/parts/schedulers.js +0 -64
  373. package/x/timeline/parts/compositor/parts/schedulers.js.map +0 -1
  374. package/x/timeline/parts/compositor/parts/tree-builder.d.ts +0 -37
  375. package/x/timeline/parts/compositor/parts/tree-builder.js +0 -147
  376. package/x/timeline/parts/compositor/parts/tree-builder.js.map +0 -1
  377. package/x/timeline/parts/compositor/parts/webcodecs-tree.d.ts +0 -3
  378. package/x/timeline/parts/compositor/parts/webcodecs-tree.js +0 -28
  379. package/x/timeline/parts/compositor/parts/webcodecs-tree.js.map +0 -1
  380. package/x/timeline/parts/compositor/playback.d.ts +0 -19
  381. package/x/timeline/parts/compositor/playback.js +0 -71
  382. package/x/timeline/parts/compositor/playback.js.map +0 -1
  383. package/x/timeline/parts/compositor/samplers/html.d.ts +0 -3
  384. package/x/timeline/parts/compositor/samplers/html.js +0 -106
  385. package/x/timeline/parts/compositor/samplers/html.js.map +0 -1
  386. package/x/timeline/parts/compositor/samplers/webcodecs.d.ts +0 -2
  387. package/x/timeline/parts/compositor/samplers/webcodecs.js +0 -55
  388. package/x/timeline/parts/compositor/samplers/webcodecs.js.map +0 -1
  389. package/x/timeline/parts/waveform.d.ts +0 -8
  390. package/x/timeline/parts/waveform.js +0 -51
  391. package/x/timeline/parts/waveform.js.map +0 -1
  392. package/x/timeline/sugar/builders.d.ts +0 -96
  393. package/x/timeline/sugar/builders.js +0 -108
  394. package/x/timeline/sugar/builders.js.map +0 -1
  395. package/x/timeline/sugar/omni-test.d.ts +0 -1
  396. package/x/timeline/sugar/omni-test.js +0 -22
  397. package/x/timeline/sugar/omni-test.js.map +0 -1
  398. package/x/timeline/timeline.d.ts +0 -9
  399. package/x/timeline/timeline.js +0 -22
  400. package/x/timeline/timeline.js.map +0 -1
  401. package/x/timeline/utils/audio-stream.d.ts +0 -6
  402. package/x/timeline/utils/audio-stream.js +0 -17
  403. package/x/timeline/utils/audio-stream.js.map +0 -1
  404. package/x/timeline/utils/video-cursor.d.ts +0 -10
  405. package/x/timeline/utils/video-cursor.js +0 -36
  406. package/x/timeline/utils/video-cursor.js.map +0 -1
  407. package/x/tools/common/loader.d.ts +0 -19
  408. package/x/tools/common/loader.js +0 -18
  409. package/x/tools/common/loader.js.map +0 -1
  410. package/x/tools/common/transformer-pipeline.d.ts +0 -8
  411. package/x/tools/common/transformer-pipeline.js +0 -24
  412. package/x/tools/common/transformer-pipeline.js.map +0 -1
  413. package/x/tools/speech-recognition/common/model.d.ts +0 -14
  414. package/x/tools/speech-recognition/common/model.js +0 -16
  415. package/x/tools/speech-recognition/common/model.js.map +0 -1
  416. package/x/tools/speech-recognition/whisper/fns/host.d.ts +0 -13
  417. package/x/tools/speech-recognition/whisper/fns/host.js +0 -19
  418. package/x/tools/speech-recognition/whisper/fns/host.js.map +0 -1
  419. package/x/tools/speech-recognition/whisper/fns/schematic.d.ts +0 -19
  420. package/x/tools/speech-recognition/whisper/fns/schematic.js +0 -2
  421. package/x/tools/speech-recognition/whisper/fns/schematic.js.map +0 -1
  422. package/x/tools/speech-recognition/whisper/fns/work.d.ts +0 -12
  423. package/x/tools/speech-recognition/whisper/fns/work.js +0 -74
  424. package/x/tools/speech-recognition/whisper/fns/work.js.map +0 -1
  425. package/x/tools/speech-recognition/whisper/parts/types.d.ts +0 -31
  426. package/x/tools/speech-recognition/whisper/parts/types.js.map +0 -1
  427. package/x/tools/speech-recognition/whisper/parts/worker.bundle.d.ts +0 -1
  428. package/x/tools/speech-recognition/whisper/parts/worker.bundle.js +0 -4
  429. package/x/tools/speech-recognition/whisper/parts/worker.bundle.js.map +0 -1
  430. package/x/tools/speech-recognition/whisper/parts/worker.bundle.min.js +0 -8
  431. package/x/tools/speech-recognition/whisper/parts/worker.bundle.min.js.map +0 -7
  432. package/x/tools/speech-recognition/whisper/tool.d.ts +0 -12
  433. package/x/tools/speech-recognition/whisper/tool.js +0 -63
  434. package/x/tools/speech-recognition/whisper/tool.js.map +0 -1
  435. /package/x/{tests.test.d.ts → tests.bundle.d.ts} +0 -0
  436. /package/x/{tools/speech-recognition/whisper → timeline/parts/waveform}/parts/types.js +0 -0
package/s/demo/demo.css CHANGED
@@ -1,11 +1,16 @@
1
1
 
2
- @layer vars, basics, page;
2
+ @layer vars, basics, page, demo;
3
3
 
4
4
  @layer vars {
5
5
  :root {
6
- --link: cyan;
7
- --color: #fffa;
8
- --background: #111;
6
+ --ink: #f2f4f8;
7
+ --muted: #9fb0c3;
8
+ --surface: #0f141c;
9
+ --panel: #121a26;
10
+ --accent: #2cffd7;
11
+ --accent-2: #ff9a3c;
12
+ --border: color-mix(in oklab, #ffffff 10%, transparent);
13
+ --shadow: 0 20px 60px #00000066;
9
14
  }
10
15
  }
11
16
 
@@ -20,16 +25,20 @@
20
25
  @layer page {
21
26
  html {
22
27
  font-size: 10px;
23
- color: var(--color);
24
- background: var(--background);
28
+ color: var(--ink);
29
+ background:
30
+ radial-gradient(1200px 600px at 10% -10%, #1f314e 0%, transparent 60%),
31
+ radial-gradient(800px 500px at 90% -20%, #2a1f4e 0%, transparent 55%),
32
+ linear-gradient(160deg, #0a0f16 0%, #0b1018 45%, #0b0f14 100%);
33
+ font-family: "Space Grotesk", system-ui, sans-serif;
25
34
  }
26
35
 
27
36
  body {
28
- padding: 2em;
37
+ padding: 3.2em;
29
38
  }
30
39
 
31
40
  .results {
32
- margin-top: 1em;
41
+ margin-top: 2em;
33
42
 
34
43
  display: flex;
35
44
  flex-direction: column;
@@ -37,8 +46,10 @@
37
46
 
38
47
  > div {
39
48
  font-size: 1.5em;
40
- border: 1px solid color-mix(in lch, transparent, var(--color) 20%);
49
+ border: 1px solid var(--border);
41
50
  padding: 1em;
51
+ background: var(--panel);
52
+ box-shadow: var(--shadow);
42
53
  }
43
54
 
44
55
  canvas {
@@ -46,14 +57,233 @@
46
57
  }
47
58
  }
48
59
 
49
- canvas {
50
- width: 500px;
51
- height: 300px;
60
+ }
61
+
62
+ @layer demo {
63
+ .hero {
64
+ display: flex;
65
+ align-items: center;
66
+ justify-content: space-between;
67
+ gap: 2em;
68
+ margin-bottom: 2.4em;
69
+ }
70
+
71
+ .hero h1 {
72
+ font-family: "Share Tech", system-ui, sans-serif;
73
+ font-size: 3.4em;
74
+ letter-spacing: 0.05em;
75
+ text-transform: uppercase;
76
+ }
77
+
78
+ .hero h1 small {
79
+ font-size: 0.5em;
80
+ color: var(--muted);
81
+ }
82
+
83
+ .hero p {
84
+ font-size: 1.4em;
85
+ color: var(--muted);
86
+ margin-top: 0.6em;
87
+ max-width: 60ch;
88
+ }
89
+
90
+ .demo-grid {
91
+ display: grid;
92
+ grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
93
+ gap: 1.8em;
94
+ margin-bottom: 2.4em;
95
+ }
96
+
97
+ .demo-card {
98
+ background: linear-gradient(160deg, #111a25 0%, #0f1620 60%, #0d121a 100%);
99
+ border: 1px solid var(--border);
100
+ border-radius: 16px;
101
+ padding: 1.6em;
102
+ box-shadow: var(--shadow);
103
+ display: grid;
104
+ gap: 1.2em;
105
+ }
106
+
107
+ .demo-card h2 {
108
+ font-size: 1.8em;
109
+ letter-spacing: 0.03em;
110
+ }
111
+
112
+ .demo-card p {
113
+ color: var(--muted);
114
+ font-size: 1.2em;
115
+ }
116
+
117
+ .demo-controls {
118
+ display: grid;
119
+ gap: 0.8em;
120
+ }
121
+
122
+ .demo-progress {
123
+ display: grid;
124
+ grid-template-columns: 1fr auto;
125
+ align-items: center;
126
+ gap: 0.8em;
127
+ font-size: 1.1em;
128
+ color: var(--muted);
129
+ }
130
+
131
+ .demo-progress .status {
132
+ letter-spacing: 0.06em;
133
+ text-transform: uppercase;
134
+ font-size: 0.9em;
135
+ }
136
+
137
+ progress.progress {
138
+ width: 100%;
139
+ height: 10px;
140
+ border-radius: 999px;
141
+ overflow: hidden;
142
+ background: #0b1118;
143
+ border: 1px solid var(--border);
144
+ }
145
+
146
+ progress.progress::-webkit-progress-bar {
147
+ background: #0b1118;
148
+ }
149
+
150
+ progress.progress::-webkit-progress-value {
151
+ background: linear-gradient(120deg, var(--accent), #4df1ff);
152
+ }
153
+
154
+ progress.progress::-moz-progress-bar {
155
+ background: linear-gradient(120deg, var(--accent), #4df1ff);
156
+ }
157
+
158
+ .demo-preview {
159
+ border: 1px solid var(--border);
160
+ border-radius: 12px;
161
+ min-height: 160px;
162
+ background: #0b1118;
163
+ display: grid;
164
+ place-items: center;
165
+ overflow: hidden;
166
+ }
167
+
168
+ .demo-preview canvas {
169
+ width: 100%;
170
+ height: auto;
52
171
  }
53
172
 
54
- #filmstrip {
173
+ .filmstrip-controls,
174
+ .waveform-controls {
175
+ display: grid;
176
+ gap: 0.6em;
177
+ font-size: 1.1em;
178
+ color: var(--muted);
179
+ }
180
+
181
+ .filmstrip-controls input[type="range"],
182
+ .waveform-controls input[type="range"] {
183
+ width: 100%;
184
+ }
185
+
186
+ input[type="file"] {
187
+ background: #0b111a;
188
+ color: var(--ink);
189
+ border: 1px dashed #2b3b52;
190
+ border-radius: 10px;
191
+ padding: 0.8em;
192
+ font-size: 1.2em;
193
+ }
194
+
195
+ button {
196
+ background: linear-gradient(120deg, var(--accent), #4df1ff);
197
+ border: none;
198
+ color: #0a0f14;
199
+ font-weight: 600;
200
+ letter-spacing: 0.03em;
201
+ border-radius: 10px;
202
+ padding: 0.8em 1.2em;
203
+ cursor: pointer;
204
+ transition: transform 120ms ease, box-shadow 120ms ease;
205
+ box-shadow: 0 10px 20px #00ffd533;
206
+ }
207
+
208
+ button[data-action="export"] {
209
+ background: linear-gradient(120deg, var(--accent-2), #ffd479);
210
+ box-shadow: 0 10px 20px #ffb35a33;
211
+ }
212
+
213
+ button:disabled {
214
+ opacity: 0.6;
215
+ cursor: not-allowed;
216
+ transform: none;
217
+ box-shadow: none;
218
+ }
219
+
220
+ button:not(:disabled):hover {
221
+ transform: translateY(-1px);
222
+ }
223
+
224
+ .filmstrip {
55
225
  display: flex;
56
226
  overflow-x: scroll;
227
+ gap: 0.4em;
228
+ padding: 0.4em 0;
229
+ }
230
+
231
+ .player {
232
+ margin-top: 1.2em;
233
+ display: grid;
234
+ gap: 0.8em;
57
235
  }
58
- }
59
236
 
237
+ .player .timeline {
238
+ display: grid;
239
+ gap: 0.6em;
240
+ }
241
+
242
+ .player .track {
243
+ position: relative;
244
+ height: 10px;
245
+ border-radius: 999px;
246
+ background:
247
+ linear-gradient(90deg, #1e1e1e, #1a1a1a),
248
+ repeating-linear-gradient(90deg, #ffffff14 0 6px, transparent 6px 12px);
249
+ border: 1px solid #ffffff22;
250
+ overflow: hidden;
251
+ }
252
+
253
+ .player .playhead {
254
+ position: absolute;
255
+ left: 0%;
256
+ top: -6px;
257
+ width: 2px;
258
+ height: 22px;
259
+ background: #3cff9c;
260
+ box-shadow: 0 0 12px #3cff9c99;
261
+ }
262
+
263
+ .player .scrub {
264
+ width: 100%;
265
+ }
266
+
267
+ .player .timecode {
268
+ font-size: 1.2em;
269
+ letter-spacing: 0.06em;
270
+ color: #c7ffe3;
271
+ }
272
+
273
+ .player .controls {
274
+ display: flex;
275
+ gap: 0.8em;
276
+ }
277
+
278
+ .player-canvas {
279
+ border: 1px solid var(--border);
280
+ border-radius: 10px;
281
+ padding: 0.6em;
282
+ background: #0b1118;
283
+ }
284
+
285
+ canvas {
286
+ width: 100%;
287
+ height: auto;
288
+ }
289
+ }
@@ -0,0 +1,16 @@
1
+ import {Omni, TimelineFile} from "../../timeline/index.js"
2
+
3
+ export function exportTest(
4
+ omni: Omni,
5
+ timeline: TimelineFile,
6
+ exportButton: HTMLButtonElement,
7
+ onStatus?: (state: "running" | "done") => void
8
+ ) {
9
+ exportButton.addEventListener("click", () => {
10
+ onStatus?.("running")
11
+ omni.render(timeline).then(() => {
12
+ console.log("done")
13
+ onStatus?.("done")
14
+ })
15
+ })
16
+ }
@@ -1,14 +1,16 @@
1
1
  import {Filmstrip} from "../../timeline/parts/filmstrip.js"
2
2
 
3
- export async function filmstripTest(file: File) {
4
- const rangeSlider = document.querySelector(".range") as HTMLInputElement
5
- const rangeView = document.querySelector(".range-view")!
6
- const rangeSizeSlider = document.querySelector(".range-size")! as HTMLInputElement
7
- const frequencySlider = document.querySelector(".frequency")! as HTMLInputElement
8
- const frequencyView = document.querySelector(".frequency-view")!
9
- const container = document.querySelector("#filmstrip")!
10
- const FPS_10 = 1000/10 / 1000
3
+ export async function filmstripTest(file: File, root: HTMLElement) {
4
+ const rangeSlider = root.querySelector(".range") as HTMLInputElement
5
+ const rangeView = root.querySelector(".range-view")!
6
+ const rangeSizeSlider = root.querySelector(".range-size")! as HTMLInputElement
7
+ const frequencySlider = root.querySelector(".frequency")! as HTMLInputElement
8
+ const frequencyView = root.querySelector(".frequency-view")!
9
+ const container = root.querySelector(".filmstrip")!
10
+ const FPS_10 = 1 / 10
11
11
  let rangeSize = 0.5
12
+ container.replaceChildren()
13
+
12
14
  const filmstrip = await Filmstrip.init(
13
15
  file,
14
16
  {
@@ -27,22 +29,24 @@ export async function filmstripTest(file: File) {
27
29
  fit: "fill"
28
30
  }
29
31
  }
30
- )
31
- rangeSizeSlider.addEventListener("change", () => {
32
+ )
33
+ rangeSizeSlider.oninput = () => {
32
34
  rangeSize = +rangeSizeSlider.value
33
- const [start, end] = [+rangeSlider.value, +rangeSlider.value+rangeSize]
35
+ const start = +rangeSlider.value
36
+ const end = start + rangeSize
34
37
  filmstrip.range = [start, end]
35
38
  rangeView.textContent = `visible time range: [${start}, ${end}]`
36
- })
37
- rangeSlider.addEventListener("change", () => {
38
- const [start, end] = [+rangeSlider.value, +rangeSlider.value+rangeSize]
39
+ }
40
+ rangeSlider.oninput = () => {
41
+ const start = +rangeSlider.value
42
+ const end = start + rangeSize
39
43
  filmstrip.range = [start, end]
40
44
  rangeView.textContent = `visible time range: [${start}, ${end}]`
41
- })
42
- frequencySlider.addEventListener("change", () => {
43
- filmstrip.frequency = 1000/+frequencySlider.value/1000
45
+ }
46
+ frequencySlider.oninput = () => {
47
+ filmstrip.frequency = 1 / +frequencySlider.value
44
48
  frequencyView.textContent = `frame every ${filmstrip.frequency.toFixed(3)} second (${frequencySlider.value} frames per second)`
45
- })
49
+ }
46
50
  filmstrip.range = [10, 10.5]
47
51
  }
48
52
 
@@ -1,7 +1,6 @@
1
1
 
2
- export async function loadVideo(url: string): Promise<ArrayBuffer> {
2
+ export async function loadVideo(url: string) {
3
3
  return fetch(url)
4
- .then(response => response.bytes())
5
- .then(bytes => bytes.buffer)
4
+ .then(response => response.blob())
6
5
  }
7
6
 
@@ -0,0 +1,61 @@
1
+
2
+ import {O, Omni, TimelineFile} from "../../timeline/index.js"
3
+
4
+ export async function playbackTest(timeline: TimelineFile, omni: Omni, root: HTMLElement) {
5
+ const playButton = root.querySelector(".play") as HTMLButtonElement
6
+ const stopButton = root.querySelector(".stop") as HTMLButtonElement
7
+ const scrub = root.querySelector(".scrub") as HTMLInputElement
8
+ const playhead = root.querySelector(".playhead") as HTMLDivElement
9
+ const timecode = root.querySelector(".timecode") as HTMLDivElement
10
+ const canvasSlot = root.querySelector(".player-canvas") as HTMLDivElement
11
+ const o = new O({timeline})
12
+ const player = await omni.playback(timeline)
13
+ canvasSlot.replaceChildren(player.canvas)
14
+
15
+ playButton.disabled = false
16
+ stopButton.disabled = false
17
+
18
+ playButton.addEventListener("click", () => player.play())
19
+ stopButton.addEventListener("click", () => player.pause())
20
+ scrub.max = String(Math.ceil(player.duration))
21
+
22
+ let isScrubbing = false
23
+
24
+ player.playback.onTick.on(() => setScrubState(player.currentTime, player.duration))
25
+
26
+ const updateTimecode = (currentMs: number, durationMs: number) => {
27
+ timecode.textContent = `${formatTime(currentMs)} / ${formatTime(durationMs)}`
28
+ }
29
+
30
+ scrub.addEventListener("input", async () => {
31
+ isScrubbing = true
32
+ const next = Math.max(0, Math.min(+scrub.value, player.duration))
33
+ updateTimecode(next, player.duration)
34
+ await player.seek(next)
35
+ })
36
+
37
+ scrub.addEventListener("change", async () => {
38
+ isScrubbing = false
39
+ const next = Math.max(0, Math.min(+scrub.value, player.duration))
40
+ await player.seek(next)
41
+ })
42
+
43
+ const setScrubState = (timeMs: number, durationMs: number) => {
44
+ const clamped = Math.max(0, Math.min(timeMs, durationMs))
45
+ if (!isScrubbing) scrub.value = String(Math.round(clamped))
46
+ const progress = durationMs ? (clamped / durationMs) * 100 : 0
47
+ playhead.style.left = `${progress}%`
48
+ updateTimecode(clamped, durationMs)
49
+ }
50
+
51
+ player.update(o.timeline)
52
+ }
53
+
54
+ function formatTime(ms: number) {
55
+ const clamped = Math.max(0, ms)
56
+ const totalSeconds = Math.floor(clamped / 1000)
57
+ const minutes = Math.floor(totalSeconds / 60)
58
+ const seconds = totalSeconds % 60
59
+ const millis = Math.floor(clamped % 1000)
60
+ return `${minutes}:${String(seconds).padStart(2, "0")}.${String(millis).padStart(3, "0")}`
61
+ }
@@ -0,0 +1,50 @@
1
+
2
+ import {Driver} from "../../driver/driver.js"
3
+ import {Datafile, Item, Omni} from "../../timeline/index.js"
4
+
5
+ export async function TimelineSchemaTest(driver: Driver, file: File) {
6
+ const omni = new Omni(driver)
7
+ const {videoA} = await omni.load({videoA: Datafile.make(file)})
8
+ const timeline = omni.timeline(o => {
9
+ const text = o.text("content", {duration: 3000})
10
+ const fade = o.animate.opacity.make("easeIn", [
11
+ [0, 0],
12
+ [700, 1],
13
+ [2200, 1],
14
+ [3000, 0.35],
15
+ ])
16
+ const style = o.textStyle({fill: "green", fontSize: 100})
17
+ const videoSpatial = o.spatial(
18
+ o.transform({
19
+ position: [240, 160],
20
+ scale: [1.4, 1.4],
21
+ rotation: 0.08,
22
+ }),
23
+ [0.15, 0.1, 0.05, 0.2],
24
+ )
25
+ const textSpatial = o.animatedSpatial(
26
+ o.anim.transform("linear", [
27
+ [0, o.transform({position: [-320, 80], scale: [0.7, 0.7]})],
28
+ [1000, o.transform({position: [120, 80], scale: [1, 1]})],
29
+ [2000, o.transform({position: [200, 40], scale: [1.35, 1.35], rotation: 8})],
30
+ [3000, o.transform({position: [320, 0], scale: [1.15, 1.15], rotation: 0})],
31
+ ]),
32
+ )
33
+
34
+ const video = o.video(videoA, {duration: 3000, start: 1000})
35
+ o.set<Item.Text>(text.id, {styleId: style.id, spatialId: textSpatial.id, animationId: fade.id})
36
+ o.set<Item.Video>(video.id, {spatialId: videoSpatial.id})
37
+
38
+ return o.sequence(
39
+ o.stack(
40
+ text,
41
+ video,
42
+ o.audio(videoA, {duration: 1000})
43
+ ),
44
+ o.gap(500),
45
+ o.video(videoA, {duration: 7000, start: 5000})
46
+ )
47
+ })
48
+
49
+ return {timeline, omni}
50
+ }
@@ -1,3 +1,4 @@
1
+
1
2
  import {Driver} from "../../driver/driver.js"
2
3
  import {DecoderSource} from "../../driver/fns/schematic.js"
3
4
 
@@ -15,14 +16,18 @@ export function setupTranscodeTest(driver: Driver, source: DecoderSource) {
15
16
  async onFrame(frame) {
16
17
  const composed = await driver.composite([
17
18
  {
19
+ id: 0,
18
20
  kind: "image",
19
21
  frame
20
22
  },
21
23
  {
24
+ id: 1,
22
25
  kind: "text",
23
26
  content: "omnitool",
24
- fontSize: 50,
25
- color: "green"
27
+ style: {
28
+ fontSize: 50,
29
+ fill: "green"
30
+ }
26
31
  }
27
32
  ])
28
33
  frame.close()
@@ -32,15 +37,24 @@ export function setupTranscodeTest(driver: Driver, source: DecoderSource) {
32
37
  })
33
38
  const audio = driver.decodeAudio({source})
34
39
 
35
- await driver.encode({
36
- video,
37
- audio,
40
+ const {readable, done} = driver.encode({
41
+ video: video.readable,
42
+ audio: audio.readable,
38
43
  config: {
39
44
  audio: {codec: "opus", bitrate: 128000},
40
45
  video: {codec: "vp9", bitrate: 1000000}
41
46
  }
42
47
  })
48
+
49
+ const handle = await window.showSaveFilePicker()
50
+ const writable = await handle.createWritable()
51
+
52
+ await Promise.all([
53
+ readable.pipeTo(writable),
54
+ done
55
+ ])
43
56
  }
44
57
 
45
58
  return {canvas, run}
46
59
  }
60
+
@@ -30,8 +30,8 @@ export async function setupTransitionsTest(driver: Driver, source: DecoderSource
30
30
  }
31
31
  })
32
32
 
33
- await driver.encode({
34
- video,
33
+ driver.encode({
34
+ video: video.readable,
35
35
  config: {
36
36
  audio: {codec: "opus", bitrate: 128000},
37
37
  video: {codec: "vp9", bitrate: 1000000}
@@ -1,12 +1,39 @@
1
- import {Waveform} from "../../timeline/parts/waveform.js"
2
1
 
3
- export async function waveformTest() {
4
- const container = document.querySelector(".waveform-demo") as HTMLElement
5
- const widthSlider = document.querySelector(".width") as HTMLInputElement
6
- const waveform = await Waveform.init("/assets/temp/gl.mp4", container)
2
+ import {Driver} from "../../driver/driver.js"
3
+ import {Waveform} from "../../timeline/parts/waveform/waveform.js"
7
4
 
8
- widthSlider.addEventListener("change", () => {
9
- const width = +widthSlider.value
10
- waveform.width = width
5
+ export async function waveformTest(driver: Driver, source: File, root: HTMLElement) {
6
+ const container = root.querySelector(".waveform-canvas") as HTMLDivElement
7
+ const widthSlider = root.querySelector(".width") as HTMLInputElement
8
+
9
+ container.replaceChildren()
10
+ container.style.position = "relative"
11
+ container.style.height = "96px"
12
+ container.style.overflow = "hidden"
13
+
14
+ const waveform = await Waveform.init(driver, source, {
15
+ tileHeight: 96,
16
+ onChange: () => renderTiles()
11
17
  })
18
+
19
+ const renderTiles = () => {
20
+ const width = +widthSlider.value
21
+ const zoom = pixelsPerSecond(width, waveform.duration)
22
+ waveform.zoom = zoom
23
+ container.style.width = `${width}px`
24
+ container.replaceChildren(...[...waveform.getTiles().values()].map(tile => {
25
+ tile.canvas.style.position = "absolute"
26
+ tile.canvas.style.top = "0"
27
+ tile.canvas.style.left = `${tile.startTime * pixelsPerSecond(width, waveform.duration)}px`
28
+ tile.canvas.style.height = "100%"
29
+ return tile.canvas
30
+ }))
31
+ }
32
+
33
+ widthSlider.oninput = renderTiles
34
+ waveform.range = [0, waveform.duration]
35
+ }
36
+
37
+ function pixelsPerSecond(width: number, duration: number) {
38
+ return duration > 0 ? width / duration : 0
12
39
  }
@@ -0,0 +1,9 @@
1
+
2
+ import {Comrade} from "@e280/comrade"
3
+ import {setupDriverWork} from "./fns/work.js"
4
+ import {DriverSchematic} from "./fns/schematic.js"
5
+
6
+ export async function driverWorker() {
7
+ await Comrade.worker<DriverSchematic>(setupDriverWork)
8
+ }
9
+
@@ -5,7 +5,7 @@ import {Science, test, expect} from "@e280/science"
5
5
  const workerUrl = new URL("./driver.worker.bundle.js", import.meta.url)
6
6
 
7
7
  export default Science.suite({
8
- "driver hello world": test(async() => {
8
+ "driver hello world": test.skip(async() => {
9
9
  const driver = await Driver.setup({workerUrl})
10
10
  expect(driver.machina.count).is(0)
11
11
  await driver.thread.work.hello()