forked from webaverse-studios/avatars-wasm
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathworker.cc
125 lines (103 loc) · 4.57 KB
/
worker.cc
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
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
#include <emscripten.h>
// #include "geometry.h"
// #include "compose.h"
// #include "noise.h"
// #include "march.h"
// #include "collide.h"
#include "physics.h"
#include "meshoptimizer/meshoptimizer.h"
#include "vector.h"
// #include "convex.h"
// #include "earcut.h"
// #include <iostream>
// #include "cut.h"
#include <deque>
#include <map>
extern "C" {
// memory
EMSCRIPTEN_KEEPALIVE void *doMalloc(size_t size) {
return malloc(size);
}
EMSCRIPTEN_KEEPALIVE void doFree(void *ptr) {
free(ptr);
}
//
EMSCRIPTEN_KEEPALIVE void initialize() {
physicsBase = new PBase();
}
//
EMSCRIPTEN_KEEPALIVE PBase *makePhysicsBase() {
return new PBase();
}
EMSCRIPTEN_KEEPALIVE void cookGeometryPhysics(float *positions, unsigned int *indices, unsigned int numPositions, unsigned int numIndices, uint8_t **data, unsigned int *length, PxDefaultMemoryOutputStream **writeStream) {
physicsBase->cookGeometry(positions, indices, numPositions, numIndices, data, length, writeStream);
}
EMSCRIPTEN_KEEPALIVE void cookConvexGeometryPhysics(float *positions, unsigned int *indices, unsigned int numPositions, unsigned int numIndices, uint8_t **data, unsigned int *length, PxDefaultMemoryOutputStream **writeStream) {
physicsBase->cookConvexGeometry(positions, indices, numPositions, numIndices, data, length, writeStream);
}
EMSCRIPTEN_KEEPALIVE void cookHeightFieldGeometryPhysics(unsigned int numRows, unsigned int numColumns, int16_t *scratchStack, uint8_t **data, unsigned int *length, PxDefaultMemoryOutputStream **writeStream) {
physicsBase->cookHeightFieldGeometry(numRows, numColumns, scratchStack, data, length, writeStream);
}
EMSCRIPTEN_KEEPALIVE void deleteMemoryOutputStream(PxDefaultMemoryOutputStream *writeStream) {
delete writeStream;
}
//
/* class PositionUV {
public:
Vec position;
Vec2 uv;
}; */
//
// MESHOPTIMIZER_API size_t meshopt_simplify(unsigned int* destination, const unsigned int* indices, size_t index_count, const float* vertex_positions, size_t vertex_count, size_t vertex_positions_stride, size_t target_index_count, float target_error, unsigned int options, float* result_error);
EMSCRIPTEN_KEEPALIVE void meshoptSimplify(
const unsigned int* indices,
size_t index_count,
const float* vertex_positions,
size_t vertex_count,
// const float* uvs,
size_t target_index_count,
float target_error,
unsigned int **destination,
unsigned int *numDestinations
) {
/* std::vector<PositionUV> positionUvs(vertex_count);
for (size_t i = 0; i < vertex_count; i++) {
positionUvs[i].position = Vec{vertex_positions[i * 3], vertex_positions[i * 3 + 1], vertex_positions[i * 3 + 2]};
positionUvs[i].uv = Vec2{uvs[i * 2], uvs[i * 2 + 1]};
} */
*destination = (unsigned int *)malloc(sizeof(unsigned int) * index_count);
const size_t vertex_positions_stride = 3 * sizeof(float);
constexpr unsigned int options = 0;
float result_error;
*numDestinations = meshopt_simplify(*destination, indices, index_count, vertex_positions, vertex_count, vertex_positions_stride, target_index_count, target_error, options, &result_error);
}
// MESHOPTIMIZER_EXPERIMENTAL size_t meshopt_simplifySloppy(unsigned int* destination, const unsigned int* indices, size_t index_count, const float* vertex_positions, size_t vertex_count, size_t vertex_positions_stride, size_t target_index_count, float target_error, float* result_error);
// indices.byteOffset,
// indices.length,
// positions.byteOffset,
// positions.length,
// target_index_count,
// scratchStack.u32.byteOffset,
// scratchStack.u32.byteOffset + Uint32Array.BYTES_PER_ELEMENT
EMSCRIPTEN_KEEPALIVE void meshoptSimplifySloppy(
const unsigned int* indices,
size_t index_count,
const float* vertex_positions,
size_t vertex_count,
// const float* uvs,
size_t target_index_count,
float target_error,
unsigned int **destination,
unsigned int *numDestinations
) {
/* std::vector<PositionUV> positionUvs(vertex_count);
for (size_t i = 0; i < vertex_count; i++) {
positionUvs[i].position = Vec{vertex_positions[i * 3], vertex_positions[i * 3 + 1], vertex_positions[i * 3 + 2]};
positionUvs[i].uv = Vec2{uvs[i * 2], uvs[i * 2 + 1]};
} */
*destination = (unsigned int *)malloc(sizeof(unsigned int) * index_count);
const size_t vertex_positions_stride = 3 * sizeof(float);
float result_error;
*numDestinations = meshopt_simplifySloppy(*destination, indices, index_count, vertex_positions, vertex_count, vertex_positions_stride, target_index_count, target_error, &result_error);
}
} // extern "C"