Press n or j to go to the next uncovered block, b, p or k for the previous block.
| 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 | import { PolyDataClipCacheType } from '../../../helpers/clipAndCacheSurfacesForViewport';
import { RawContourData } from '../contourComputationStrategies';
/**
* Extracts contour data from the given polyDataCache.
* @param polyDataCache - The polyData cache containing intersection information.
* @param segmentIndexMap - Optional map for mapping surface IDs to segment indices.
* @returns A map of segment indices to an array of contour results.
*/
export function extractContourData(
polyDataCache: PolyDataClipCacheType,
segmentIndexMap?: Map<string, number>
) {
const rawResults = new Map() as RawContourData;
for (const [cacheId, intersectionInfo] of polyDataCache) {
// Todo; fix this
const surfaceId = cacheId.split('_')[1];
for (const [_, result] of intersectionInfo) {
if (!result) {
continue;
}
const segmentIndex = Number(surfaceId) || segmentIndexMap?.get(surfaceId);
if (!segmentIndex) {
continue;
}
if (!rawResults.has(segmentIndex)) {
rawResults.set(segmentIndex, []);
}
rawResults.get(segmentIndex).push(result);
}
}
return rawResults;
}
|