@loaders.gl/pcd 4.0.0-alpha.5 → 4.0.0-alpha.6
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.
- package/dist/bundle.js +2 -2
- package/dist/dist.min.js +93 -487
- package/dist/es5/bundle.js +6 -0
- package/dist/es5/bundle.js.map +1 -0
- package/dist/es5/index.js +45 -0
- package/dist/es5/index.js.map +1 -0
- package/dist/es5/lib/decompress-lzf.js +57 -0
- package/dist/es5/lib/decompress-lzf.js.map +1 -0
- package/dist/es5/lib/get-pcd-schema.js +54 -0
- package/dist/es5/lib/get-pcd-schema.js.map +1 -0
- package/dist/es5/lib/parse-pcd.js +299 -0
- package/dist/es5/lib/parse-pcd.js.map +1 -0
- package/dist/es5/lib/pcd-types.js +2 -0
- package/dist/es5/lib/pcd-types.js.map +1 -0
- package/dist/es5/pcd-loader.js +21 -0
- package/dist/es5/pcd-loader.js.map +1 -0
- package/dist/es5/workers/pcd-worker.js +6 -0
- package/dist/es5/workers/pcd-worker.js.map +1 -0
- package/dist/esm/bundle.js +4 -0
- package/dist/esm/bundle.js.map +1 -0
- package/dist/esm/index.js +10 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/lib/decompress-lzf.js +51 -0
- package/dist/esm/lib/decompress-lzf.js.map +1 -0
- package/dist/esm/lib/get-pcd-schema.js +48 -0
- package/dist/esm/lib/get-pcd-schema.js.map +1 -0
- package/dist/esm/lib/parse-pcd.js +289 -0
- package/dist/esm/lib/parse-pcd.js.map +1 -0
- package/dist/esm/lib/pcd-types.js +2 -0
- package/dist/esm/lib/pcd-types.js.map +1 -0
- package/dist/esm/pcd-loader.js +14 -0
- package/dist/esm/pcd-loader.js.map +1 -0
- package/dist/esm/workers/pcd-worker.js +4 -0
- package/dist/esm/workers/pcd-worker.js.map +1 -0
- package/dist/index.d.ts +3 -25
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +17 -8
- package/dist/lib/decompress-lzf.d.ts.map +1 -1
- package/dist/lib/decompress-lzf.js +61 -43
- package/dist/lib/get-pcd-schema.d.ts +1 -3
- package/dist/lib/get-pcd-schema.d.ts.map +1 -1
- package/dist/lib/get-pcd-schema.js +32 -19
- package/dist/lib/parse-pcd.d.ts +2 -11
- package/dist/lib/parse-pcd.d.ts.map +1 -1
- package/dist/lib/parse-pcd.js +304 -260
- package/dist/lib/pcd-types.d.ts +12 -12
- package/dist/lib/pcd-types.d.ts.map +1 -1
- package/dist/lib/pcd-types.js +2 -2
- package/dist/pcd-loader.d.ts +3 -14
- package/dist/pcd-loader.d.ts.map +1 -1
- package/dist/pcd-loader.js +21 -14
- package/dist/pcd-worker.js +140 -466
- package/dist/workers/pcd-worker.js +5 -4
- package/package.json +6 -6
- package/src/index.ts +3 -2
- package/src/lib/decompress-lzf.ts +21 -7
- package/src/lib/get-pcd-schema.ts +15 -10
- package/src/lib/parse-pcd.ts +95 -42
- package/src/lib/pcd-types.ts +9 -9
- package/src/pcd-loader.ts +5 -4
- package/dist/bundle.js.map +0 -1
- package/dist/index.js.map +0 -1
- package/dist/lib/decompress-lzf.js.map +0 -1
- package/dist/lib/get-pcd-schema.js.map +0 -1
- package/dist/lib/parse-pcd.js.map +0 -1
- package/dist/lib/pcd-types.js.map +0 -1
- package/dist/pcd-loader.js.map +0 -1
- package/dist/workers/pcd-worker.js.map +0 -1
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
export function decompressLZF(inData, outLength) {
|
|
2
|
+
const inLength = inData.length;
|
|
3
|
+
const outData = new Uint8Array(outLength);
|
|
4
|
+
let inPtr = 0;
|
|
5
|
+
let outPtr = 0;
|
|
6
|
+
let ctrl;
|
|
7
|
+
let len;
|
|
8
|
+
let ref;
|
|
9
|
+
do {
|
|
10
|
+
ctrl = inData[inPtr++];
|
|
11
|
+
if (ctrl < 1 << 5) {
|
|
12
|
+
ctrl++;
|
|
13
|
+
if (outPtr + ctrl > outLength) {
|
|
14
|
+
throw new Error('Output buffer is not large enough');
|
|
15
|
+
}
|
|
16
|
+
if (inPtr + ctrl > inLength) {
|
|
17
|
+
throw new Error('Invalid compressed data');
|
|
18
|
+
}
|
|
19
|
+
do {
|
|
20
|
+
outData[outPtr++] = inData[inPtr++];
|
|
21
|
+
} while (--ctrl);
|
|
22
|
+
} else {
|
|
23
|
+
len = ctrl >> 5;
|
|
24
|
+
ref = outPtr - ((ctrl & 0x1f) << 8) - 1;
|
|
25
|
+
if (inPtr >= inLength) {
|
|
26
|
+
throw new Error('Invalid compressed data');
|
|
27
|
+
}
|
|
28
|
+
if (len === 7) {
|
|
29
|
+
len += inData[inPtr++];
|
|
30
|
+
if (inPtr >= inLength) {
|
|
31
|
+
throw new Error('Invalid compressed data');
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
ref -= inData[inPtr++];
|
|
35
|
+
if (outPtr + len + 2 > outLength) {
|
|
36
|
+
throw new Error('Output buffer is not large enough');
|
|
37
|
+
}
|
|
38
|
+
if (ref < 0) {
|
|
39
|
+
throw new Error('Invalid compressed data');
|
|
40
|
+
}
|
|
41
|
+
if (ref >= outPtr) {
|
|
42
|
+
throw new Error('Invalid compressed data');
|
|
43
|
+
}
|
|
44
|
+
do {
|
|
45
|
+
outData[outPtr++] = outData[ref++];
|
|
46
|
+
} while (--len + 2);
|
|
47
|
+
}
|
|
48
|
+
} while (inPtr < inLength);
|
|
49
|
+
return outData;
|
|
50
|
+
}
|
|
51
|
+
//# sourceMappingURL=decompress-lzf.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"decompress-lzf.js","names":["decompressLZF","inData","outLength","inLength","length","outData","Uint8Array","inPtr","outPtr","ctrl","len","ref","Error"],"sources":["../../../src/lib/decompress-lzf.ts"],"sourcesContent":["/* eslint-disable */\n/**\n * from https://gitlab.com/taketwo/three-pcd-loader/blob/master/decompress-lzf.js\n * @param inData\n * @param outLength\n * @returns\n */\nexport function decompressLZF(inData: Uint8Array, outLength: number): Uint8Array {\n const inLength = inData.length;\n const outData = new Uint8Array(outLength);\n let inPtr = 0;\n let outPtr = 0;\n let ctrl;\n let len;\n let ref;\n\n do {\n ctrl = inData[inPtr++];\n\n if (ctrl < 1 << 5) {\n ctrl++;\n if (outPtr + ctrl > outLength) {\n throw new Error('Output buffer is not large enough');\n }\n if (inPtr + ctrl > inLength) {\n throw new Error('Invalid compressed data');\n }\n\n do {\n outData[outPtr++] = inData[inPtr++];\n } while (--ctrl);\n } else {\n len = ctrl >> 5;\n ref = outPtr - ((ctrl & 0x1f) << 8) - 1;\n if (inPtr >= inLength) {\n throw new Error('Invalid compressed data');\n }\n\n if (len === 7) {\n len += inData[inPtr++];\n if (inPtr >= inLength) {\n throw new Error('Invalid compressed data');\n }\n }\n\n ref -= inData[inPtr++];\n if (outPtr + len + 2 > outLength) {\n throw new Error('Output buffer is not large enough');\n }\n if (ref < 0) {\n throw new Error('Invalid compressed data');\n }\n if (ref >= outPtr) {\n throw new Error('Invalid compressed data');\n }\n\n do {\n outData[outPtr++] = outData[ref++];\n } while (--len + 2);\n }\n } while (inPtr < inLength);\n\n return outData;\n}\n"],"mappings":"AAOA,OAAO,SAASA,aAAaA,CAACC,MAAkB,EAAEC,SAAiB,EAAc;EAC/E,MAAMC,QAAQ,GAAGF,MAAM,CAACG,MAAM;EAC9B,MAAMC,OAAO,GAAG,IAAIC,UAAU,CAACJ,SAAS,CAAC;EACzC,IAAIK,KAAK,GAAG,CAAC;EACb,IAAIC,MAAM,GAAG,CAAC;EACd,IAAIC,IAAI;EACR,IAAIC,GAAG;EACP,IAAIC,GAAG;EAEP,GAAG;IACDF,IAAI,GAAGR,MAAM,CAACM,KAAK,EAAE,CAAC;IAEtB,IAAIE,IAAI,GAAG,CAAC,IAAI,CAAC,EAAE;MACjBA,IAAI,EAAE;MACN,IAAID,MAAM,GAAGC,IAAI,GAAGP,SAAS,EAAE;QAC7B,MAAM,IAAIU,KAAK,CAAC,mCAAmC,CAAC;MACtD;MACA,IAAIL,KAAK,GAAGE,IAAI,GAAGN,QAAQ,EAAE;QAC3B,MAAM,IAAIS,KAAK,CAAC,yBAAyB,CAAC;MAC5C;MAEA,GAAG;QACDP,OAAO,CAACG,MAAM,EAAE,CAAC,GAAGP,MAAM,CAACM,KAAK,EAAE,CAAC;MACrC,CAAC,QAAQ,EAAEE,IAAI;IACjB,CAAC,MAAM;MACLC,GAAG,GAAGD,IAAI,IAAI,CAAC;MACfE,GAAG,GAAGH,MAAM,IAAI,CAACC,IAAI,GAAG,IAAI,KAAK,CAAC,CAAC,GAAG,CAAC;MACvC,IAAIF,KAAK,IAAIJ,QAAQ,EAAE;QACrB,MAAM,IAAIS,KAAK,CAAC,yBAAyB,CAAC;MAC5C;MAEA,IAAIF,GAAG,KAAK,CAAC,EAAE;QACbA,GAAG,IAAIT,MAAM,CAACM,KAAK,EAAE,CAAC;QACtB,IAAIA,KAAK,IAAIJ,QAAQ,EAAE;UACrB,MAAM,IAAIS,KAAK,CAAC,yBAAyB,CAAC;QAC5C;MACF;MAEAD,GAAG,IAAIV,MAAM,CAACM,KAAK,EAAE,CAAC;MACtB,IAAIC,MAAM,GAAGE,GAAG,GAAG,CAAC,GAAGR,SAAS,EAAE;QAChC,MAAM,IAAIU,KAAK,CAAC,mCAAmC,CAAC;MACtD;MACA,IAAID,GAAG,GAAG,CAAC,EAAE;QACX,MAAM,IAAIC,KAAK,CAAC,yBAAyB,CAAC;MAC5C;MACA,IAAID,GAAG,IAAIH,MAAM,EAAE;QACjB,MAAM,IAAII,KAAK,CAAC,yBAAyB,CAAC;MAC5C;MAEA,GAAG;QACDP,OAAO,CAACG,MAAM,EAAE,CAAC,GAAGH,OAAO,CAACM,GAAG,EAAE,CAAC;MACpC,CAAC,QAAQ,EAAED,GAAG,GAAG,CAAC;IACpB;EACF,CAAC,QAAQH,KAAK,GAAGJ,QAAQ;EAEzB,OAAOE,OAAO;AAChB"}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
export function getPCDSchema(PCDheader, metadata) {
|
|
2
|
+
const offset = PCDheader.offset;
|
|
3
|
+
const fields = [];
|
|
4
|
+
if (offset.x !== undefined) {
|
|
5
|
+
fields.push({
|
|
6
|
+
name: 'POSITION',
|
|
7
|
+
type: {
|
|
8
|
+
type: 'fixed-size-list',
|
|
9
|
+
listSize: 3,
|
|
10
|
+
children: [{
|
|
11
|
+
name: 'xyz',
|
|
12
|
+
type: 'float32'
|
|
13
|
+
}]
|
|
14
|
+
}
|
|
15
|
+
});
|
|
16
|
+
}
|
|
17
|
+
if (offset.normal_x !== undefined) {
|
|
18
|
+
fields.push({
|
|
19
|
+
name: 'NORMAL',
|
|
20
|
+
type: {
|
|
21
|
+
type: 'fixed-size-list',
|
|
22
|
+
listSize: 3,
|
|
23
|
+
children: [{
|
|
24
|
+
name: 'xyz',
|
|
25
|
+
type: 'float32'
|
|
26
|
+
}]
|
|
27
|
+
}
|
|
28
|
+
});
|
|
29
|
+
}
|
|
30
|
+
if (offset.rgb !== undefined) {
|
|
31
|
+
fields.push({
|
|
32
|
+
name: 'COLOR_0',
|
|
33
|
+
type: {
|
|
34
|
+
type: 'fixed-size-list',
|
|
35
|
+
listSize: 3,
|
|
36
|
+
children: [{
|
|
37
|
+
name: 'rgb',
|
|
38
|
+
type: 'uint8'
|
|
39
|
+
}]
|
|
40
|
+
}
|
|
41
|
+
});
|
|
42
|
+
}
|
|
43
|
+
return {
|
|
44
|
+
fields,
|
|
45
|
+
metadata
|
|
46
|
+
};
|
|
47
|
+
}
|
|
48
|
+
//# sourceMappingURL=get-pcd-schema.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"get-pcd-schema.js","names":["getPCDSchema","PCDheader","metadata","offset","fields","x","undefined","push","name","type","listSize","children","normal_x","rgb"],"sources":["../../../src/lib/get-pcd-schema.ts"],"sourcesContent":["import {Schema, Field} from '@loaders.gl/schema';\nimport type {PCDHeader} from './pcd-types';\n\n/**\n * Gets schema from PCD header\n * @param PCDheader\n * @param metadata\n * @returns Schema\n */\nexport function getPCDSchema(PCDheader: PCDHeader, metadata: Record<string, string>): Schema {\n const offset = PCDheader.offset;\n\n const fields: Field[] = [];\n\n if (offset.x !== undefined) {\n fields.push({\n name: 'POSITION',\n type: {type: 'fixed-size-list', listSize: 3, children: [{name: 'xyz', type: 'float32'}]}\n });\n }\n\n if (offset.normal_x !== undefined) {\n fields.push({\n name: 'NORMAL',\n type: {type: 'fixed-size-list', listSize: 3, children: [{name: 'xyz', type: 'float32'}]}\n });\n }\n\n if (offset.rgb !== undefined) {\n fields.push({\n name: 'COLOR_0',\n type: {type: 'fixed-size-list', listSize: 3, children: [{name: 'rgb', type: 'uint8'}]}\n });\n }\n\n return {fields, metadata};\n}\n"],"mappings":"AASA,OAAO,SAASA,YAAYA,CAACC,SAAoB,EAAEC,QAAgC,EAAU;EAC3F,MAAMC,MAAM,GAAGF,SAAS,CAACE,MAAM;EAE/B,MAAMC,MAAe,GAAG,EAAE;EAE1B,IAAID,MAAM,CAACE,CAAC,KAAKC,SAAS,EAAE;IAC1BF,MAAM,CAACG,IAAI,CAAC;MACVC,IAAI,EAAE,UAAU;MAChBC,IAAI,EAAE;QAACA,IAAI,EAAE,iBAAiB;QAAEC,QAAQ,EAAE,CAAC;QAAEC,QAAQ,EAAE,CAAC;UAACH,IAAI,EAAE,KAAK;UAAEC,IAAI,EAAE;QAAS,CAAC;MAAC;IACzF,CAAC,CAAC;EACJ;EAEA,IAAIN,MAAM,CAACS,QAAQ,KAAKN,SAAS,EAAE;IACjCF,MAAM,CAACG,IAAI,CAAC;MACVC,IAAI,EAAE,QAAQ;MACdC,IAAI,EAAE;QAACA,IAAI,EAAE,iBAAiB;QAAEC,QAAQ,EAAE,CAAC;QAAEC,QAAQ,EAAE,CAAC;UAACH,IAAI,EAAE,KAAK;UAAEC,IAAI,EAAE;QAAS,CAAC;MAAC;IACzF,CAAC,CAAC;EACJ;EAEA,IAAIN,MAAM,CAACU,GAAG,KAAKP,SAAS,EAAE;IAC5BF,MAAM,CAACG,IAAI,CAAC;MACVC,IAAI,EAAE,SAAS;MACfC,IAAI,EAAE;QAACA,IAAI,EAAE,iBAAiB;QAAEC,QAAQ,EAAE,CAAC;QAAEC,QAAQ,EAAE,CAAC;UAACH,IAAI,EAAE,KAAK;UAAEC,IAAI,EAAE;QAAO,CAAC;MAAC;IACvF,CAAC,CAAC;EACJ;EAEA,OAAO;IAACL,MAAM;IAAEF;EAAQ,CAAC;AAC3B"}
|
|
@@ -0,0 +1,289 @@
|
|
|
1
|
+
import { getMeshBoundingBox } from '@loaders.gl/schema';
|
|
2
|
+
import { decompressLZF } from './decompress-lzf';
|
|
3
|
+
import { getPCDSchema } from './get-pcd-schema';
|
|
4
|
+
const LITTLE_ENDIAN = true;
|
|
5
|
+
export default function parsePCD(data) {
|
|
6
|
+
const textData = new TextDecoder().decode(data);
|
|
7
|
+
const pcdHeader = parsePCDHeader(textData);
|
|
8
|
+
let attributes = {};
|
|
9
|
+
switch (pcdHeader.data) {
|
|
10
|
+
case 'ascii':
|
|
11
|
+
attributes = parsePCDASCII(pcdHeader, textData);
|
|
12
|
+
break;
|
|
13
|
+
case 'binary':
|
|
14
|
+
attributes = parsePCDBinary(pcdHeader, data);
|
|
15
|
+
break;
|
|
16
|
+
case 'binary_compressed':
|
|
17
|
+
attributes = parsePCDBinaryCompressed(pcdHeader, data);
|
|
18
|
+
break;
|
|
19
|
+
default:
|
|
20
|
+
throw new Error("PCD: ".concat(pcdHeader.data, " files are not supported"));
|
|
21
|
+
}
|
|
22
|
+
attributes = getMeshAttributes(attributes);
|
|
23
|
+
const header = getMeshHeader(pcdHeader, attributes);
|
|
24
|
+
const metadata = Object.fromEntries([['mode', '0'], ['boundingBox', JSON.stringify(header.boundingBox)]]);
|
|
25
|
+
const schema = getPCDSchema(pcdHeader, metadata);
|
|
26
|
+
return {
|
|
27
|
+
loader: 'pcd',
|
|
28
|
+
loaderData: pcdHeader,
|
|
29
|
+
header,
|
|
30
|
+
schema,
|
|
31
|
+
mode: 0,
|
|
32
|
+
topology: 'point-list',
|
|
33
|
+
attributes
|
|
34
|
+
};
|
|
35
|
+
}
|
|
36
|
+
function getMeshHeader(pcdHeader, attributes) {
|
|
37
|
+
if (typeof pcdHeader.width === 'number' && typeof pcdHeader.height === 'number') {
|
|
38
|
+
const pointCount = pcdHeader.width * pcdHeader.height;
|
|
39
|
+
return {
|
|
40
|
+
vertexCount: pointCount,
|
|
41
|
+
boundingBox: getMeshBoundingBox(attributes)
|
|
42
|
+
};
|
|
43
|
+
}
|
|
44
|
+
return {
|
|
45
|
+
vertexCount: pcdHeader.vertexCount,
|
|
46
|
+
boundingBox: pcdHeader.boundingBox
|
|
47
|
+
};
|
|
48
|
+
}
|
|
49
|
+
function getMeshAttributes(attributes) {
|
|
50
|
+
const normalizedAttributes = {
|
|
51
|
+
POSITION: {
|
|
52
|
+
value: new Float32Array(attributes.position),
|
|
53
|
+
size: 3
|
|
54
|
+
}
|
|
55
|
+
};
|
|
56
|
+
if (attributes.normal && attributes.normal.length > 0) {
|
|
57
|
+
normalizedAttributes.NORMAL = {
|
|
58
|
+
value: new Float32Array(attributes.normal),
|
|
59
|
+
size: 3
|
|
60
|
+
};
|
|
61
|
+
}
|
|
62
|
+
if (attributes.color && attributes.color.length > 0) {
|
|
63
|
+
normalizedAttributes.COLOR_0 = {
|
|
64
|
+
value: new Uint8Array(attributes.color),
|
|
65
|
+
size: 3
|
|
66
|
+
};
|
|
67
|
+
}
|
|
68
|
+
if (attributes.intensity && attributes.intensity.length > 0) {
|
|
69
|
+
normalizedAttributes.COLOR_0 = {
|
|
70
|
+
value: new Uint8Array(attributes.color),
|
|
71
|
+
size: 3
|
|
72
|
+
};
|
|
73
|
+
}
|
|
74
|
+
if (attributes.label && attributes.label.length > 0) {
|
|
75
|
+
normalizedAttributes.COLOR_0 = {
|
|
76
|
+
value: new Uint8Array(attributes.label),
|
|
77
|
+
size: 3
|
|
78
|
+
};
|
|
79
|
+
}
|
|
80
|
+
return normalizedAttributes;
|
|
81
|
+
}
|
|
82
|
+
function parsePCDHeader(data) {
|
|
83
|
+
const result1 = data.search(/[\r\n]DATA\s(\S*)\s/i);
|
|
84
|
+
const result2 = /[\r\n]DATA\s(\S*)\s/i.exec(data.substr(result1 - 1));
|
|
85
|
+
const pcdHeader = {};
|
|
86
|
+
pcdHeader.data = result2 && result2[1];
|
|
87
|
+
if (result2 !== null) {
|
|
88
|
+
pcdHeader.headerLen = (result2 && result2[0].length) + result1;
|
|
89
|
+
}
|
|
90
|
+
pcdHeader.str = data.substr(0, pcdHeader.headerLen);
|
|
91
|
+
pcdHeader.str = pcdHeader.str.replace(/\#.*/gi, '');
|
|
92
|
+
pcdHeader.version = /VERSION (.*)/i.exec(pcdHeader.str);
|
|
93
|
+
pcdHeader.fields = /FIELDS (.*)/i.exec(pcdHeader.str);
|
|
94
|
+
pcdHeader.size = /SIZE (.*)/i.exec(pcdHeader.str);
|
|
95
|
+
pcdHeader.type = /TYPE (.*)/i.exec(pcdHeader.str);
|
|
96
|
+
pcdHeader.count = /COUNT (.*)/i.exec(pcdHeader.str);
|
|
97
|
+
pcdHeader.width = /WIDTH (.*)/i.exec(pcdHeader.str);
|
|
98
|
+
pcdHeader.height = /HEIGHT (.*)/i.exec(pcdHeader.str);
|
|
99
|
+
pcdHeader.viewpoint = /VIEWPOINT (.*)/i.exec(pcdHeader.str);
|
|
100
|
+
pcdHeader.points = /POINTS (.*)/i.exec(pcdHeader.str);
|
|
101
|
+
if (pcdHeader.version !== null) {
|
|
102
|
+
pcdHeader.version = parseFloat(pcdHeader.version[1]);
|
|
103
|
+
}
|
|
104
|
+
if (pcdHeader.fields !== null) {
|
|
105
|
+
pcdHeader.fields = pcdHeader.fields[1].split(' ');
|
|
106
|
+
}
|
|
107
|
+
if (pcdHeader.type !== null) {
|
|
108
|
+
pcdHeader.type = pcdHeader.type[1].split(' ');
|
|
109
|
+
}
|
|
110
|
+
if (pcdHeader.width !== null) {
|
|
111
|
+
pcdHeader.width = parseInt(pcdHeader.width[1], 10);
|
|
112
|
+
}
|
|
113
|
+
if (pcdHeader.height !== null) {
|
|
114
|
+
pcdHeader.height = parseInt(pcdHeader.height[1], 10);
|
|
115
|
+
}
|
|
116
|
+
if (pcdHeader.viewpoint !== null) {
|
|
117
|
+
pcdHeader.viewpoint = pcdHeader.viewpoint[1];
|
|
118
|
+
}
|
|
119
|
+
if (pcdHeader.points !== null) {
|
|
120
|
+
pcdHeader.points = parseInt(pcdHeader.points[1], 10);
|
|
121
|
+
}
|
|
122
|
+
if (pcdHeader.points === null && typeof pcdHeader.width === 'number' && typeof pcdHeader.height === 'number') {
|
|
123
|
+
pcdHeader.points = pcdHeader.width * pcdHeader.height;
|
|
124
|
+
}
|
|
125
|
+
if (pcdHeader.size !== null) {
|
|
126
|
+
pcdHeader.size = pcdHeader.size[1].split(' ').map(x => parseInt(x, 10));
|
|
127
|
+
}
|
|
128
|
+
if (pcdHeader.count !== null) {
|
|
129
|
+
pcdHeader.count = pcdHeader.count[1].split(' ').map(x => parseInt(x, 10));
|
|
130
|
+
} else {
|
|
131
|
+
pcdHeader.count = [];
|
|
132
|
+
if (pcdHeader.fields !== null) {
|
|
133
|
+
for (let i = 0; i < pcdHeader.fields.length; i++) {
|
|
134
|
+
pcdHeader.count.push(1);
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
pcdHeader.offset = {};
|
|
139
|
+
let sizeSum = 0;
|
|
140
|
+
if (pcdHeader.fields !== null && pcdHeader.size !== null) {
|
|
141
|
+
for (let i = 0; i < pcdHeader.fields.length; i++) {
|
|
142
|
+
if (pcdHeader.data === 'ascii') {
|
|
143
|
+
pcdHeader.offset[pcdHeader.fields[i]] = i;
|
|
144
|
+
} else {
|
|
145
|
+
pcdHeader.offset[pcdHeader.fields[i]] = sizeSum;
|
|
146
|
+
sizeSum += pcdHeader.size[i];
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
pcdHeader.rowSize = sizeSum;
|
|
151
|
+
return pcdHeader;
|
|
152
|
+
}
|
|
153
|
+
function parsePCDASCII(pcdHeader, textData) {
|
|
154
|
+
const position = [];
|
|
155
|
+
const normal = [];
|
|
156
|
+
const color = [];
|
|
157
|
+
const intensity = [];
|
|
158
|
+
const label = [];
|
|
159
|
+
const offset = pcdHeader.offset;
|
|
160
|
+
const pcdData = textData.substr(pcdHeader.headerLen);
|
|
161
|
+
const lines = pcdData.split('\n');
|
|
162
|
+
for (let i = 0; i < lines.length; i++) {
|
|
163
|
+
if (lines[i] !== '') {
|
|
164
|
+
const line = lines[i].split(' ');
|
|
165
|
+
if (offset.x !== undefined) {
|
|
166
|
+
position.push(parseFloat(line[offset.x]));
|
|
167
|
+
position.push(parseFloat(line[offset.y]));
|
|
168
|
+
position.push(parseFloat(line[offset.z]));
|
|
169
|
+
}
|
|
170
|
+
if (offset.rgb !== undefined) {
|
|
171
|
+
const floatValue = parseFloat(line[offset.rgb]);
|
|
172
|
+
const binaryColor = new Float32Array([floatValue]);
|
|
173
|
+
const dataview = new DataView(binaryColor.buffer, 0);
|
|
174
|
+
color.push(dataview.getUint8(0));
|
|
175
|
+
color.push(dataview.getUint8(1));
|
|
176
|
+
color.push(dataview.getUint8(2));
|
|
177
|
+
}
|
|
178
|
+
if (offset.normal_x !== undefined) {
|
|
179
|
+
normal.push(parseFloat(line[offset.normal_x]));
|
|
180
|
+
normal.push(parseFloat(line[offset.normal_y]));
|
|
181
|
+
normal.push(parseFloat(line[offset.normal_z]));
|
|
182
|
+
}
|
|
183
|
+
if (offset.intensity !== undefined) {
|
|
184
|
+
intensity.push(parseFloat(line[offset.intensity]));
|
|
185
|
+
}
|
|
186
|
+
if (offset.label !== undefined) {
|
|
187
|
+
label.push(parseInt(line[offset.label]));
|
|
188
|
+
}
|
|
189
|
+
}
|
|
190
|
+
}
|
|
191
|
+
return {
|
|
192
|
+
position,
|
|
193
|
+
normal,
|
|
194
|
+
color
|
|
195
|
+
};
|
|
196
|
+
}
|
|
197
|
+
function parsePCDBinary(pcdHeader, data) {
|
|
198
|
+
const position = [];
|
|
199
|
+
const normal = [];
|
|
200
|
+
const color = [];
|
|
201
|
+
const intensity = [];
|
|
202
|
+
const label = [];
|
|
203
|
+
const dataview = new DataView(data, pcdHeader.headerLen);
|
|
204
|
+
const offset = pcdHeader.offset;
|
|
205
|
+
for (let i = 0, row = 0; i < pcdHeader.points; i++, row += pcdHeader.rowSize) {
|
|
206
|
+
if (offset.x !== undefined) {
|
|
207
|
+
position.push(dataview.getFloat32(row + offset.x, LITTLE_ENDIAN));
|
|
208
|
+
position.push(dataview.getFloat32(row + offset.y, LITTLE_ENDIAN));
|
|
209
|
+
position.push(dataview.getFloat32(row + offset.z, LITTLE_ENDIAN));
|
|
210
|
+
}
|
|
211
|
+
if (offset.rgb !== undefined) {
|
|
212
|
+
color.push(dataview.getUint8(row + offset.rgb + 0));
|
|
213
|
+
color.push(dataview.getUint8(row + offset.rgb + 1));
|
|
214
|
+
color.push(dataview.getUint8(row + offset.rgb + 2));
|
|
215
|
+
}
|
|
216
|
+
if (offset.normal_x !== undefined) {
|
|
217
|
+
normal.push(dataview.getFloat32(row + offset.normal_x, LITTLE_ENDIAN));
|
|
218
|
+
normal.push(dataview.getFloat32(row + offset.normal_y, LITTLE_ENDIAN));
|
|
219
|
+
normal.push(dataview.getFloat32(row + offset.normal_z, LITTLE_ENDIAN));
|
|
220
|
+
}
|
|
221
|
+
if (offset.intensity !== undefined) {
|
|
222
|
+
intensity.push(dataview.getFloat32(row + offset.intensity, LITTLE_ENDIAN));
|
|
223
|
+
}
|
|
224
|
+
if (offset.label !== undefined) {
|
|
225
|
+
label.push(dataview.getInt32(row + offset.label, LITTLE_ENDIAN));
|
|
226
|
+
}
|
|
227
|
+
}
|
|
228
|
+
return {
|
|
229
|
+
position,
|
|
230
|
+
normal,
|
|
231
|
+
color,
|
|
232
|
+
intensity,
|
|
233
|
+
label
|
|
234
|
+
};
|
|
235
|
+
}
|
|
236
|
+
|
|
237
|
+
/** Parse compressed PCD data in in binary_compressed form ( https://pointclouds.org/documentation/tutorials/pcd_file_format.html)
|
|
238
|
+
* from https://github.com/mrdoob/three.js/blob/master/examples/jsm/loaders/PCDLoader.js
|
|
239
|
+
* @license MIT (http://opensource.org/licenses/MIT)
|
|
240
|
+
* @param pcdHeader
|
|
241
|
+
* @param data
|
|
242
|
+
* @returns [attributes]
|
|
243
|
+
*/
|
|
244
|
+
function parsePCDBinaryCompressed(pcdHeader, data) {
|
|
245
|
+
const position = [];
|
|
246
|
+
const normal = [];
|
|
247
|
+
const color = [];
|
|
248
|
+
const intensity = [];
|
|
249
|
+
const label = [];
|
|
250
|
+
const sizes = new Uint32Array(data.slice(pcdHeader.headerLen, pcdHeader.headerLen + 8));
|
|
251
|
+
const compressedSize = sizes[0];
|
|
252
|
+
const decompressedSize = sizes[1];
|
|
253
|
+
const decompressed = decompressLZF(new Uint8Array(data, pcdHeader.headerLen + 8, compressedSize), decompressedSize);
|
|
254
|
+
const dataview = new DataView(decompressed.buffer);
|
|
255
|
+
const offset = pcdHeader.offset;
|
|
256
|
+
for (let i = 0; i < pcdHeader.points; i++) {
|
|
257
|
+
if (offset.x !== undefined) {
|
|
258
|
+
position.push(dataview.getFloat32(pcdHeader.points * offset.x + pcdHeader.size[0] * i, LITTLE_ENDIAN));
|
|
259
|
+
position.push(dataview.getFloat32(pcdHeader.points * offset.y + pcdHeader.size[1] * i, LITTLE_ENDIAN));
|
|
260
|
+
position.push(dataview.getFloat32(pcdHeader.points * offset.z + pcdHeader.size[2] * i, LITTLE_ENDIAN));
|
|
261
|
+
}
|
|
262
|
+
if (offset.rgb !== undefined) {
|
|
263
|
+
color.push(dataview.getUint8(pcdHeader.points * offset.rgb + pcdHeader.size[3] * i + 0) / 255.0);
|
|
264
|
+
color.push(dataview.getUint8(pcdHeader.points * offset.rgb + pcdHeader.size[3] * i + 1) / 255.0);
|
|
265
|
+
color.push(dataview.getUint8(pcdHeader.points * offset.rgb + pcdHeader.size[3] * i + 2) / 255.0);
|
|
266
|
+
}
|
|
267
|
+
if (offset.normal_x !== undefined) {
|
|
268
|
+
normal.push(dataview.getFloat32(pcdHeader.points * offset.normal_x + pcdHeader.size[4] * i, LITTLE_ENDIAN));
|
|
269
|
+
normal.push(dataview.getFloat32(pcdHeader.points * offset.normal_y + pcdHeader.size[5] * i, LITTLE_ENDIAN));
|
|
270
|
+
normal.push(dataview.getFloat32(pcdHeader.points * offset.normal_z + pcdHeader.size[6] * i, LITTLE_ENDIAN));
|
|
271
|
+
}
|
|
272
|
+
if (offset.intensity !== undefined) {
|
|
273
|
+
const intensityIndex = pcdHeader.fields.indexOf('intensity');
|
|
274
|
+
intensity.push(dataview.getFloat32(pcdHeader.points * offset.intensity + pcdHeader.size[intensityIndex] * i, LITTLE_ENDIAN));
|
|
275
|
+
}
|
|
276
|
+
if (offset.label !== undefined) {
|
|
277
|
+
const labelIndex = pcdHeader.fields.indexOf('label');
|
|
278
|
+
label.push(dataview.getInt32(pcdHeader.points * offset.label + pcdHeader.size[labelIndex] * i, LITTLE_ENDIAN));
|
|
279
|
+
}
|
|
280
|
+
}
|
|
281
|
+
return {
|
|
282
|
+
position,
|
|
283
|
+
normal,
|
|
284
|
+
color,
|
|
285
|
+
intensity,
|
|
286
|
+
label
|
|
287
|
+
};
|
|
288
|
+
}
|
|
289
|
+
//# sourceMappingURL=parse-pcd.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"parse-pcd.js","names":["getMeshBoundingBox","decompressLZF","getPCDSchema","LITTLE_ENDIAN","parsePCD","data","textData","TextDecoder","decode","pcdHeader","parsePCDHeader","attributes","parsePCDASCII","parsePCDBinary","parsePCDBinaryCompressed","Error","concat","getMeshAttributes","header","getMeshHeader","metadata","Object","fromEntries","JSON","stringify","boundingBox","schema","loader","loaderData","mode","topology","width","height","pointCount","vertexCount","normalizedAttributes","POSITION","value","Float32Array","position","size","normal","length","NORMAL","color","COLOR_0","Uint8Array","intensity","label","result1","search","result2","exec","substr","headerLen","str","replace","version","fields","type","count","viewpoint","points","parseFloat","split","parseInt","map","x","i","push","offset","sizeSum","rowSize","pcdData","lines","line","undefined","y","z","rgb","floatValue","binaryColor","dataview","DataView","buffer","getUint8","normal_x","normal_y","normal_z","row","getFloat32","getInt32","sizes","Uint32Array","slice","compressedSize","decompressedSize","decompressed","intensityIndex","indexOf","labelIndex"],"sources":["../../../src/lib/parse-pcd.ts"],"sourcesContent":["// PCD Loader, adapted from THREE.js (MIT license)\n// Description: A loader for PCD ascii and binary files.\n// Limitations: Compressed binary files are not supported.\n//\n// Attributions per original THREE.js source file:\n// @author Filipe Caixeta / http://filipecaixeta.com.br\n// @author Mugen87 / https://github.com/Mugen87\n\nimport {MeshAttribute, MeshAttributes} from '@loaders.gl/schema';\nimport {getMeshBoundingBox} from '@loaders.gl/schema';\nimport {decompressLZF} from './decompress-lzf';\nimport {getPCDSchema} from './get-pcd-schema';\nimport type {PCDHeader, PCDMesh} from './pcd-types';\n\ntype MeshHeader = {\n vertexCount: number;\n boundingBox: [[number, number, number], [number, number, number]];\n};\n\ntype NormalizedAttributes = {\n POSITION: {\n value: Float32Array;\n size: number;\n };\n NORMAL?: {\n value: Float32Array;\n size: number;\n };\n COLOR_0?: {\n value: Uint8Array;\n size: number;\n };\n};\n\ntype HeaderAttributes = {\n [attributeName: string]: number[];\n};\n\nconst LITTLE_ENDIAN: boolean = true;\n\n/**\n *\n * @param data\n * @returns\n */\nexport default function parsePCD(data: ArrayBufferLike): PCDMesh {\n // parse header (always ascii format)\n const textData = new TextDecoder().decode(data);\n const pcdHeader = parsePCDHeader(textData);\n\n let attributes: any = {};\n\n // parse data\n switch (pcdHeader.data) {\n case 'ascii':\n attributes = parsePCDASCII(pcdHeader, textData);\n break;\n\n case 'binary':\n attributes = parsePCDBinary(pcdHeader, data);\n break;\n\n case 'binary_compressed':\n attributes = parsePCDBinaryCompressed(pcdHeader, data);\n break;\n\n default:\n throw new Error(`PCD: ${pcdHeader.data} files are not supported`);\n }\n\n attributes = getMeshAttributes(attributes);\n\n const header = getMeshHeader(pcdHeader, attributes);\n\n const metadata = Object.fromEntries([\n ['mode', '0'],\n ['boundingBox', JSON.stringify(header.boundingBox)]\n ]);\n\n const schema = getPCDSchema(pcdHeader, metadata);\n\n return {\n loader: 'pcd',\n loaderData: pcdHeader,\n header,\n schema,\n mode: 0, // POINTS\n topology: 'point-list',\n attributes\n };\n}\n\n// Create a header that contains common data for PointCloud category loaders\nfunction getMeshHeader(pcdHeader: PCDHeader, attributes: NormalizedAttributes): MeshHeader {\n if (typeof pcdHeader.width === 'number' && typeof pcdHeader.height === 'number') {\n const pointCount = pcdHeader.width * pcdHeader.height; // Supports \"organized\" point sets\n return {\n vertexCount: pointCount,\n boundingBox: getMeshBoundingBox(attributes)\n };\n }\n return {\n vertexCount: pcdHeader.vertexCount,\n boundingBox: pcdHeader.boundingBox\n };\n}\n\n/**\n * @param attributes\n * @returns Normalized attributes\n */\nfunction getMeshAttributes(attributes: HeaderAttributes): {[attributeName: string]: MeshAttribute} {\n const normalizedAttributes: MeshAttributes = {\n POSITION: {\n // Binary PCD is only 32 bit\n value: new Float32Array(attributes.position),\n size: 3\n }\n };\n\n if (attributes.normal && attributes.normal.length > 0) {\n normalizedAttributes.NORMAL = {\n value: new Float32Array(attributes.normal),\n size: 3\n };\n }\n\n if (attributes.color && attributes.color.length > 0) {\n // TODO - RGBA\n normalizedAttributes.COLOR_0 = {\n value: new Uint8Array(attributes.color),\n size: 3\n };\n }\n\n if (attributes.intensity && attributes.intensity.length > 0) {\n // TODO - RGBA\n normalizedAttributes.COLOR_0 = {\n value: new Uint8Array(attributes.color),\n size: 3\n };\n }\n\n if (attributes.label && attributes.label.length > 0) {\n // TODO - RGBA\n normalizedAttributes.COLOR_0 = {\n value: new Uint8Array(attributes.label),\n size: 3\n };\n }\n\n return normalizedAttributes;\n}\n\n/**\n * Incoming data parsing\n * @param data\n * @returns Header\n */\n/* eslint-disable complexity, max-statements */\nfunction parsePCDHeader(data: string): PCDHeader {\n const result1 = data.search(/[\\r\\n]DATA\\s(\\S*)\\s/i);\n const result2 = /[\\r\\n]DATA\\s(\\S*)\\s/i.exec(data.substr(result1 - 1));\n\n const pcdHeader: any = {};\n pcdHeader.data = result2 && result2[1];\n if (result2 !== null) {\n pcdHeader.headerLen = (result2 && result2[0].length) + result1;\n }\n pcdHeader.str = data.substr(0, pcdHeader.headerLen);\n\n // remove comments\n\n pcdHeader.str = pcdHeader.str.replace(/\\#.*/gi, '');\n\n // parse\n\n pcdHeader.version = /VERSION (.*)/i.exec(pcdHeader.str);\n pcdHeader.fields = /FIELDS (.*)/i.exec(pcdHeader.str);\n pcdHeader.size = /SIZE (.*)/i.exec(pcdHeader.str);\n pcdHeader.type = /TYPE (.*)/i.exec(pcdHeader.str);\n pcdHeader.count = /COUNT (.*)/i.exec(pcdHeader.str);\n pcdHeader.width = /WIDTH (.*)/i.exec(pcdHeader.str);\n pcdHeader.height = /HEIGHT (.*)/i.exec(pcdHeader.str);\n pcdHeader.viewpoint = /VIEWPOINT (.*)/i.exec(pcdHeader.str);\n pcdHeader.points = /POINTS (.*)/i.exec(pcdHeader.str);\n\n // evaluate\n\n if (pcdHeader.version !== null) {\n pcdHeader.version = parseFloat(pcdHeader.version[1]);\n }\n\n if (pcdHeader.fields !== null) {\n pcdHeader.fields = pcdHeader.fields[1].split(' ');\n }\n\n if (pcdHeader.type !== null) {\n pcdHeader.type = pcdHeader.type[1].split(' ');\n }\n\n if (pcdHeader.width !== null) {\n pcdHeader.width = parseInt(pcdHeader.width[1], 10);\n }\n\n if (pcdHeader.height !== null) {\n pcdHeader.height = parseInt(pcdHeader.height[1], 10);\n }\n\n if (pcdHeader.viewpoint !== null) {\n pcdHeader.viewpoint = pcdHeader.viewpoint[1];\n }\n\n if (pcdHeader.points !== null) {\n pcdHeader.points = parseInt(pcdHeader.points[1], 10);\n }\n\n if (\n pcdHeader.points === null &&\n typeof pcdHeader.width === 'number' &&\n typeof pcdHeader.height === 'number'\n ) {\n pcdHeader.points = pcdHeader.width * pcdHeader.height;\n }\n\n if (pcdHeader.size !== null) {\n pcdHeader.size = pcdHeader.size[1].split(' ').map((x) => parseInt(x, 10));\n }\n\n if (pcdHeader.count !== null) {\n pcdHeader.count = pcdHeader.count[1].split(' ').map((x) => parseInt(x, 10));\n } else {\n pcdHeader.count = [];\n if (pcdHeader.fields !== null) {\n for (let i = 0; i < pcdHeader.fields.length; i++) {\n pcdHeader.count.push(1);\n }\n }\n }\n\n pcdHeader.offset = {};\n\n let sizeSum = 0;\n if (pcdHeader.fields !== null && pcdHeader.size !== null) {\n for (let i = 0; i < pcdHeader.fields.length; i++) {\n if (pcdHeader.data === 'ascii') {\n pcdHeader.offset[pcdHeader.fields[i]] = i;\n } else {\n pcdHeader.offset[pcdHeader.fields[i]] = sizeSum;\n sizeSum += pcdHeader.size[i];\n }\n }\n }\n\n // for binary only\n pcdHeader.rowSize = sizeSum;\n\n return pcdHeader;\n}\n\n/**\n * @param pcdHeader\n * @param textData\n * @returns [attributes]\n */\n// eslint-enable-next-line complexity, max-statements\nfunction parsePCDASCII(pcdHeader: PCDHeader, textData: string): HeaderAttributes {\n const position: number[] = [];\n const normal: number[] = [];\n const color: number[] = [];\n const intensity: number[] = [];\n const label: number[] = [];\n\n const offset = pcdHeader.offset;\n const pcdData = textData.substr(pcdHeader.headerLen);\n const lines = pcdData.split('\\n');\n\n for (let i = 0; i < lines.length; i++) {\n if (lines[i] !== '') {\n const line = lines[i].split(' ');\n\n if (offset.x !== undefined) {\n position.push(parseFloat(line[offset.x]));\n position.push(parseFloat(line[offset.y]));\n position.push(parseFloat(line[offset.z]));\n }\n\n if (offset.rgb !== undefined) {\n const floatValue = parseFloat(line[offset.rgb]);\n const binaryColor = new Float32Array([floatValue]);\n const dataview = new DataView(binaryColor.buffer, 0);\n color.push(dataview.getUint8(0));\n color.push(dataview.getUint8(1));\n color.push(dataview.getUint8(2));\n // TODO - handle alpha channel / RGBA?\n }\n\n if (offset.normal_x !== undefined) {\n normal.push(parseFloat(line[offset.normal_x]));\n normal.push(parseFloat(line[offset.normal_y]));\n normal.push(parseFloat(line[offset.normal_z]));\n }\n\n if (offset.intensity !== undefined) {\n intensity.push(parseFloat(line[offset.intensity]));\n }\n\n if (offset.label !== undefined) {\n label.push(parseInt(line[offset.label]));\n }\n }\n }\n\n return {position, normal, color};\n}\n\n/**\n * @param pcdHeader\n * @param data\n * @returns [attributes]\n */\nfunction parsePCDBinary(pcdHeader: PCDHeader, data: ArrayBufferLike): HeaderAttributes {\n const position: number[] = [];\n const normal: number[] = [];\n const color: number[] = [];\n const intensity: number[] = [];\n const label: number[] = [];\n\n const dataview = new DataView(data, pcdHeader.headerLen);\n const offset = pcdHeader.offset;\n\n for (let i = 0, row = 0; i < pcdHeader.points; i++, row += pcdHeader.rowSize) {\n if (offset.x !== undefined) {\n position.push(dataview.getFloat32(row + offset.x, LITTLE_ENDIAN));\n position.push(dataview.getFloat32(row + offset.y, LITTLE_ENDIAN));\n position.push(dataview.getFloat32(row + offset.z, LITTLE_ENDIAN));\n }\n\n if (offset.rgb !== undefined) {\n color.push(dataview.getUint8(row + offset.rgb + 0));\n color.push(dataview.getUint8(row + offset.rgb + 1));\n color.push(dataview.getUint8(row + offset.rgb + 2));\n }\n\n if (offset.normal_x !== undefined) {\n normal.push(dataview.getFloat32(row + offset.normal_x, LITTLE_ENDIAN));\n normal.push(dataview.getFloat32(row + offset.normal_y, LITTLE_ENDIAN));\n normal.push(dataview.getFloat32(row + offset.normal_z, LITTLE_ENDIAN));\n }\n\n if (offset.intensity !== undefined) {\n intensity.push(dataview.getFloat32(row + offset.intensity, LITTLE_ENDIAN));\n }\n\n if (offset.label !== undefined) {\n label.push(dataview.getInt32(row + offset.label, LITTLE_ENDIAN));\n }\n }\n\n return {position, normal, color, intensity, label};\n}\n\n/** Parse compressed PCD data in in binary_compressed form ( https://pointclouds.org/documentation/tutorials/pcd_file_format.html)\n * from https://github.com/mrdoob/three.js/blob/master/examples/jsm/loaders/PCDLoader.js\n * @license MIT (http://opensource.org/licenses/MIT)\n * @param pcdHeader\n * @param data\n * @returns [attributes]\n */\n// eslint-enable-next-line complexity, max-statements\nfunction parsePCDBinaryCompressed(pcdHeader: PCDHeader, data: ArrayBufferLike): HeaderAttributes {\n const position: number[] = [];\n const normal: number[] = [];\n const color: number[] = [];\n const intensity: number[] = [];\n const label: number[] = [];\n\n const sizes = new Uint32Array(data.slice(pcdHeader.headerLen, pcdHeader.headerLen + 8));\n const compressedSize = sizes[0];\n const decompressedSize = sizes[1];\n const decompressed = decompressLZF(\n new Uint8Array(data, pcdHeader.headerLen + 8, compressedSize),\n decompressedSize\n );\n const dataview = new DataView(decompressed.buffer);\n\n const offset = pcdHeader.offset;\n\n for (let i = 0; i < pcdHeader.points; i++) {\n if (offset.x !== undefined) {\n position.push(\n dataview.getFloat32(pcdHeader.points * offset.x + pcdHeader.size[0] * i, LITTLE_ENDIAN)\n );\n position.push(\n dataview.getFloat32(pcdHeader.points * offset.y + pcdHeader.size[1] * i, LITTLE_ENDIAN)\n );\n position.push(\n dataview.getFloat32(pcdHeader.points * offset.z + pcdHeader.size[2] * i, LITTLE_ENDIAN)\n );\n }\n\n if (offset.rgb !== undefined) {\n color.push(\n dataview.getUint8(pcdHeader.points * offset.rgb + pcdHeader.size[3] * i + 0) / 255.0\n );\n color.push(\n dataview.getUint8(pcdHeader.points * offset.rgb + pcdHeader.size[3] * i + 1) / 255.0\n );\n color.push(\n dataview.getUint8(pcdHeader.points * offset.rgb + pcdHeader.size[3] * i + 2) / 255.0\n );\n }\n\n if (offset.normal_x !== undefined) {\n normal.push(\n dataview.getFloat32(\n pcdHeader.points * offset.normal_x + pcdHeader.size[4] * i,\n LITTLE_ENDIAN\n )\n );\n normal.push(\n dataview.getFloat32(\n pcdHeader.points * offset.normal_y + pcdHeader.size[5] * i,\n LITTLE_ENDIAN\n )\n );\n normal.push(\n dataview.getFloat32(\n pcdHeader.points * offset.normal_z + pcdHeader.size[6] * i,\n LITTLE_ENDIAN\n )\n );\n }\n\n if (offset.intensity !== undefined) {\n const intensityIndex = pcdHeader.fields.indexOf('intensity');\n intensity.push(\n dataview.getFloat32(\n pcdHeader.points * offset.intensity + pcdHeader.size[intensityIndex] * i,\n LITTLE_ENDIAN\n )\n );\n }\n\n if (offset.label !== undefined) {\n const labelIndex = pcdHeader.fields.indexOf('label');\n label.push(\n dataview.getInt32(\n pcdHeader.points * offset.label + pcdHeader.size[labelIndex] * i,\n LITTLE_ENDIAN\n )\n );\n }\n }\n\n return {\n position,\n normal,\n color,\n intensity,\n label\n };\n}\n"],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pcd-types.js","names":[],"sources":["../../../src/lib/pcd-types.ts"],"sourcesContent":["import type {Mesh} from '@loaders.gl/schema';\n\ntype BoundingBox = [[number, number, number], [number, number, number]];\n\nexport type PCDHeader = {\n data: any;\n headerLen: number;\n str: string;\n version: number;\n fields: string[];\n size: number[];\n type: null | string[];\n count: null | number[];\n width: number;\n height: number;\n viewpoint: null | string;\n points: number;\n offset: {[index: string]: number};\n rowSize: number;\n vertexCount: number;\n boundingBox: BoundingBox;\n};\n\n/** */\nexport type PCDMesh = Mesh & {\n loader: 'pcd';\n loaderData: PCDHeader;\n topology: 'point-list';\n mode: 0;\n};\n"],"mappings":""}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
const VERSION = typeof "4.0.0-alpha.6" !== 'undefined' ? "4.0.0-alpha.6" : 'latest';
|
|
2
|
+
export const PCDLoader = {
|
|
3
|
+
name: 'PCD (Point Cloud Data)',
|
|
4
|
+
id: 'pcd',
|
|
5
|
+
module: 'pcd',
|
|
6
|
+
version: VERSION,
|
|
7
|
+
worker: true,
|
|
8
|
+
extensions: ['pcd'],
|
|
9
|
+
mimeTypes: ['text/plain'],
|
|
10
|
+
options: {
|
|
11
|
+
pcd: {}
|
|
12
|
+
}
|
|
13
|
+
};
|
|
14
|
+
//# sourceMappingURL=pcd-loader.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pcd-loader.js","names":["VERSION","PCDLoader","name","id","module","version","worker","extensions","mimeTypes","options","pcd"],"sources":["../../src/pcd-loader.ts"],"sourcesContent":["// loaders.gl, MIT license\n\nimport type {Loader, LoaderOptions} from '@loaders.gl/loader-utils';\nimport {PCDMesh} from './lib/pcd-types';\n\n// __VERSION__ is injected by babel-plugin-version-inline\n// @ts-ignore TS2304: Cannot find name '__VERSION__'.\nconst VERSION = typeof __VERSION__ !== 'undefined' ? __VERSION__ : 'latest';\n\n/**\n * Worker loader for PCD - Point Cloud Data\n */\nexport const PCDLoader: Loader<PCDMesh, never, LoaderOptions> = {\n name: 'PCD (Point Cloud Data)',\n id: 'pcd',\n module: 'pcd',\n version: VERSION,\n worker: true,\n extensions: ['pcd'],\n mimeTypes: ['text/plain'],\n options: {\n pcd: {}\n }\n};\n"],"mappings":"AAOA,MAAMA,OAAO,GAAG,sBAAkB,KAAK,WAAW,qBAAiB,QAAQ;AAK3E,OAAO,MAAMC,SAAgD,GAAG;EAC9DC,IAAI,EAAE,wBAAwB;EAC9BC,EAAE,EAAE,KAAK;EACTC,MAAM,EAAE,KAAK;EACbC,OAAO,EAAEL,OAAO;EAChBM,MAAM,EAAE,IAAI;EACZC,UAAU,EAAE,CAAC,KAAK,CAAC;EACnBC,SAAS,EAAE,CAAC,YAAY,CAAC;EACzBC,OAAO,EAAE;IACPC,GAAG,EAAE,CAAC;EACR;AACF,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pcd-worker.js","names":["createLoaderWorker","PCDLoader"],"sources":["../../../src/workers/pcd-worker.ts"],"sourcesContent":["import {createLoaderWorker} from '@loaders.gl/loader-utils';\nimport {PCDLoader} from '../index';\n\ncreateLoaderWorker(PCDLoader);\n"],"mappings":"AAAA,SAAQA,kBAAkB,QAAO,0BAA0B;AAC3D,SAAQC,SAAS,QAAO,UAAU;AAElCD,kBAAkB,CAACC,SAAS,CAAC"}
|
package/dist/index.d.ts
CHANGED
|
@@ -1,32 +1,10 @@
|
|
|
1
|
-
import type { LoaderWithParser } from '@loaders.gl/loader-utils';
|
|
2
|
-
import parsePCDSync from './lib/parse-pcd';
|
|
1
|
+
import type { LoaderOptions, LoaderWithParser } from '@loaders.gl/loader-utils';
|
|
3
2
|
import { PCDLoader as PCDWorkerLoader } from './pcd-loader';
|
|
3
|
+
import { PCDMesh } from './lib/pcd-types';
|
|
4
4
|
export { PCDWorkerLoader };
|
|
5
5
|
/**
|
|
6
6
|
* Loader for PCD - Point Cloud Data
|
|
7
7
|
*/
|
|
8
|
-
export declare const PCDLoader:
|
|
9
|
-
parse: (arrayBuffer: any) => Promise<{
|
|
10
|
-
loaderData: {
|
|
11
|
-
header: import("./lib/pcd-types").PCDHeader;
|
|
12
|
-
};
|
|
13
|
-
header: Partial<import("./lib/pcd-types").PCDHeader>;
|
|
14
|
-
schema: import("@loaders.gl/schema").Schema;
|
|
15
|
-
mode: number;
|
|
16
|
-
indices: null;
|
|
17
|
-
attributes: any;
|
|
18
|
-
}>;
|
|
19
|
-
parseSync: typeof parsePCDSync;
|
|
20
|
-
name: string;
|
|
21
|
-
id: string;
|
|
22
|
-
module: string;
|
|
23
|
-
version: any;
|
|
24
|
-
worker: boolean;
|
|
25
|
-
extensions: string[];
|
|
26
|
-
mimeTypes: string[];
|
|
27
|
-
options: {
|
|
28
|
-
pcd: {};
|
|
29
|
-
};
|
|
30
|
-
};
|
|
8
|
+
export declare const PCDLoader: LoaderWithParser<PCDMesh, never, LoaderOptions>;
|
|
31
9
|
export declare const _typecheckPCDLoader: LoaderWithParser;
|
|
32
10
|
//# sourceMappingURL=index.d.ts.map
|
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAC,gBAAgB,EAAC,MAAM,0BAA0B,CAAC;
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAC,aAAa,EAAE,gBAAgB,EAAC,MAAM,0BAA0B,CAAC;AAE9E,OAAO,EAAC,SAAS,IAAI,eAAe,EAAC,MAAM,cAAc,CAAC;AAC1D,OAAO,EAAC,OAAO,EAAC,MAAM,iBAAiB,CAAC;AAExC,OAAO,EAAC,eAAe,EAAC,CAAC;AAEzB;;GAEG;AACH,eAAO,MAAM,SAAS,EAAE,gBAAgB,CAAC,OAAO,EAAE,KAAK,EAAE,aAAa,CAIrE,CAAC;AAEF,eAAO,MAAM,mBAAmB,EAAE,gBAA4B,CAAC"}
|
package/dist/index.js
CHANGED
|
@@ -1,9 +1,18 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
export const PCDLoader = { ...PCDWorkerLoader,
|
|
5
|
-
parse: async arrayBuffer => parsePCDSync(arrayBuffer),
|
|
6
|
-
parseSync: parsePCDSync
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
7
4
|
};
|
|
8
|
-
|
|
9
|
-
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports._typecheckPCDLoader = exports.PCDLoader = exports.PCDWorkerLoader = void 0;
|
|
7
|
+
const parse_pcd_1 = __importDefault(require("./lib/parse-pcd"));
|
|
8
|
+
const pcd_loader_1 = require("./pcd-loader");
|
|
9
|
+
Object.defineProperty(exports, "PCDWorkerLoader", { enumerable: true, get: function () { return pcd_loader_1.PCDLoader; } });
|
|
10
|
+
/**
|
|
11
|
+
* Loader for PCD - Point Cloud Data
|
|
12
|
+
*/
|
|
13
|
+
exports.PCDLoader = {
|
|
14
|
+
...pcd_loader_1.PCDLoader,
|
|
15
|
+
parse: async (arrayBuffer) => (0, parse_pcd_1.default)(arrayBuffer),
|
|
16
|
+
parseSync: parse_pcd_1.default
|
|
17
|
+
};
|
|
18
|
+
exports._typecheckPCDLoader = exports.PCDLoader;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"decompress-lzf.d.ts","sourceRoot":"","sources":["../../src/lib/decompress-lzf.ts"],"names":[],"mappings":"AACA;;;;;GAKG;AACH,wBAAgB,aAAa,CAAC,MAAM,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,GAAG,UAAU,
|
|
1
|
+
{"version":3,"file":"decompress-lzf.d.ts","sourceRoot":"","sources":["../../src/lib/decompress-lzf.ts"],"names":[],"mappings":"AACA;;;;;GAKG;AACH,wBAAgB,aAAa,CAAC,MAAM,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,GAAG,UAAU,CAwD/E"}
|