From 0034435e3f6353fcd2e91cd042cda0f127eba601 Mon Sep 17 00:00:00 2001 From: Melissa Linkert Date: Tue, 12 Sep 2023 11:02:41 -0500 Subject: [PATCH] DICOM writer: throw an exception if the provided tiles don't match the expected tile size --- .../src/loci/formats/out/DicomWriter.java | 14 +++++++++++--- 1 file changed, 11 insertions(+), 3 deletions(-) diff --git a/components/formats-bsd/src/loci/formats/out/DicomWriter.java b/components/formats-bsd/src/loci/formats/out/DicomWriter.java index 3164bd36728..3aa822f437b 100644 --- a/components/formats-bsd/src/loci/formats/out/DicomWriter.java +++ b/components/formats-bsd/src/loci/formats/out/DicomWriter.java @@ -188,6 +188,10 @@ public void saveBytes(int no, byte[] buf, int x, int y, int w, int h) { checkParams(no, buf, x, y, w, h); + int resolutionIndex = getIndex(series, resolution); + int thisTileWidth = tileWidth[resolutionIndex]; + int thisTileHeight = tileHeight[resolutionIndex]; + MetadataRetrieve r = getMetadataRetrieve(); if ((!(r instanceof IPyramidStore) || ((IPyramidStore) r).getResolutionCount(series) == 1) && @@ -195,11 +199,17 @@ public void saveBytes(int no, byte[] buf, int x, int y, int w, int h) { throw new FormatException("DicomWriter does not allow tiles for non-pyramid images"); } + else if (x % thisTileWidth != 0 || y % thisTileHeight != 0 || + (w != thisTileWidth && x + w != getSizeX()) || + (h != thisTileHeight && y + h != getSizeY())) + { + throw new FormatException("Tile too small, expected " + thisTileWidth + "x" + thisTileHeight + + ". Setting the tile size to " + getSizeX() + "x" + getSizeY() + " or smaller may work."); + } checkPixelCount(false); boolean first = x == 0 && y == 0; boolean last = x + w == getSizeX() && y + h == getSizeY(); - int resolutionIndex = getIndex(series, resolution); // the compression type isn't supplied to the writer until // after setId is called, so metadata that indicates or @@ -264,8 +274,6 @@ public void saveBytes(int no, byte[] buf, int x, int y, int w, int h) byte[] paddedBuf = null; - int thisTileWidth = tileWidth[resolutionIndex]; - int thisTileHeight = tileHeight[resolutionIndex]; int thisTilePixels = thisTileWidth * thisTileHeight; // pad the last row and column of tiles to match specified tile size