172 lines
4.7 KiB
Python
Raw Normal View History

2022-08-14 10:55:18 +08:00
class ImageFormat:
"""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:
"""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-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
...
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):
"""Add two images"""
2022-09-27 22:47:32 +08:00
def minus(self, image: Image):
"""Minus two images"""
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:
"""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):
"""
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:
"""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 """
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
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):
"""xywh"""
2022-09-27 22:47:32 +08:00
def getOTSUthre(image: Image) -> int:
"""return otsu threshold"""
2022-09-27 22:47:32 +08:00
def setOTSU(image: Image):
"""otsu"""
2022-09-27 22:47:32 +08:00
def resize(image: Image, x: int, y: int, resizeType: int):
"""
resize image
0:NEAREST
TODO:
1:BILINEAR
"""
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:
"""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"""