明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 1831|回复: 8

请教怎样把“含有弧段pline线”转化为pline?

[复制链接]
发表于 2013-3-27 10:09:29 | 显示全部楼层 |阅读模式
请教高手一个问题:请教怎样把“含有弧段pline线”转化为pline?

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?注册

x
"觉得好,就打赏"
还没有人打赏,支持一下
发表于 2013-3-27 10:26:50 | 显示全部楼层
楼主的意思是用小的直线段来拟合圆弧。早期的线切割机床有些没有圆弧功能,就需要做这种处理。
楼主希望小的直线段的长度是多少?或者说对应的圆角是多大?
发表于 2013-3-27 10:39:01 | 显示全部楼层
一个思路
先以 Divide / measure
取得点集后以 Line 绘制
用 OverKill 合并共线之直线
再 Pedit ...
发表于 2013-3-27 11:55:23 | 显示全部楼层
  1. (defun c:FitPl
  2.        (/ ENT FGX VERTEXSNUM N SECDEV PLIST D1 D2 D K D0 PARAM obj)
  3.   ;;直线拟合多段线 By Gu_xl
  4.   (while (not (setq ent (car (entsel "\n选择多段线:")))))
  5.   (setq obj (vlax-ename->vla-object ent))
  6.   (setq fgx (getdist "\n输入最小分割间距<0.5>:"))
  7.   (if (null fgx)
  8.     (setq fgx 0.5)
  9.     )
  10.   (setq vertexsNum
  11.          (fix (vlax-curve-getEndParam ent))
  12.         n 0
  13.         )
  14.   (repeat vertexsNum
  15.     (if (setq secdev (vlax-curve-getSecondDeriv ent n))
  16.       (if (equal '(0.0 0.0 0.0) secdev 1e-8)
  17.         (setq plist (cons (vlax-curve-getPointAtParam ent n) plist))
  18.         (progn
  19.           (setq d1    (vlax-curve-getdistAtParam ent n)
  20.                 d2    (vlax-curve-getdistAtParam ent (1+ n))
  21.                 d     (- d2 d1)
  22.                 k     (fix (/ d fgx))
  23.                 d0    (/ 1.0 (1+ k))
  24.                 param n
  25.                 )
  26.           (setq plist (cons (vlax-curve-getPointAtParam ent n) plist))
  27.           (if (equal d0 1.0 0.001)
  28.             (setq plist
  29.                    (cons (vlax-curve-getPointAtParam ent (+ 0.5 param))
  30.                          plist
  31.                          )
  32.                   )
  33.             (repeat k
  34.               (setq plist (cons (vlax-curve-getPointAtParam
  35.                                   ent
  36.                                   (setq param (+ param d0))
  37.                                   )
  38.                                 plist
  39.                                 )
  40.                     )
  41.               )
  42.             )
  43.           )
  44.         )
  45.       )
  46.     (setq n (1+ n))
  47.     )
  48.   (if (not (vlax-curve-isClosed ent))
  49.     (setq plist (cons (vlax-curve-getEndPoint ent) plist))
  50.     )
  51.   (reverse plist)
  52.   (command "pline")
  53.   (foreach p plist
  54.     (command "_non" (trans p 0 1))
  55.     )
  56.   (command "")
  57.   (if (vlax-curve-isClosed obj)
  58.     (vla-put-closed
  59.       (vlax-ename->vla-object (entlast))
  60.       :vlax-true
  61.       )
  62.     )
  63.   (princ)
  64.   )
发表于 2013-3-27 11:56:38 | 显示全部楼层
根据线段上的弧 计算出等分点 然后把凸度去除 添加顶点
 楼主| 发表于 2013-3-27 13:23:10 | 显示全部楼层
非常感谢超级版主Gu_xl,您超牛!
发表于 2013-3-28 09:52:55 | 显示全部楼层
Gu_xl 发表于 2013-3-27 11:55

试用了,不过好像不太完美,弧、SP均有些问题
发表于 2013-3-28 10:51:37 | 显示全部楼层
(acet-autoload2 '("FLATTENSUP.LSP" (acet-flatn ss hide)))
(acet-flatn (ssget) t)
您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|CAD论坛|CAD教程|CAD下载|联系我们|关于明经|明经通道 ( 粤ICP备05003914号 )  
©2000-2023 明经通道 版权所有 本站代码,在未取得本站及作者授权的情况下,不得用于商业用途

GMT+8, 2024-11-17 10:56 , Processed in 0.178287 second(s), 26 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表