Image模块+diaplay模块+camera模块==maixpy3

MaixPy3 提供了丰富的图像处理模块,包括 Image 模块,支持创建、加载、保存图像,以及各种图像操作如旋转、翻转、缩放、绘制图形等。同时,display 模块允许配置屏幕显示和图像展示,而 camera 模块则提供了摄像头的配置和图像捕获功能。此外,maix_vision 类集成了多种视觉操作,如色块统计、色块查找、寻线等。
摘要由CSDN通过智能技术生成
1、Image模块
1.1全局接口
# 导入imgae模块是机器视觉创作的基本对象
# image(_maix_image) 模块采用 pybind11 c++ 语言进行开发。
from maix import image

# 图像模块全局接口
# 创建Image对象
image.new 

# 加载图像数据,并创建Image对象
image.load

# 打开图像文件,并创建 Image 对象
image.open

# 加载 freetype 字体,加载后执行 draw_string() 函数将会用该函数加载的字体.
image.load_freetype(path="xxx.ttf")

# 计算某个字符串的高度和长度,方便字符串确定显示的位置。str 字符串, scale 对应 draw_string 的 scale 参数。
image.get_string_size(str="hello", [scale=1.0])

# 释放当前加载 freetype 字体
image.free_freetype()
1.2Image对象属性变量
# 返回以像素计的图像的宽度。
Image.width

# 返回以像素计的图像的高度。
Image.height

# 返回图像的格式,目前支持"RGB", "RGBA", "L", "RGB16"(RGB565)
Image.mode

# 返回以像素计的图像的大小,如相同 width height 但不同 mode 的 RGB 和 RGBA 不同缓冲区长度。
Image.size
1.3Image对象基础接口
  • 打开、关闭、加载、保存、转换、复制、清除、序列化。
# 创建一张新的图片,size为图像尺寸,color为图像填充颜色,mode为图像格式.目前支持"RGB", "RGBA", "L", "RGB16"(RGB565),
# 返回 Image 对象,以便您可以使用 . 表示法调用另一个方法。
Image.new([size = (240, 240), [color = (0, 0, 0) , [mode = "RGB"]]])

# 从二进制文件中打开一张图片,path为路径名,会统一转换成RGB模式.Image.open("./tmp.jpg")
Image.open(path)

# 将Image 对象保存成二进制文件,Image.save("./tmp.jpg")
Image.save(path)

# 在python对象中加载出一张图像,会将python对象的数据copy到Image对象内部,如将tobytes的二进制数据重新恢复成 Image对象。
# date可以是PIL对象, image.Image() 对象,bytes对象,numpy 对象.当data为bytes,numpy对象时,需要提供size和mode参数.
# 返回 Image 对象,以便您可以使用 . 表示法调用另一个方法。
Image.load(data, [size = (240, 240) , [mode = "RGB"]])

# 返回一张img类的Image 对象,img可以是"maix_image", "PIL", "numpy"
# 返回 Image 对象,以便您可以使用 . 表示法调用另一个方法。
Image.copy([img = "maix_image"])

# 清除 image.Image 对象内部的图像数据,但不删除对象。
Image.clear()

# 释放 image.Image 对象。
Image.delete()

# 返回图像的 bytes 数据,用于序列化数据。
Image.tobytes()

# 将图像调整至(w, h)大小,func 可选,size 可选(和 w h 互斥),padding 默认会按比例缩放填充,而不是 CV 的拉伸图像变形。
# 0 (INTER_NEAREST 最近邻插值)
# 1 (INTER_LINEAR 双线性插值)(默认设置)
# 2 (INTER_CUBIC 4x4像素邻域的双三次插值)
# 3 (INTER_AREA 使用像素区域关系进行重采样)
# 4 (INTER_LANCZOS4 8x8像素邻域的Lanczos插值)
# 返回 Image 对象,以便您可以使用 . 表示法调用另一个方法。
Image.resize(w, h, func = 1, padding = 1, size=(0, 0))

# 在图像上绘制一条从(x0,y0)到(x1,y1)的线。
# color 是RGB888元组。默认为灰色。
# thickness 控制线的粗细像素。
# 返回 Image 对象,以便您可以使用 . 表示法调用另一个方法。
Image.draw_line(x1, y1, x2, y2, [color = (127, 127, 127), [thickness = 1]])

# 还不确定实现接口,待测试和设计。
Image.draw_cross(x1, y1, c, size, [color = (127, 127, 127), [thickness = 1]])

# 在图像上绘制一个矩形。
# color 是RGB888元组。默认为灰色。
# thickness 控制线的粗细像素。当thickness=-1时,将会用color颜色填充整个区域.
# 返回 Image 对象,以便您可以使用 . 表示法调用另一个方法。
Image.draw_rectangle(x1, y1, x2, y2, [color = (127, 127, 127), [thickness = 1]])

