这篇文章主要介绍了如何基于pythonnet调用halcon脚本,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
最近的项目中遇到了使用python程序结合不同部分,其中包括使用halcon处理拍摄到的图像。
halcon本身提供了c++与.NET的开发库,但无python库,网上有pyhalcon之类的库,但功能与原版并不一致。
这片文章默认大家已经有halcon.NET的开发基础了,也会使用HDevEngine调用halcon脚本。这样的话自己看一下pythonnet的说明也能会哈。主要网上没人写过,我综合总结一下。而且最后一段才是重点,不同平台的数据类型变化。
1.pythonnet简介
- pythonnet是cpython的扩展
- pythonnet提供了cpython和.net程序集之间交互的桥梁
- pythonnet开源在github上
- 通过`pip install pythonnet`安装
- pythonnet的使用帮助,请参见github.
ref类型的参数如何返回
- 返回值的第一个元素是c#的返回值
- 返回值的第二个元素就是ref的值了,ref String[] 对应的返回值第二个元素就是元组tuple
2.如何使用pythonnet调用halcon函数
import clr # 导入pythonnet import sys import System # 导入.NET系统库 from System import String, Char, Int32, Environment, IntPtr #导入.NET变量。
这一步所有.NET库的导入IDE编辑器都会提示找不到引用,但是只要名称对,就能DEBUG和运行。
# 导入halcon支持库 d = clr.AddReference("source/halcondotnet") print(d) # 打印库的信息,包括你的halcon版本 # 导入halcon脚本引擎库 d = clr.AddReference("source/hdevenginedotnet") from HalconDotNet import * 定义使用HDevEngine来调用halcon脚本是最方便的在python中。 class HdevEnginePy: # halcon过程变量,也就是函数。 Procedure = HDevProcedure() # halcon程序变量,就是halcon脚本文件 Program = HDevProgram() ourProcedure = "hdev/procedures" # 我们自己写的函数脚本目录 def __init__(self): # 声明halcon的HDev引擎。 self.MyEngine = HDevEngine() self.MyEngine.SetProcedurePath(self.ourProcedure) # 添加我们的脚本目录 return def get_proc_names(self): procedure_name = self.MyEngine.GetProcedureNames() # 获取并打印我们所有加载的函数名,可用于检查 return procedure_name def load_proc(self): try: # 加载自定义函数,打印输入变量名称 self.Procedure = HDevProcedure("函数名") print("加载脚本函数 成功!") self.ProcCall = HDevProcedureCall(self.Procedure) # 可执行函数对象 ctrlNames = self.Procedure.GetInputCtrlParamNames() print("-输入控制变量:", ctrlNames) iconNames = self.Procedure.GetInputIconicParamNames() print("-输入图像变量:", iconNames) except: print("加载halcon函数脚本出错。") self.ProcCall.Dispose() return def excute_proc(self): # 测试用。 try: image = HImage() # 声明halcon的Himage变量 image.ReadImage("images/apple.bmp") # 加载图像 self.ProcCall.SetInputIconicParamObject("image", image) # 传入图像参数 thmin = HTuple(128) thmax = HTuple(255) self.ProcCall.SetInputCtrlParamTuple("thmin", thmin) # 传入控制变量参数 self.ProcCall.SetInputCtrlParamTuple("thmax", thmax) self.ProcCall.Execute() # 执行函数 FinArea = self.ProcCall.GetOutputCtrlParamTuple("maxArea") # 取得返回变量。 print(FinArea) except: print("执行脚本异常") finally: self.ProcCall.Dispose() exit() return
3.如何把ptyhon图像格式转化为HImage
python中的图像格式我使用ndarry,是不能直接作为参数传入halcon函数的,会报错。需要先转为HImage对象。
正确的转换效果
测试用原图,发现 没加偏移量的转换结果。
def converttoHImage(ndArray): # 把ndArray格式的图像转换成HImage,这是实验下来最兼具速度和内存使用的方法。 # 提取BGR各通道,注意python中ndArray的通道顺序不一样。 imgB = ndArray[0:ndArray.shape[0], 0:ndArray.shape[1], 0] imgG = ndArray[0:ndArray.shape[0], 0:ndArray.shape[1], 1] imgR = ndArray[0:ndArray.shape[0], 0:ndArray.shape[1], 2] # 将BGR通道降维成一维数组 imgBflat = imgB.flatten() imgGflat = imgG.flatten() imgRflat = imgR.flatten() # 生成字节数组内存地址,且有32个地址偏移。 Bbuffer = bytes(imgBflat) Bptr = id(Bbuffer) intptrB = IntPtr.Overloads[int](Bptr + 32) Gbuffer = bytes(imgGflat) Gptr = id(Gbuffer) intptrG = IntPtr.Overloads[int](Gptr + 32) Rbuffer = bytes(imgRflat) Rptr = id(Rbuffer) intptrR = IntPtr.Overloads[int](Rptr + 32) imgSnap = HImage() # 将三个通道的内存地址传入 imgSnap.GenImage3("byte", ndArray.shape[1], ndArray.shape[0], intptrR, intptrG, intptrB) return imgSnap
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
P70系列延期,华为新旗舰将在下月发布
3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。
而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?
根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。
更新日志
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]