1 Star 0 Fork 2

chenyp401/CAM

forked from zzthfut/CAM 
加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
ClipperAdaptor.py 1.25 KB
一键复制 编辑 原始数据 按行查看 历史
zzthfut 提交于 2023-08-08 21:17 . 8-6
import math
from GeomBase import Point3D
import pyclipper
from Polyline import Polyline
class ClipperAdaptor:
def __init__(self, digits=7):
self.f = math.pow(10, digits)
self.arcTolerance = 0.005
def toPath(self, poly):
path = []
for pt in poly.points:
path.append((pt.x * self.f, pt.y * self.f))
return path
def toPaths(self, polys):
paths = []
for poly in polys:
paths.append(self.toPath(poly))
return paths
def toPoly(self, path, z=0, closed=True):
poly = Polyline()
for tp in path:
poly.addPoint(Point3D(tp[0] / self.f, tp[1] / self.f, z))
if len(path) > 2 and closed:
poly.addPoint(poly.startPoint())
return poly
def toPolys(self, paths, z=0, closed=True):
polys = []
for path in paths:
polys.append(self.toPoly(path, z, closed))
return polys
def offset(self, polys, delta, jt=pyclipper.JT_SQUARE):
pco = pyclipper.PyclipperOffset()
pco.ArcTolerance = self.arcTolerance * self.f
pco.AddPaths(self.toPaths(polys), jt, pyclipper.ET_CLOSEDPOLYGON)
sln = pco.Execute(delta * self.f)
return self.toPolys(sln, polys[0].startPoint().z)
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
Python
1
https://gitee.com/chenyp401/cam.git
git@gitee.com:chenyp401/cam.git
chenyp401
cam
CAM
master

搜索帮助