# 在图像上绘制一个圆形。x, y为圆的中心点坐标, radius为圆的半径
# color 是RGB888元组。默认为灰色
# thickness 控制线的粗细像素。当thickness=-1时,将会用color颜色填充整个区域.
# 返回 Image 对象,以便您可以使用 . 表示法调用另一个方法。
Image.draw_circle(x, y, radius, [color = (127, 127, 127), [thickness = 1]])

# 在图像上绘制椭圆。
# cx, xy, rx, ry ,椭圆的中心坐标和长轴短轴.
# angle 椭圆旋转角度(0~180)
# startAngle椭圆的开始绘图角度(0~360),
# endAngle椭圆的结束绘图角度(0~360),
# color 是RGB888元组。默认为灰色。
# thickness 控制线的粗细像素。当thickness=-1时,将会用color颜色填充整个区域.
# 返回 Image 对象,以便您可以使用 . 表示法调用另一个方法。
Image.draw_ellipse(cx, xy, rx, ry, angle, startAngle, endAngle, [color = (127, 127, 127), [thickness = 1]])

# 从图像中的(x, y)位置开始绘制文本
# scale 可以放大/缩小图像上文本的大小。您可以传递大于0的整数或浮点值。
# color 是RGB888元组。默认为灰色。
# thickness 控制线的粗细像素。您可以传递大于0的整数.
# 返回 Image 对象,以便您可以使用 . 表示法调用另一个方法。
Image.draw_string(x, y, str, [scale = 1.0, [color = (127, 127, 127), [thickness = 1]]])

# 旋转图像到固定的角度,保持图像的尺寸不变
# rotate旋转角度.您可以传递大于0的浮点值.
# 返回 Image 对象,以便您可以使用 . 表示法调用另一个方法。
Image.rotate(rotate = 1.0)

# 沿着 x 或 y 轴进行翻转图像,保持图像的尺寸不变。
# 参数 -1 horizontal & vertical, 1 horizontal, 0 vertical 。
Image.flip(flip = 1)

# 转换图像的格式.
# mode为图像格式.目前支持"RGB", "RGBA", "L", "RGB16"(RGB565)
# 返回 Image 对象,以便您可以使用 . 表示法调用另一个方法。
Image.convert(mode = "RGB")

# 别名为 cut 函数接口。
# 裁剪图片返回一张全新的图片
# x, y, w, h裁剪图像的位置和大小
# 返回 Image 对象,以便您可以使用 . 表示法调用另一个方法。
Image.crop(x, y, w, h)

# 将传递的img图像画在 image.Image() 对象内部的图像上
# img只能传递 image.Image() 对象的图像.
# 返回 Image 对象,以便您可以使用 . 表示法调用另一个方法。
Image.draw_image(img, x, y)

# 得到图像x,y位置的像素值,
# 返回是一个四元组对象,(r, g, b, a),如果为灰度,那只有r有效
Image.get_pixel(x, y)
1.4Image对象视觉操作
  • maix_vision 类是对于图像的一系列操作方法的集合
# 统计函数,得到图像感兴趣区域的最大颜色值.
# roi 是感兴趣区域的矩形元组(x,y,w,h)。如果未指定,ROI即整个图像的图像矩形。 操作范围仅限于 roi 区域内的像素。尽量选取较小的区域,区域较大时统计效果比较差.
# critical为返回值区域范围,简单将统计到的最大颜色值和critical相加或相减,当为0时,返回原来的色值.co为返回的颜色空间模型.可选为0 rgb  1 lab  2 hsv
# 返回值:当co为0时返回[r, g, b]
# 当co为1时返回[L - critical, A - critical, B - critical, L + critical, A +critical, B + critical]
# 当co为2时同1
maix_vision.get_blob_color(roi = (0, 0, 0, 0), critical = 0, co = 0)

