2022-08-14 10:55:18 +08:00
|
|
|
class ImageFormat:
|
2022-07-08 09:33:53 +00:00
|
|
|
"""The ImageFormat class is used to
|
|
|
|
store the image format enum of an image."""
|
|
|
|
RGB888: int
|
|
|
|
RGB565: int
|
|
|
|
GRAY: int
|
|
|
|
JPEG: int
|
|
|
|
def __init__(self): ...
|
|
|
|
|
|
|
|
|
2022-08-14 10:55:18 +08:00
|
|
|
class Image:
|
2022-07-08 09:33:53 +00:00
|
|
|
"""Create a empty image. The image can be
|
|
|
|
filled with data by read a file e.g.: `read()`
|
|
|
|
or load bytes e.g:. `loadRGB888`, `loadRGB565`, `loadGray` or `loadJpeg`"""
|
|
|
|
|
|
|
|
def __init__(self): ...
|
|
|
|
|
|
|
|
def read(self, path: str):
|
2022-07-11 10:29:45 +08:00
|
|
|
"""Read the image from the specified path,
|
|
|
|
Need implement the `__platform_fopen()`, `__platform_fread()`
|
|
|
|
and `__platform_fclose()`"""
|
2022-07-08 09:33:53 +00:00
|
|
|
...
|
|
|
|
|
2022-07-11 10:22:04 +08:00
|
|
|
def write(self, path: str):
|
2022-07-11 10:29:45 +08:00
|
|
|
"""Write the image to the specified path,
|
|
|
|
Need implement the `__platform_fopen()`, `__platform_fwrite()`
|
|
|
|
and `__platform_fclose()`"""
|
2022-07-11 10:22:04 +08:00
|
|
|
...
|
|
|
|
|
2022-07-08 09:33:53 +00:00
|
|
|
def loadJpeg(self, bytes: any):
|
|
|
|
"""Load the image from bytes"""
|
|
|
|
|
|
|
|
def loadRGB888(self, width: int, height: int, bytes: bytes):
|
|
|
|
"""Load the image from bytes"""
|
|
|
|
|
|
|
|
def loadRGB565(self, width: int, hight: int, bytes: bytes):
|
|
|
|
"""Load the image from bytes"""
|
|
|
|
|
|
|
|
def loadGray(self, width: int, hight: int, bytes: bytes):
|
|
|
|
"""Load the image from bytes"""
|
|
|
|
|
|
|
|
def width(self) -> int:
|
|
|
|
"""Get the width of the image"""
|
|
|
|
|
|
|
|
def hight(self) -> int:
|
|
|
|
"""Get the hight of the image"""
|
|
|
|
|
|
|
|
def format(self) -> int:
|
|
|
|
"""Get the format of the image.
|
|
|
|
The format is one of the `ImageFormat` enum,
|
|
|
|
like `ImageFormat.RGB888`"""
|
|
|
|
|
|
|
|
def data(self) -> bytes:
|
|
|
|
"""Get the data of the image"""
|
|
|
|
|
|
|
|
def getPixel(self, x: int, y: int, channel: int) -> int:
|
|
|
|
"""Get the pixel value of the specified channel.
|
|
|
|
For example, if the format of image is `RGB888`,
|
|
|
|
the channel `0`, `1`, `2`, means `R`, `G`, `B`,
|
|
|
|
and for the format of `GRAY8`, the channel is `0`
|
|
|
|
"""
|
|
|
|
|
|
|
|
def setPixel(self, x: int, y: int, channel: int, value: int):
|
|
|
|
"""Set the pixel value of the specified channel.
|
|
|
|
For example, if the format of image is `RGB888`,
|
|
|
|
the channel `0`, `1`, `2`, means `R`, `G`, `B`,
|
|
|
|
and for the format of `GRAY8`, the channel is `0`
|
|
|
|
"""
|
|
|
|
|
|
|
|
def size(self) -> int:
|
|
|
|
"""Get the size of the image by bytes"""
|
|
|
|
|
2022-09-27 22:47:32 +08:00
|
|
|
def add(self, image: Image):
|
2022-07-13 05:13:04 +00:00
|
|
|
"""Add two images"""
|
|
|
|
|
2022-09-27 22:47:32 +08:00
|
|
|
def minus(self, image: Image):
|
2022-07-13 05:13:04 +00:00
|
|
|
"""Minus two images"""
|
2022-07-08 09:33:53 +00:00
|
|
|
|
2022-09-27 22:47:32 +08:00
|
|
|
def split(self) -> list:
|
2022-07-15 14:21:45 +08:00
|
|
|
"""Split one 3-channels image to three 1-channel"""
|
|
|
|
|
2022-09-27 22:47:32 +08:00
|
|
|
def merge(self, R: Image, G: Image, B: Image):
|
2022-07-15 14:21:45 +08:00
|
|
|
"""Merge three 1-channel image to 3-channels"""
|
|
|
|
|
2022-09-27 22:47:32 +08:00
|
|
|
|
2022-08-14 10:55:18 +08:00
|
|
|
class Converter:
|
2022-07-08 09:33:53 +00:00
|
|
|
"""The Converter class is used to
|
|
|
|
convert an image from one format to another."""
|
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
def toRGB888(image: Image):
|
|
|
|
"""Convert the image to RGB888"""
|
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
def toRGB565(image: Image):
|
|
|
|
"""Convert the image to RGB565"""
|
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
def toGray(image: Image):
|
|
|
|
"""Convert the image to Gray"""
|
2022-07-11 10:22:04 +08:00
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
def toBMP(image: Image):
|
|
|
|
"""Convert the image to BMP"""
|
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
def toBGR888(image: Image):
|
|
|
|
"""Convert the image to BGR888"""
|
2022-09-27 22:47:32 +08:00
|
|
|
def converter(image: Image, format: int):
|
2022-07-23 22:29:59 +08:00
|
|
|
"""
|
|
|
|
2:RGB888
|
|
|
|
3:BGR888
|
|
|
|
4:RGB565
|
|
|
|
5:GRAY
|
|
|
|
6:BMP
|
|
|
|
"""
|
2022-07-11 10:22:04 +08:00
|
|
|
|
2022-09-27 22:47:32 +08:00
|
|
|
|
2022-08-14 10:55:18 +08:00
|
|
|
class Transforms:
|
2022-07-11 11:22:14 +08:00
|
|
|
"""The transforms class is used to
|
2022-07-11 10:29:45 +08:00
|
|
|
supply the rotate, flip, and crop operation for an image."""
|
2022-07-11 10:22:04 +08:00
|
|
|
@staticmethod
|
|
|
|
def rotateDown(image: Image):
|
|
|
|
"""Rotate the image """
|
2022-09-27 22:47:32 +08:00
|
|
|
def threshold(image: Image, thre: int, maxval: int, thresholdType: int):
|
2022-07-18 16:00:15 +08:00
|
|
|
"""
|
|
|
|
0:THRESH_BINARY
|
|
|
|
1:THRESH_BINARY_INV
|
|
|
|
2:THRESH_TRUNC
|
|
|
|
3:THRESH_TOZERO
|
|
|
|
4:THRESH_TOZERO_INV
|
2022-07-19 18:04:38 +08:00
|
|
|
5:OTSU
|
2022-07-18 16:00:15 +08:00
|
|
|
"""
|
2022-09-27 22:47:32 +08:00
|
|
|
def setROI(image: Image, x: int, y: int, w: int, h: int):
|
2022-07-19 18:04:38 +08:00
|
|
|
"""xywh"""
|
2022-09-27 22:47:32 +08:00
|
|
|
def getOTSUthre(image: Image) -> int:
|
2022-07-19 18:04:38 +08:00
|
|
|
"""return otsu threshold"""
|
2022-09-27 22:47:32 +08:00
|
|
|
def setOTSU(image: Image):
|
2022-07-19 18:04:38 +08:00
|
|
|
"""otsu"""
|
2022-09-27 22:47:32 +08:00
|
|
|
def resize(image: Image, x: int, y: int, resizeType: int):
|
2022-07-19 18:04:38 +08:00
|
|
|
"""
|
|
|
|
resize image
|
|
|
|
0:NEAREST
|
|
|
|
TODO:
|
|
|
|
1:BILINEAR
|
2022-07-20 11:57:51 +08:00
|
|
|
"""
|
2022-09-27 22:47:32 +08:00
|
|
|
def adaptiveThreshold(image: Image, maxval: int, subsize: int, c: int, method: int):
|
2022-07-20 14:52:22 +08:00
|
|
|
"""
|
|
|
|
AdaptiveThreshold
|
|
|
|
method
|
|
|
|
0:meanFilter
|
|
|
|
1:medianFilter
|
|
|
|
#TODO 2:gaussianFilter
|
|
|
|
"""
|
2022-09-27 22:47:32 +08:00
|
|
|
|
|
|
|
|
2022-08-14 10:55:18 +08:00
|
|
|
class Filter:
|
2022-07-20 11:57:51 +08:00
|
|
|
"""The Filter class is used to
|
|
|
|
supply some Image Filtering Algorithms ."""
|
2022-09-27 22:47:32 +08:00
|
|
|
def meanFilter(image: Image, ksizex: int, ksizey: int):
|
2022-07-20 14:11:52 +08:00
|
|
|
""" mean filter,ksize is odd"""
|
2022-09-27 22:47:32 +08:00
|
|
|
def medianFilter(image: Image):
|
2022-08-14 10:55:18 +08:00
|
|
|
""" median filter,kernel size is 3*3"""
|