Jump to content

Getting objects onto snap without using lisp


bustr

Recommended Posts

Nothing in the drawing I'm working on is drawn on snap. I would like to correct this.

 

I have a lisp routine that can do this. It is shown below. However, I am using AutoCAD LT 2023 which doesn't allow lisp routines.

 

Does anyone know of another way to do this?

 

 

 

This lisp routine forces object onto a 1/16" snap.

 

 

(defun ROUND (NMBR)
  (setq RMDR (rem NMBR SNPV))
  (cond
    ((and (>= (abs RMDR) 0.0) (<= (abs RMDR) (/ SNPV 2.0)))
     (- NMBR RMDR)
    )
    ((and (> (abs RMDR) (/ SNPV 2.0)) (< (abs RMDR) SNPV))
     (+ NMBR (- SNPV RMDR))
    )
    ((or (= (abs RMDR) 0.0) (= (abs RMDR) (/ SNPV 2.0)))
     (+ NMBR 0.0)
    )
  ) ; cond
) ; end of ROUND

 ;--------------------------------------------------------------------------------
 ; THIS ROUTINE MOVES THE FOLLOWING TO THE NEAREST SNAP POINT:
 ; 1) ENDS OF LINES, 2) CENTERS OF ARCS AND CIRCLES 3) BLOCK & TEXT INSERT POINTS
 ; THIS WORKS ONLY ON A RECTANGULAR SNAP WHERE X & Y ARE EQUAL.
 ;
 ; NOTES: ADD PROVISION TO MAKE SURE HOR/VERT LINES REMAIN AS-IS
 ;        MAKE SURE TO IGNORE ISOMETRIC DRAWINGS


(defun C:16thSnapfix (/      SNPV     ENTS   CNTR   EDAT   ETYP
           STRT      XVL1     YVL1    RND1   ENDP   XVL2   YVL2
           RND2      ARAD     RAD1    VRCT   PLST   PLXV   PLYV
           PLNW
          )
 ;--------------------------------------------------------------------------------

  (setq SNPV 0.0625) ; set SNAP value

  (setvar "SNAPUNIT" (list SNPV SNPV))
  (setvar "CMDECHO" 0)
  (setvar "SNAPMODE" 1)
  (setvar "GRIDUNIT" (list 0.250 0.250))
  (setvar "GRIDMODE" 1)
  (setvar "OSMODE" 0)
  (command "REGEN")
  (setvar "PLINETYPE" 2) ; set new plines to LWPOLYLINEs
  (command "CONVERT" "ALL" "ALL") ; convert all plines to LWPOLYLINEs

  (setq    ENTS (ssget "X"
            '((-4 . "<OR")
              (0 . "ARC")
              (0 . "CIRCLE")
              (0 . "INSERT")
              (0 . "LINE")
              (0 . "*POLYLINE")
              (0 . "*TEXT")
              (-4 . "OR>")
             )
         )
  )

  (setq CNTR (1- (sslength ENTS)))

  (while (>= CNTR 0)
    (progn
      (setq EDAT (entget (ssname ENTS CNTR)))
      (setq ETYP (cdr (assoc 0 EDAT)))

      (cond
 ;--------------------------------------------------------------------------------
    ((or (= ETYP "LINE")
         (= ETYP "INSERT")
         (= ETYP "TEXT")
         (= ETYP "MTEXT")
     )

 ; EVAL THE START POINT
     (setq STRT (assoc 10 EDAT) ; start point
           XVL1 (round (cadr STRT)) ; X value
           YVL1 (round (caddr STRT)) ; Y value
     )

     (setq RND1 (list 10 XVL1 YVL1 0.0) ; build a code 10 list
           EDAT (subst RND1 (assoc 10 EDAT) EDAT)
 ; repl old list for new
     )
     (entmod EDAT) ; update the entity

 ; EVAL THE END POINT
     (if (/= (assoc 11 EDAT) nil)
       (progn
         (setq ENDP    (assoc 11 EDAT) ; end point
           XVL2    (round (cadr ENDP)) ; X value
           YVL2    (round (caddr ENDP)) ; Y value
           RND2    (list 11 XVL2 YVL2 0.0) ; build a code 11 list
           EDAT    (subst RND2 (assoc 11 EDAT) EDAT)
 ; repl old list for new
         )
         (entmod EDAT) ; update the entity
       ) ; progn
     ) ; if
    ) ; cond LINE, INSERT, TEXT

 ;--------------------------------------------------------------------------------
    ((or (= ETYP "ARC") (= ETYP "CIRCLE"))
     (setq STRT (assoc 10 EDAT) ; start point
           XVL1 (round (cadr STRT)) ; X value
           YVL1 (round (caddr STRT)) ; Y value
           EDAT (subst (list 10 XVL1 YVL1 0.0) (assoc 10 EDAT) EDAT)
 ; repl old list for new
           ARAD (assoc 40 EDAT) ; radius
           RAD1 (round (cdr ARAD))
           EDAT (subst (cons 40 RAD1) (assoc 40 EDAT) EDAT)
 ; repl old rad for new
     )
     (entmod EDAT) ; update the entity
    ) ; 2nd cond

 ;--------------------------------------------------------------------------------

    ((if (= ETYP "LWPOLYLINE")
       (progn
         (setq VRCT 0) ; vertex counter
         (setq PLST (assoc 10 EDAT)) ; the 1st vertex
         (while (/= VRCT (length EDAT))
           (if (= (car (nth VRCT EDAT)) 10)
         (progn
           (setq PLST (nth VRCT EDAT)
             PLXV (round (cadr PLST)) ; X val
             PLYV (round (caddr PLST)) ; Y val
             PLNW (list 10 PLXV PLYV) ; new list
             EDAT (subst PLNW PLST EDAT)
           )
           (entmod EDAT)
         ) ; progn
           ) ; if
           (setq VRCT (1+ VRCT))
         ) ; while
       ) ; progn
     ) ; if
    ) ; 3rd cond

 ;--------------------------------------------------------------------------------

      ) ; end of conds

      (setq CNTR (1- CNTR))
      (princ)
    ) ; progn

  ) ; while

  (setvar "CMDECHO" 1)
  (princ)

) ; end defun


 

Link to comment
Share on other sites

1 hour ago, tombu said:

I have thought about upgrading. But, autocad has made so many "improvements" that I have to spend a week straightening out these things after a new installation. 

 

 

Why not use the 2024 or just released 2025 version of AutoCAD LT with lisp included instead?

https://help.autodesk.com/view/ACDLT/2024/ENU/?guid=GUID-FB2F8870-8CC0-4062-AA06-9D2893F8E09E

I've never used LT and couldn't imagine working without lisp functions.

Link to comment
Share on other sites

Try the following and see if it shows any promise.  The results are a function of the extents and location in WCS.

 

Move [enter] 

all [enter]

[enter]

1e16,1e16 [enter] [enter]

Move [enter] 

all [enter]

[enter]

-1e16,-1e16 [enter][enter]

 

Since the precision of AutoCAD is approcimately 15 signifcant digits this action moves object beyond its precision resultig in a rounding of coordinates. It may not do what you want and there could be surprises but its easy to try!

 

Link to comment
Share on other sites

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

Guest
Unfortunately, your content contains terms that we do not allow. Please edit your content to remove the highlighted words below.
Reply to this topic...

×   Pasted as rich text.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

×
×
  • Create New...