# 查找图像中所有色块,并返回一个包括每个色块的色块对象的列表。
# thresholds 必须是元组列表. [(minL, minA, minB, maxL, maxA, maxB)]roi 是感兴趣区域的矩形元组(x,y,w,h)。如果未指定,ROI即整个图像的图像矩形。 操作范围仅限于 roi 区域内的像素。
# x_stride 是查找某色块时需要跳过的x像素的数量。找到色块后,直线填充算法将精确像素。 若已知色块较大,可增加 x_stride 来提高查找色块的速度。
# y_stride 是查找某色块时需要跳过的y像素的数量。找到色块后,直线填充算法将精确像素。 若已知色块较大,可增加 y_stride 来提高查找色块的速度。
# invert 反转阈值操作,像素在已知颜色范围之外进行匹配,而非在已知颜色范围内。
# 若一个色块的边界框区域小于 area_threshold ,则会被过滤掉。
# 若一个色块的像素数小于 pixels_threshold ,则会被过滤掉。
# merge 若为True,则合并所有没有被过滤掉的色块,这些色块的边界矩形互相交错重叠。margin 可在相交测试中用来增大或减小色块边界矩形的大小。例如:边缘为1、相互间边界矩形为1的色块将被合并。
# tilt设置是否查找最小斜矩形框,为0则不查找.
# co为返回的颜色空间模型.可选为,如果不是特殊需要,请保持默认0 rgb  1 lab  2 hsv 3 灰度
# 返回值:[{'x': 140, 'y': 88, 'w': 15, 'h': 7, 'pixels': 43, 'cx': 147, 'cy': 91}](x, y, w, h)色块的外框,pixels,色块的像素大小,(cx, cy)色块的中心点.
maix_vision.find_blobs(thresholds, roi = (0,0,0,0), x_stride = 2, y_stride = 2, invert = 0, area_threshold = 10, pixels_threshold = 10, merge = 0, margin = 0, tilt = 0, co = 1)

# 该函数是在maix_vision.find_blobs的基础上通过基尔霍夫圆拟合,并返回拟合的圆.
# thresholds 必须是元组列表. [(minL, minA, minB, maxL, maxA, maxB)]
# co为返回的颜色空间模型.可选为,如果不是特殊需要,请保持默认0 rgb 1 lab 2 hsv
maix_vision.find_ball_color(thresholds, co = 1)

# 该函数是内置的寻线函数.通过自适应的图像操作,将图像中的黑线选出来,然后返回黑线的矩形区域,可以作为小车的寻线函数.
# 返回值:{'rect': [9, 229, 9, 9, 145, 9, 145, 229], 'pixels': 12959, 'cx': 77, 'cy': 119, 'rotation': -1.570796251296997}
# rect为线的框,
# pixels为线的像素大小
# (cx, cy)框的中心点
# rotation为框的偏转角度(弧度制)
maix_vision.find_line()

# 可用api接口
get_statistics
rotation_corr
gamma_corr
lens_corr
mean
find_rects
find_lines
find_circles
find_line_segments
find_apriltags
find_qrcodes
find_barcodes
2.diaplay模块
# 导入模块
from maix import 

# display.width & display.height#
# 返回当前屏幕配置的图像的宽和高。
print(display.width, display.height)# 结果<function width at 0x7f54a80f9160> <function height at 0x7f54a80f91f0>
print(display.width(), display.height())# 结果240 240

# display.config
# 配置屏幕,如大小、类型,在桌面环境上 。
# 官方的板子会自动从设备树或 fb 里取大小配置,若是桌面系统可以通过该参数配置成更大的窗口。
display.config((416, 416))
print(display.width(), display.height())#结果416 416

# display.as_image
# 可以把 display 作为 _maix_image.image 使用。
print(display.as_image())#结果<_maix_image.Image 0x2033160 " width":240, "height":240, "type"=RGB, "size":172800>

# display.show()
# 根据传入的 image 对象来自适应显示图像内容。
# 如果处于 IDE 模式下会自动进行图传到 jupyter rpyc 核心上。
from maix import display
display.show(display.as_image())
3.camera模块
# 导入模块
from maix import camera

# camera.width & camera.height
# 返回当前摄像头配置的图像的宽和高,默认值为(0,0)
print(camera.width(), camera.height())# 0 0

# camera.config
# 这个 API 涉及硬件容易使软件崩溃所以移除了,详细请查阅 maix/camera.py
# 主要用于配置摄像头,如获取的图像大小、旋转(部分芯片可选)、翻转(部分芯片可选)
# 现在作为开发调试的保留功能,像缩放、裁剪、翻转、旋转请使用 image 的一系列函数。
camera.camera.config(size=(240, 240))
#结果[v4l2] Current data format information:
#    width:320
#    height:240
#    pixelformat:56595559
print(camera.width(), camera.height())#结果 240 240

# 捕获一张图像并返回 _maix_image.image 
#(可选功能一)某些设备支持选择获取多个不同尺寸的图像,如 V831 设备。
#(可选功能二)可以返回其他模块实现的 image ,如 pillow 模块。
print(camera.capture())
#结果<_maix_image.Image 0x1eb3a10 " width":240, "height":240, "type"=RGB, "size":172800>

# camera.close
# 关闭、释放当前设备。
camera.close()

原资料链接:https://wiki.sipeed.com/soft/maixpy3/zh/api/maix/display.html

  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

栋哥爱做饭

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值