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 40 41 42 43 44 45 46 47 | 66x 66x 66x 66x 66x 66x 66x 66x 66x 66x | import { getRenderingEngine } from '../RenderingEngine'; import { getRenderingEngines } from '../RenderingEngine/getRenderingEngine'; import { IStackViewport, IVolumeViewport } from '../types'; type Viewport = IStackViewport | IVolumeViewport; /** * Get the viewport that is rendering the image with the given imageURI (imageId without * the loader schema), this can be a stackViewport or a volumeViewport. * * @param renderingEngine - The rendering engine that is rendering the viewports * @param imageURI - The imageURI of the image that is requested * @returns A Viewport */ export default function getViewportsWithImageURI( imageURI: string, renderingEngineId?: string ): Array<Viewport> { // If rendering engine is not provided, use all rendering engines let renderingEngines; Eif (renderingEngineId) { renderingEngines = [getRenderingEngine(renderingEngineId)]; } else { renderingEngines = getRenderingEngines(); } const viewports = []; renderingEngines.forEach((renderingEngine) => { const stackViewports = renderingEngine.getStackViewports(); const filteredStackViewports = stackViewports.filter((viewport) => viewport.hasImageURI(imageURI) ); // If no stack viewport found but a volumeViewport is rendering the same data const volumeViewports = renderingEngine.getVolumeViewports(); const filteredVolumeViewports = volumeViewports.filter((viewport) => viewport.hasImageURI(imageURI) ); viewports.push(...filteredStackViewports, ...filteredVolumeViewports); }); return viewports; } |