|
|
发表于 2010-1-2 12:23:07
|
显示全部楼层
来自: 中国广东汕头
所谓角度捕捉,是指当十字光标在某一角度α的一定范围内选取一点时,该点自动落在该α角度线上;当我们设定捕捉角度为α时,将会以基准点作为原点、自X轴正方向出发,将整个屏幕划分为[360/α]个区间,则NXα角度就是角度捕捉线,其中,0≤N≤[360/α],[360/α]表示不大于360/α的整数。
2 w0 t; T, `) H: Y' Q4 H) O8 k% T+ h; H) D. E
所谓长度捕捉,是在角度捕捉的基础上,在某一角度线上有一系列捕捉点,该系列点离基准点的距离为捕捉长度的正整数倍,当选取直线上的一点时,落点自动落到离其最近的捕捉点上。
) Z4 p: V" z) @) i8 T9 }3 r
" Z# }6 ]5 e1 S/ G1 y( u 实现特定角度和长度捕捉的关键点是:当十字光标(即十字交叉线)移动时,程序要随时跟踪其交叉点的位置,并将该位置与用户所设定的捕捉角度与长度对应起来,从而计算出在该角度上的落点。 ( B2 {6 m% p E- A8 z
' }- ^2 Y$ P. Z) C8 E% d
以下举例说明该两个捕捉的实现过程:
" |: t5 d8 ~* E: d! e" X% u' T
1 @+ `) ^3 A" d/ i+ t 假定捕捉角度为α=30°,捕捉长度为L。 & t0 J8 t5 c4 y$ |6 M* K
. H3 F3 J* |6 P" p# [* h 当十字光标在任意的某一区间内移动时,比如在第5区间(120°~150 °)内移动时,此时,落点只能在120°或150°线上(该线在图中并不直接显示),该两根角度线的中心线为135°。当十字光标的中心点处在120°~135°之间时, 则落点应在120°线上,该落点的具体位置为由十字光标的中心点向120°线作垂线来获得,其交点D(称为垂点)即为落点,为直观起见,此时由基准点(此处为O点)向落点作一橡筋拖曳线,该橡筋拖曳线随十字光标的移动而相应移动,显示出拖动过程(见图1);同样,当十字光标的中心点处在135°~150°之间时,则落点应在150°线上,并显示相应的橡筋拖曳线。该橡筋拖曳线并不是真正的线段, 只是用XOR墨水绘制的一个向量,当用XOR墨水重新绘制一遍该向量时,该向量将从屏幕上消失,这就是本程序实现光标拖动的原理。
2 g. n m- h1 X( f: d
$ o o& R7 x+ y/ z$ p) _0 L 落点落在某一捕捉角度线上时,还得落在捕捉长度L 的整数倍的点(称为捕捉点)上,还是针对图1,其垂点必然处于某两个捕捉点A与B之间,设A与B的中点为C,当D处于A与C之间时,落点应为A;当D处于C与B之间时,落点应为B (见图1)。其中:
5 F8 H$ S. F6 F2 c7 Z, i) `9 E4 h j- f
-- --
) d+ b) `' G* H- T4 |' g. R0 P/ n& y5 D. C' V9 G2 y$ `$ d7 N
OA = n XL ; OB = (n + 1) XL
- O! j8 P6 p- h1 `
6 o# l& g* I, ] n: 非负整数。 7 d8 }: s8 ]5 ~9 Z" s
- n6 m8 E& a; x L: 捕捉长度。 此时,程序通过一定的操作将在屏幕的最上面的坐标提示行准确地显示落点相对基准点的偏移长度和偏移角度。用户可以滑动鼠标准确捕捉到目标点。 & v1 O v+ C* C4 z/ k0 B, o
1 G+ O6 W V# U至此,已实现某些特定角度及长度的捕捉。为了满足在程序执行过程中能随时更改捕捉角度和捕捉长度的需要,本程序还增加了相应的模块;另外,本程序中嵌入了窗口放缩功能模块,通过点取下拉菜单中窗口及漫游子菜单,方便了各种作图的需要。 # X% Q1 B6 Y7 }8 T2 z+ l
5 Q2 t, _) I+ N5 P7 w+ l
三、源程序清单 # U3 ?, a+ @; H
9 `9 s% `* c+ c ;; OS.LSP源程序
5 r4 m ^7 T; o- b2 d/ \' b8 o' u' M7 F* t9 u$ j" }
;;err(),出错处理子程序 ) A; ?& C# Y2 h5 d, I9 b4 { C; Y
+ i3 }- L) T8 T* Q7 I; k( h' I9 z (defun err ( msg) % E! m) u! S1 H, { E; G7 s
/ i" o0 D+ z, W' i
(if (/= msg "Function cancelled")
9 U. W" ?0 L% j- j$ v' v) a3 ?5 m6 K0 R: U j
(princ(strcat "\nError:" msg)) ;打印错误内容 ) s$ C4 \$ M' V+ R. U1 ] { `
& f2 u+ i- f0 v! M
) ;for if * Q' E! w$ V3 f/ y6 E+ f
, J+ K: L4 i& b9 r
(setq *error* olderr) - V( O( T- M! j) b7 U) {6 S
+ ^: |* x- l( b$ b5 O$ Y- n (setvar "cmdecho" scmd)
4 R" X' g* H6 I6 r! \) [ Y9 }" Y' H$ u, X# m6 [
(setvar "osmode" cosmode) 5 u* K+ A; \9 ~
8 ?; p, G+ c; `1 w
(setvar "coords" ccoords) 0 F1 F A9 J6 E2 \/ o
- v& h: J/ C, {3 Y7 ^ (princ "n\n\t --多谢使用角度捕捉2.0版,程序非正常结束--!\n")
# ~* w, G5 |$ S3 T' u, u
, m4 q5 W, F7 W# c (princ)
: f1 M7 [7 U/ b3 t* Q( a9 B& P5 \
1 }/ F% ^0 r* V/ q; {) E5 c3 Z; s ) ;for defun err / E. l- z% G: C/ b- U3 R$ }
3 N3 _1 R1 t( Q& e1 k
;; ant(),设定捕捉角度子程序 1 N; }; T, \* Z! g+ ~" E/ b
% M" P5 C% i+ V( _$ j4 ? (defun ant ( / ang0 ang1 )
$ s! M- @: @6 u/ R
& d# J( G: e: b) g5 R' R# h0 h (setq ang0 (* an0 (/ 180 pi)) ) # |1 s! D* }2 W6 f% ]( E
; h$ @& @% f: S" O3 W: d( \
(princ (strcat "\n请输入捕捉角度:<" (rtos ang0) ">_")) |
|