From 244de73eea274a313b77bca14aab7c3a4e641aab Mon Sep 17 00:00:00 2001 From: Florian M Date: Fri, 11 Nov 2022 21:31:21 +0100 Subject: [PATCH] Fix NGFF import for datasets with no channel axis --- CHANGELOG.unreleased.md | 1 + app/models/binary/explore/NgffExplorer.scala | 7 +++++-- 2 files changed, 6 insertions(+), 2 deletions(-) diff --git a/CHANGELOG.unreleased.md b/CHANGELOG.unreleased.md index e455205939..977036dba6 100644 --- a/CHANGELOG.unreleased.md +++ b/CHANGELOG.unreleased.md @@ -30,6 +30,7 @@ For upgrade instructions, please check the [migration guide](MIGRATIONS.released - Fixed importing a dataset from disk. [#6615](https://github.com/scalableminds/webknossos/pull/6615) - Fixed a bug in the dataset import view, where the layer name text field would lose focus after each key press. [#6615](https://github.com/scalableminds/webknossos/pull/6615) - Fixed importing NGFF Zarr datasets with non-scale transforms. [#6621](https://github.com/scalableminds/webknossos/pull/6621) +- Fixed a regression in NGFF Zarr import for datasets with no channel axis. [#6636](https://github.com/scalableminds/webknossos/pull/6636) ### Removed diff --git a/app/models/binary/explore/NgffExplorer.scala b/app/models/binary/explore/NgffExplorer.scala index f094b9e920..a576683c7d 100644 --- a/app/models/binary/explore/NgffExplorer.scala +++ b/app/models/binary/explore/NgffExplorer.scala @@ -42,8 +42,11 @@ class NgffExplorer extends RemoteLayerExplorer { zarrayPath = magPath.resolve(ZarrHeader.FILENAME_DOT_ZARRAY) zarrHeader <- parseJsonFromPath[ZarrHeader](zarrayPath) ?~> s"failed to read zarr header at $zarrayPath" axisOrder <- extractAxisOrder(multiscale.axes) ?~> "Could not extract XYZ axis order mapping. Does the data have x, y and z axes, stated in multiscales metadata?" - channelAxisIndex <- axisOrder.c.toFox - } yield zarrHeader.shape(channelAxisIndex) + channelCount = axisOrder.c match { + case Some(channeAxislIndex) => zarrHeader.shape(channeAxislIndex) + case _ => 1 + } + } yield channelCount private def layersFromNgffMultiscale(multiscale: NgffMultiscalesItem, remotePath: Path,