From 9670f7979b4ca8629acab224e10d472cfc9d02ff Mon Sep 17 00:00:00 2001 From: Sam Tygier Date: Tue, 12 Nov 2024 16:48:40 +0000 Subject: [PATCH] Make BadDataOverlay mixin an abstract base class --- .../gui/widgets/bad_data_overlay/bad_data_overlay.py | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) diff --git a/mantidimaging/gui/widgets/bad_data_overlay/bad_data_overlay.py b/mantidimaging/gui/widgets/bad_data_overlay/bad_data_overlay.py index 8c784b11db6..45ef95bc883 100644 --- a/mantidimaging/gui/widgets/bad_data_overlay/bad_data_overlay.py +++ b/mantidimaging/gui/widgets/bad_data_overlay/bad_data_overlay.py @@ -2,11 +2,13 @@ # SPDX - License - Identifier: GPL-3.0-or-later from __future__ import annotations +from abc import abstractmethod, ABC from collections.abc import Callable import numpy as np from pyqtgraph import ColorMap, ImageItem, ViewBox +from mantidimaging.gui.utility.qt_helpers import _metaclass_sip_abc from mantidimaging.gui.widgets.indicator_icon.view import IndicatorIconView from mantidimaging.core.utility import finder @@ -54,7 +56,7 @@ def clear(self) -> None: self.overlay.clear() -class BadDataOverlay: +class BadDataOverlay(ABC, metaclass=_metaclass_sip_abc): """ Mixin class to be used with MIImageView and MIMiniImageView """ @@ -69,12 +71,14 @@ def __init__(self) -> None: self.sigTimeChanged.connect(self.check_for_bad_data) @property + @abstractmethod def image_item(self) -> ImageItem: - raise NotImplementedError + ... @property + @abstractmethod def viewbox(self) -> ViewBox: - raise NotImplementedError + ... def enable_nan_check(self, enable: bool = True, actions: list[tuple[str, Callable]] | None = None) -> None: if enable: