明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 2460|回复: 5

[求助]请高手添加:将计算结果保存至剪贴板

[复制链接]
发表于 2010-8-1 17:17:00 | 显示全部楼层 |阅读模式

 

 

下面这段程序由网络收集,感谢原作者!

 

   请求高手在保持原程序功能不变的情况下添加:“将程序计算结果自动复制到剪贴板,按回车或空格键退出”的功能。谢谢!

 

(defun c:jxjs (/ p1 p2 dx dy ox jd fx dcl_1)
  (command "undo" "be")
  (initget 1)
  (setq p1 (getpoint "\n请选择两圆弧交点: "))
  (initget 1)
  (setq p2 (getpoint "\n请选择圆心: "))
 (setq dx (- (car p2) (car p1))
 dy (- (cadr p2) (cadr p1))
 ox (sqrt (+ (* dx dx) (* dy dy)));;;两点间距离
 jd (/ (* (* 2 (- (/ pi 4) (atan ox 25)))180)pi);;;两结构面交线的倾角
 fx (- 90 (* (/ (angle p1 p2 )pi)180));;;两结构面交线倾向
  )
  (if (< fx 0)
    (setq fx (+ 360 fx))
  )
  (setq jd (strcat  (rtos fx 2 1)"°∠" (rtos jd 2 1)"°"))
  (princ "\n两结构面交线的产状: ")
  (princ jd)
 
  (setq dcl_1 (load_dialog "bg_jllx.dcl"))
  (if (not (new_dialog "dcl_bg_cpt" dcl_1))(exit))
  (set_tile "text3" jd)
  (action_tile "accept" " (done_dialog) ")
  (start_dialog)
  (unload_dialog dcl_1)

  (command "undo" "e")
  (princ)
)

 楼主| 发表于 2010-8-3 09:01:00 | 显示全部楼层
自己顶一下。。。
发表于 2010-8-3 10:20:00 | 显示全部楼层

用这个函数改造到VBA用就可以。

http://bbs.mjtd.com/forum.php?mod=viewthread&tid=29218

发表于 2010-8-3 16:58:00 | 显示全部楼层
[Post=10]
  1. (defun c:jxjs (/ p1 p2 dx dy ox jd fx dcl_1 jdt i)
  2. (vl-load-com)
  3.   (defun PutClipText (str / html result)
  4.     (if (= 'STR (type str))
  5.       (progn
  6. (setq html   (vlax-create-object "htmlfile")
  7.        result (vlax-invoke
  8.          (vlax-get (vlax-get html 'ParentWindow)
  9.      'ClipBoardData
  10.          )
  11.          'setData
  12.          "Text"
  13.          str
  14.        )
  15. )
  16. (vlax-release-object html)
  17. str
  18.       )
  19.     )
  20.   )
  21. ;;;  (command "undo" "be")
  22. ;;;  (initget 1)
  23.   (setq jdt "")
  24.   (setq i 0)
  25.   (while (and (setq p1 (getpoint "\n请选择两圆弧交点:<回车或空格键退出> "))
  26.        (setq p2 (getpoint "\n请选择圆心: "))
  27.   )
  28.     (progn
  29. ;;;      (initget 1)
  30.       (setq dx (- (car p2) (car p1))
  31.      dy (- (cadr p2) (cadr p1))
  32.      ox (sqrt (+ (* dx dx) (* dy dy)))
  33. ;;;两点间距离
  34.      jd (/ (* (* 2 (- (/ pi 4) (atan ox 25))) 180) pi)
  35. ;;;两结构面交线的倾角
  36.      fx (- 90 (* (/ (angle p1 p2) pi) 180))
  37. ;;;两结构面交线倾向
  38.       )
  39.       (if (< fx 0)
  40. (setq fx (+ 360 fx))
  41.       )
  42.       (setq jd (strcat (rtos fx 2 1) "°∠" (rtos jd 2 1) "°"))
  43.       (setq jdt (strcat jdt jd "\r\n"))
  44.       (princ (strcat "\n两结构面交线的产状: "
  45.        jd
  46.        "   当前记录:"
  47.        (itoa (setq i (1+ i)))
  48.       )
  49.       )
  50.       (PutClipText jdt)
  51.     )
  52.   )
  53. ;;;  (setq dcl_1 (load_dialog "bg_jllx.dcl"))
  54. ;;;  (if (not (new_dialog "dcl_bg_cpt" dcl_1))
  55. ;;;    (exit)
  56. ;;;  )
  57. ;;;  (set_tile "text3" jd)
  58. ;;;  (action_tile "accept" " (done_dialog) ")
  59. ;;;  (start_dialog)
  60. ;;;  (unload_dialog dcl_1)
  61. ;;;  (command "undo" "e")
  62.   (princ)
  63. )
[/Post]

点评

好程序   发表于 2010-8-3 00:00

评分

参与人数 1明经币 +1 收起 理由
mccad + 1 【好评】表扬一下

查看全部评分

 楼主| 发表于 2010-8-3 19:28:00 | 显示全部楼层
完全达到应用要求,衷心感谢给予帮助的好心人!!
发表于 2014-7-5 13:18:19 | 显示全部楼层
好,正需要
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-5-24 09:15 , Processed in 0.243498 second(s), 26 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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