home *** CD-ROM | disk | FTP | other *** search
/ Windows 95 v2.4 Fix / W95-v2.4fix.iso / ACADWIN / SUPPORT / EDGE.LSP < prev    next >
Encoding:
Lisp/Scheme  |  1995-02-08  |  7.6 KB  |  231 lines

  1. ; Next available MSG number is    12 
  2. ; MODULE_ID EDGE_LSP_
  3. ;;;
  4. ;;;    edge.lsp            
  5. ;;;    
  6. ;;;    Copyright (C) 1988, 1990, 1992, 1994 by Autodesk, Inc.
  7. ;;;
  8. ;;;    Permission to use, copy, modify, and distribute this software
  9. ;;;    for any purpose and without fee is hereby granted, provided
  10. ;;;    that the above copyright notice appears in all copies and
  11. ;;;    that both that copyright notice and the limited warranty and
  12. ;;;    restricted rights notice below appear in all supporting
  13. ;;;    documentation.
  14. ;;;
  15. ;;;    AUTODESK PROVIDES THIS PROGRAM "AS IS" AND WITH ALL FAULTS.
  16. ;;;    AUTODESK SPECIFICALLY DISCLAIMS ANY IMPLIED WARRANTY OF
  17. ;;;    MERCHANTABILITY OR FITNESS FOR A PARTICULAR USE.  AUTODESK, INC.
  18. ;;;    DOES NOT WARRANT THAT THE OPERATION OF THE PROGRAM WILL BE
  19. ;;;    UNINTERRUPTED OR ERROR FREE.
  20. ;;;
  21. ;;;    Use, duplication, or disclosure by the U.S. Government is subject to
  22. ;;;    restrictions set forth in FAR 52.227-19 (Commercial Computer
  23. ;;;    Software - Restricted Rights) and DFAR 252.227-7013(c)(1)(ii) 
  24. ;;;    (Rights in Technical Data and Computer Software), as applicable.
  25. ;;;
  26. ;;;.
  27. ;;;
  28. ;;; --------------------------------------------------------------------------;
  29. ;;; DESCRIPTION
  30. ;;;
  31. ;;;   Interactive editor for changing the visibility of 3DFACE edges.           
  32. ;;;   Prompt:         "Display/<Select edge>: "                                 
  33. ;;;
  34. ;;;   Features:                                                                 
  35. ;;;    > "Display" -  Allows selective regeneration of 3DFACE's highlighting    
  36. ;;;                   invisible edges.                                          
  37. ;;;    >  Select   -  Reverses the visibility of each edge found.               
  38. ;;;
  39. ;;;   Note:                                                                     
  40. ;;;    >  EDGE uses Osnap MIDpoint as the center of a small crossing box        
  41. ;;;       when selecting edges.                                                 
  42. ;;;    >  Only edges displayed (or highlighted) can be modified.  (Use          
  43. ;;;       "Display" to display a 3DFACE.)                                       
  44. ;;;    >  Invisible edges will always be displayed if the system variable       
  45. ;;;       SPLFRAME is set to 1.                                                 
  46. ;;;
  47. ;;; --------------------------------------------------------------------------;
  48.  
  49. ;;; ----------------------------- CREATE NEW *ERROR* -------------------------;
  50.  
  51. (defun edge-er (n) 
  52.   (if (/= s "Funci≤n cancelada") 
  53.     (princ (strcat "\nError: " n))
  54.   ) 
  55.   (command) 
  56.   (command "_.UCS" "_P") 
  57.   (setvar "osmode" o1)
  58.   (setvar "gridmode" g1)
  59.   (setvar "aperture" a1)
  60.   (setvar "splframe" v1)
  61.   (setvar "ucsfollow" u1)
  62.   (command "_.UNDO" "_E") 
  63.   (setvar "cmdecho" s1)
  64.   (setq n1 -1)
  65.   (repeat (sslength faclst) 
  66.     (redraw (entupd (ssname faclst (setq n1 (1+ n1)))))
  67.   ) 
  68.   (setq *error* lisp-er)
  69.   (prin1)
  70. ;;; ---------------------------- COMMONLY USED MACROS ------------------------;
  71.  
  72. (defun getval (n e) 
  73.   (cdr (assoc n e))
  74.  
  75. (defun fltfac (ss / n1) 
  76.   (setq n1 0)
  77.   (if ss 
  78.     (repeat (sslength ss) 
  79.       (if (/= (getval 0 (entget (setq e1 (ssname ss n1)))) ;|MSG0|;"3DFACE") 
  80.         (ssdel e1 ss) 
  81.         (setq n1 (1+ n1))
  82.       )
  83.     )
  84.   ) 
  85.   ss
  86.  
  87. ;;; ------------------------- FORCE DISPLAY OF ALL EDGES ---------------------;
  88.  
  89. (defun dsply (/ ss n1 t1) 
  90.   (setvar "osmode" 0)
  91.   (initget "Seleccionar Todo") 
  92.   (setq ss (if (eq (getkword "\nSeleccionar/<Todo>: ") "Seleccionar") 
  93.              (fltfac (ssget)) 
  94.              (ssget ;|MSG0|;"_x" '((0 . ;|MSG0|;"3dface")))
  95.            ) 
  96.         n1 -1)
  97.   (setvar "osmode" 2)
  98.   (cond (ss (princ "\n** Regeneraci≤n objetos 3DCARA...") 
  99.             (repeat (sslength ss) 
  100.               (ssadd (setq t1 (ssname ss (setq n1 (1+ n1)))) faclst) 
  101.               (shohdn (entget (entupd t1)))) 
  102.             (princ "terminada.") T) 
  103.     (T (princ "\nNo se han encontrado objetos 3DCARA.") nil)
  104.   )
  105. ;;; ----------------------------- SHOW HIDDEN EDGES --------------------------;
  106.  
  107. (defun shohdn (e / b1 p1 p2 p3 p4) 
  108.   (setq b1 (getval 70 e))
  109.   (mapcar '(lambda (j k) (set j (getval k e))) 
  110.           '(p1 p2 p3 p4) 
  111.           '(10 11 12 13)) 
  112.   (if (= (logand b1 1) 1) 
  113.     (grdraw p1 p2 c1 1)
  114.   ) 
  115.   (if (= (logand b1 2) 2) 
  116.     (grdraw p2 p3 c1 1)
  117.   ) 
  118.   (if (= (logand b1 4) 4) 
  119.     (grdraw p3 p4 c1 1)
  120.   ) 
  121.   (if (= (logand b1 8) 8) 
  122.     (grdraw p4 p1 c1 1)
  123.   )
  124.  
  125. ;;; --------------------------- GET ENTITY TO EDIT ---------------------------;
  126.  
  127. (defun getfce (pt / ll ur n1 ss e1 p1) 
  128.   (setq p1 (trans pt 0 2) 
  129.         ll (trans (polar P1 (/ (* pi 5) 4) h1) 2 0) 
  130.         ur (trans (polar P1 (/ pi 4) h1) 2 0) 
  131.         n1 0)
  132.   (setvar "osmode" 0)
  133.   (if (setq ss (ssget ;|MSG0|;"_c" ll ur))
  134.     (setq ss (fltfac ss))
  135.   ) 
  136.   (setvar "osmode" 2)
  137.   ss
  138.  
  139. ;;; --------------------- MODIFY 3DFACE EDGE VISIBILITY FLAG -----------------;
  140.  
  141. (defun modfce (ss pt / n1 e1 e0 p0 b1 b2 b3) 
  142.   (setq n1 0)
  143.   (repeat (sslength ss) 
  144.     (setq e1 (entget (ssname ss n1)) 
  145.           e0 (getval -1 e1))
  146.     (ssadd e0 faclst) 
  147.     (mapcar '(lambda (j k) (set j (getval k e1))) 
  148.             '(p1 p2 p3 p4) 
  149.             '(10 11 12 13)) 
  150.     (setq p0 (if (equal (distance p3 p4) 0 1e-8) 
  151.                (mapcar '(lambda (j k l) (/ (+ j k l) 3)) p1 p2 p3) 
  152.                (mapcar '(lambda (j k l m) (/ (+ j k l m) 4)) p1 p2 p3 p4)
  153.              ))
  154.     (setq b1 (getval 70 e1) 
  155.           b2 (cond ((equal pt (inters p0 pt p1 p2) h1) 1) 
  156.                ((equal pt (inters p0 pt p2 p3) h1) 2) 
  157.                ((equal pt (inters p0 pt p3 p4) h1) 4) 
  158.                ((equal pt (inters p0 pt p4 p1) h1) 8) 
  159.                (T 0)
  160.              ) 
  161.           b3 (+ b1 (if (= (logand b1 b2) b2) 
  162.                      (- b2) 
  163.                      b2
  164.                    )
  165.              ) 
  166.           e1 (shohdn (entmod (subst (cons 70 b3) (assoc 70 e1) e1))) 
  167.           n1 (1+ n1))
  168.   ) 
  169.   T
  170. ;;; ------------------------------ MAIN PROGRAM ------------------------------;
  171.  
  172. (defun c:EDGE (/ lisp-er s1 o1 g1 a1 v1 h1 u1 faclst c1 r1 t1 ss pt n e n1) 
  173.   (setq lisp-er *error* 
  174.         *error* edge-er 
  175.         s1 (getvar "cmdecho") 
  176.         o1 (getvar "osmode") 
  177.         g1 (getvar "gridmode") 
  178.         a1 (getvar "aperture") 
  179.         v1 (getvar "splframe") 
  180.         u1 (getvar "ucsfollow") 
  181.         h1 (/ (getvar "viewsize") 100) 
  182.         faclst (ssadd) 
  183.         c1 7 
  184.         r1 T)
  185.   (setvar "cmdecho" 0)
  186.   (command "_.UNDO" "_GROUP") 
  187.   (setvar "osmode" 2)
  188.   (setvar "gridmode" 0)
  189.   (setvar "aperture" 5)
  190.   (setvar "splframe" 1)
  191.   (setvar "ucsfollow" 0)
  192.   (command "_.UCS" "_W") 
  193.   (while r1 
  194.     (initget "Visualizar") 
  195.     (setq t1 (getpoint "\nVisualizar/<designar arista>: ") 
  196.           r1 (cond ((eq t1 "Visualizar") (dsply)) 
  197.                ((eq (type t1) 'LIST) (setq ss (getfce t1))
  198.                 (cond ((null ss) (princ " No se han encontrado aristas 3DCARA.")) 
  199.                   ((= (sslength ss) 0) (princ " Este no es un objeto 3DCARA.")) 
  200.                   (t (modfce ss t1))
  201.                 )
  202.                ) 
  203.                (T nil)
  204.              ))
  205.   ) 
  206.   (command "_.UCS" "_P") 
  207.   (setvar "osmode" o1)
  208.   (setvar "gridmode" g1)
  209.   (setvar "aperture" a1)
  210.   (setvar "splframe" v1)
  211.   (setvar "ucsfollow" u1)
  212.   (command "_.UNDO" "_E") 
  213.   (setvar "cmdecho" s1)
  214.   (setq n1 -1)
  215.   (repeat (sslength faclst) 
  216.     (redraw (entupd (ssname faclst (setq n1 (1+ n1)))))
  217.   ) 
  218.   (setq *error* lisp-er)
  219.   (prin1)
  220.  
  221. ;;; --------------------------------------------------------------------------;
  222.  
  223.