-
Notifications
You must be signed in to change notification settings - Fork 1
/
rlottie-worker.js
90 lines (75 loc) · 2.96 KB
/
rlottie-worker.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
importScripts('rlottie-wasm.js');
var RLottieWasm = (function () {
// create a object;
var obj = {};
// object content.
obj.Api = {};
obj.lottieHandle = 0;
// keep the api list
function initApi() {
obj.Api = {
init: Module.cwrap('lottie_init', '', []),
destroy: Module.cwrap('lottie_destroy', '', ['number']),
resize: Module.cwrap('lottie_resize', '', ['number', 'number', 'number']),
buffer: Module.cwrap('lottie_buffer', 'number', ['number']),
frameCount: Module.cwrap('lottie_frame_count', 'number', ['number']),
render: Module.cwrap('lottie_render', '', ['number', 'number']),
loadFromData: Module.cwrap('lottie_load_from_data', 'number', ['number', 'number']),
};
}
obj.init = function () {
initApi();
obj.lottieHandle = obj.Api.init();
reply('ready');
reply('info', obj.Api.frameCount(obj.lottieHandle));
}
obj.render = function (frameNo, width, height) {
obj.Api.resize(obj.lottieHandle, width, height);
obj.Api.render(obj.lottieHandle, frameNo);
var bufferPointer = obj.Api.buffer(obj.lottieHandle);
var result = new Uint8ClampedArray(Module.HEAP8.buffer, bufferPointer, width * height * 4);
return result;
}
obj.reload = function (jsString) {
var lengthBytes = lengthBytesUTF8(jsString)+1;
var stringOnWasmHeap = _malloc(lengthBytes);
stringToUTF8(jsString, stringOnWasmHeap, lengthBytes+1);
var len = obj.Api.loadFromData(obj.lottieHandle, stringOnWasmHeap);
}
obj.frameCount = function () {
return obj.Api.frameCount(obj.lottieHandle);
}
return obj;
}());
Module.onRuntimeInitialized = _ => {
RLottieWasm.init();
};
var queryableFunctions = {
// example #1: get the difference between two numbers:
reload: function(jsString) {
RLottieWasm.reload(jsString);
reply('info', RLottieWasm.frameCount());
},
// example #2: wait three seconds
render: function(frameNo, width, height) {
var data = RLottieWasm.render(frameNo, width, height);
var buffer = new Uint8ClampedArray(width * height *4);
buffer.set(data);
reply('result', width, height, buffer, [buffer]);
}
};
function defaultReply(message) {
// your default PUBLIC function executed only when main page calls the queryableWorker.postMessage() method directly
// do something
}
function reply() {
if (arguments.length < 1) { throw new TypeError('reply - not enough arguments'); return; }
postMessage({ 'queryMethodListener': arguments[0], 'queryMethodArguments': Array.prototype.slice.call(arguments, 1) });
}
onmessage = function(oEvent) {
if (oEvent.data instanceof Object && oEvent.data.hasOwnProperty('queryMethod') && oEvent.data.hasOwnProperty('queryMethodArguments')) {
queryableFunctions[oEvent.data.queryMethod].apply(self, oEvent.data.queryMethodArguments);
} else {
defaultReply(oEvent.data);
}
};