• python二次开发CATIA:文字轮廓草图


    CATIA V5 版本的草图中,并没有文字轮廓的创建命令。通常的做法是,再Drawing 文件中创建所需文本-->将 Drawing 文件另存为 dwg / dxf 格式-->打开另存的文件,文字已转为轮廓线条-->复制线条并粘贴到草图中。

    本例中,基于 opencv 和 pillow两个库,先通过 PIL 将目标文字写到一张空白的图片中,然后再通过 opencv 的findContours 方法,提取该图片中的图形轮廓,最后提取轮廓中的坐标信息,并在CATIA 草图中绘制出相应的轮廓线条。
     

    1. import win32com.client
    2. import pywintypes # 导入pywintypes模块
    3. # 启动CATIA应用
    4. catia = win32com.client.Dispatch('CATIA.Application')
    5. catia.visible=1
    6. # 输入文字并转码
    7. text=input('请输入文字:\n')
    8. str = text.encode('utf8').decode('utf8')
    9. # 字体大小与颜色
    10. fontsize=100
    11. fontcolor=(0,0,0)
    12. # 导入所需的库
    13. from PIL import Image, ImageDraw, ImageFont
    14. # 创建一张白背景图片,尺寸根据输入文字数量自动确定
    15. img_PIL=Image.new('RGBA',(100*len(str)+10,110),'white')
    16. draw = ImageDraw.Draw(img_PIL)
    17. # 设置文字属性
    18. font = ImageFont.truetype('simkai.ttf', fontsize) #字体与字号
    19. fillColor = fontcolor # 字体颜色
    20. position = (5, 5) # 文字位置,距左/上
    21. # 把字写写到图片上
    22. draw.text(position, str, font=font, fill=fillColor)
    23. import cv2
    24. import numpy as np
    25. frame = cv2.cvtColor(np.asarray(img_PIL),
    26. cv2.COLOR_RGB2BGR) # 转成OpenCV格式
    27. # cv2.imshow('result',frame)
    28. # cv2.waitKey()
    29. # 将图像转换成灰度图像,并执行图像高斯模糊,以及转化成二值图像
    30. gray=cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)
    31. # blurred = cv2.GaussianBlur(gray, (1,1), 0)
    32. ret,image_binary = cv2.threshold(gray,
    33. 127,
    34. 255,
    35. cv2.THRESH_BINARY)
    36. # cv2.imshow('result',image_binary)
    37. # cv2.waitKey()
    38. # 从二值图像中提取轮廓
    39. # contours中包含检测到的所有轮廓,以及每个轮廓的坐标点
    40. contours = cv2.findContours(image_binary.copy(),
    41. cv2.RETR_TREE,
    42. cv2.CHAIN_APPROX_TC89_KCOS)[0]
    43. # 将轮廓画在图像上并显示
    44. cv2.drawContours(frame,contours,-1,(0,0,255),1)
    45. try:
    46. doc = catia.activedocument
    47. sel = doc.selection
    48. part = doc.part
    49. sketch = part.inworkobject
    50. f2d = sketch.factory2d
    51. catia.refreshdisplay = False
    52. catia.HSOSynchronized = False
    53. for i in range(1, len(contours)):
    54. c = contours[i]
    55. for j in range(0, len(c) - 1):
    56. if j < len(c) - 2:
    57. pt1 = c[j][0]
    58. pt2 = c[j + 1][0]
    59. else:
    60. pt1 = c[j][0]
    61. pt2 = c[0][0]
    62. # print(pt1,pt2)
    63. ln = f2d.createline(pt1[0] - 5,
    64. -pt1[1] + fontsize + 5,
    65. pt2[0] - 5,
    66. -pt2[1] + fontsize + 5)
    67. catia.refreshdisplay = True
    68. catia.HSOSynchronized = True
    69. except pywintypes.com_error as e:
    70. # 如果出现错误,可能是因为没有活动文档
    71. print("无法获取活动文档,请确保CATIA应用程序中已有打开的文档。")
    72. print(e)

  • 相关阅读:
    【Spring Security 系列】(二)剖析基础组件之认证功能
    【Java面试】第三章:P6级面试
    STM32实战总结:回调函数
    1024动态
    MTK平台Metadata的加载(3)——其他Static和Request加载
    编译 mesa
    万字博客带你全面剖析Spring的依赖注入
    CSS 定位布局
    07.webpack5搭建Vue环境
    win11安装通过WSL安装docker
  • 原文地址:https://blog.csdn.net/T20151470/article/details/133517205