|
| 1 | +import typing |
| 2 | +from enum import IntEnum |
| 3 | + |
| 4 | +import numpy as np |
| 5 | +from JAbs import ClassesImportSpecT, ClassPathT, SelectedJVMInitializer |
| 6 | +from jpype import JInt # ToDo: JPype specific, create an abstraction in JAbs |
| 7 | + |
| 8 | +ji = None # initialized externally |
| 9 | + |
| 10 | + |
| 11 | +def restack(npArr: np.ndarray, perm: typing.Iterable[int]) -> np.ndarray: |
| 12 | + compsSplitted = np.moveaxis(npArr, -1, 0) |
| 13 | + permed = [] |
| 14 | + for el in perm: |
| 15 | + permed.append(compsSplitted[el]) |
| 16 | + return np.dstack(permed) |
| 17 | + |
| 18 | + |
| 19 | +def convertJavaEnum(namespace, prefix: str, name: str, enumCls: typing.Type[IntEnum] = IntEnum) -> typing.Type[IntEnum]: |
| 20 | + return enumCls(name, {el[len(prefix) :]: getattr(namespace, el) for el in dir(namespace) if el.startswith(prefix)}) |
| 21 | + |
| 22 | + |
| 23 | +class JavaImageToolsInitializer: |
| 24 | + __slots__ = ("ji", "scalaVersion") |
| 25 | + |
| 26 | + def __init__(self, classPathz: ClassPathT, classes2import: ClassesImportSpecT) -> None: |
| 27 | + self.__class__.ji.__set__(self, SelectedJVMInitializer(classPathz, classes2import)) |
| 28 | + self.loadClasses(("java.awt.image.BufferedImage", "javax.imageio.ImageIO", "java.io.File", "java.awt.image.DataBufferByte")) |
| 29 | + self.ji.ImageMode = convertJavaEnum(self.ji.BufferedImage, "TYPE_", "ImageMode") |
| 30 | + self.modeRemapping = { |
| 31 | + "RGB": (self.ImageMode.INT_RGB, None), |
| 32 | + "RGBA": (self.ImageMode["4BYTE_ABGR"], (3, 2, 1, 0)), |
| 33 | + "1": (self.ImageMode.BYTE_BINARY, None), |
| 34 | + "L": (self.ImageMode.BYTE_GRAY, None), |
| 35 | + "I;16": (self.ImageMode.USHORT_GRAY, None), |
| 36 | + "BGR;32": (self.ImageMode.INT_BGR, None) |
| 37 | + } |
| 38 | + |
| 39 | + def __getattr__(self, k: str) -> typing.Any: |
| 40 | + return getattr(self.ji, k) |
| 41 | + |
| 42 | + def __setattr__(self, k: str, v: typing.Any): |
| 43 | + setattr(self.ji, k, v) |
| 44 | + |
| 45 | + def pilImg2JavaImg(self, img): |
| 46 | + i = np.array(img) |
| 47 | + jMode, remap = self.modeRemapping[img.mode] |
| 48 | + # t = self.ImageMode() |
| 49 | + if remap: |
| 50 | + i = restack(i, remap) |
| 51 | + iJ = self.ji.BufferedImage(i.shape[1], i.shape[0], jMode) |
| 52 | + raster = iJ.getData() |
| 53 | + raster.setPixels(0, 0, i.shape[1], i.shape[0], JInt[:](bytes(i.data))) |
| 54 | + iJ.setData(raster) |
| 55 | + return iJ |
0 commit comments