13648893846 发表于 2018-8-6 22:55:04

三点生成与之相切圆弧并标注参数

三点生成与之相切圆弧并标注参数
2018-8-6 22:53 |系统分类:应用 ;;[功能]三点生成与之相切圆弧并标注参数
;;[用法](LC:3pt-MAKARC-Label (getpoint "\n 请输入第一点") (getpoint "\n 请输入顶点") (getpoint "\n 请输入第三点")(getreal "\n 请输入半径: "))
;;;(LC:3pt-MAKARC-Label (getpoint "\n 请输入第一点") (getpoint "\n 请输入顶点") (getpoint "\n 请输入第三点")55.7909 )
;;[作者]BY 老仓测绘上班记
(defun LC:3pt-MAKARC-Label (p1 p2 p3 R / p1 p2 p3 R jiajiao CIRCLE-mid-ang T1 arcpt1arcpt2 CIRCLEpt a
         arcBulge e arcmid arcptang1 arcptang2 arcang gonggao pt5)
;;;(setq ptlst '() ANGlst '())
(setq jiajiao (LC-3PT-Angle p1 p2 p3));多段线三点夹角
(if (> jiajiao 0)
    (progn
      (setq CIRCLE-mid-ang (/ jiajiao 2))
      (setq T1 (abs (/ R (LC-tan CIRCLE-mid-ang))));切线
      (setq arcpt1 (polar p2 (angle p2 p1) T1));圆弧起点
      (setq arcpt2 (polar p2 (angle p2 p3) T1));圆弧终点
      (setq CIRCLEpt (polar arcpt1 (- (angle p1 arcpt1) (/ pi 2)) r));圆心坐标
      (setq a (- jiajiao pi))   ;转角
)
    (progn
      (setq CIRCLE-mid-ang (/ jiajiao 2));夹角角平分线
      (setq T1 (abs (/ R (LC-tan CIRCLE-mid-ang))));切线
      (setq arcpt1 (polar p2 (angle p2 p1) T1));圆弧起点
      (setq arcpt2 (polar p2 (angle p2 p3) T1));圆弧终点
      (setq CIRCLEpt (polar arcpt1 (+ (angle p1 arcpt1) (/ pi 2)) r));圆心坐标
      (setq a (+ jiajiao pi))
    )
)
(setq e (- (distance p2 CIRCLEpt) R));外距
(setq gonggao (- (distance p2 CIRCLEpt) (sqrt(- (* R R) (* (/ (distance arcpt1 arcpt2) 2) (/ (distance arcpt1 arcpt2) 2)))) e));弓高
(setq arcmid (polar p2 (angle p2 CIRCLEpt) e));圆弧中点
(setq arcptang1 (angle CIRCLEpt arcpt1));起点角度
(setq arcptang2 (angle CIRCLEpt arcpt2));终点角度
(setq arcang (LC-3PT-Angle arcpt1 CIRCLEpt arcpt2));圆心角
(if (> jiajiao 0)
    (setq arcBulge (-(/ (* gonggao 2) (distance arcpt1 arcpt2))));凸度
    (setq arcBulge (/ (* gonggao 2) (distance arcpt1 arcpt2)));凸度
    )
(setq ARCDIST (abs(* arcang r)));弧长
(setq a (atof(LC:radian-angle a)))
(LC:make-arcpline arcpt1 arcpt2 arcBulge);生成带凸度多段线
(LC-MAK-QXBZ-TEXT (setq pt5 (getpoint "\n 请输入标注点: ")) A r T1 ARCDIST E)
)


USER2128 发表于 2018-8-7 21:32:42

本帖最后由 USER2128 于 2018-8-7 22:07 编辑

程序有点复杂,赞一个

13648893846 发表于 2018-8-9 21:01:50

USER2128 发表于 2018-8-7 21:32
程序有点复杂,赞一个

我是菜鸟,所以。。。

852456 发表于 2018-8-10 23:19:32

好多大大啊
页: [1]
查看完整版本: 三点生成与之相切圆弧并标注参数