7empest Posted August 21 Share Posted August 21 (edited) Hello, This is my first post ever on here so I apologize if this is not formatted correctly. Basically, I am looking for a lisp that can auto dimension the distance between 2 lots along a line. For example: The pink line is setback 6m from the blue line and I would want a dimension the distance between each lot along the pink line. I have tried using some auto dimension lisps, but they only really work for total length of each line. Does anyone have a lisp recommendation for this type of dimensioning? Thank you so much for your help! Edited August 21 by 7empest Quote Link to comment Share on other sites More sharing options...
ronjonp Posted August 21 Share Posted August 21 Welcome! If you break those into segments along the lot lines then it would be easy to add a length field at the midpoints. Quote Link to comment Share on other sites More sharing options...
7empest Posted August 21 Author Share Posted August 21 34 minutes ago, ronjonp said: Welcome! If you break those into segments along the lot lines then it would be easy to add a length field at the midpoints. Thank you for the reply. With the link that you have attached, I would need to make an account. Is what you linked some sort of lisp that will break up each frontage line between each lot? I know of the "break" tool in autocad, but when working on a subdivision with 2000+ lots, it would take longer to break them all up than to manually dimension them. Unless what you've linked solves that? Thank you again for your reply! Quote Link to comment Share on other sites More sharing options...
BIGAL Posted August 22 Share Posted August 22 Most land development plans have 2 choices individual frontages or a pline between intersecting roads. Sometimes both. You need to post a dwg with multiple dimensions not just 2. So get a better idea of dimension variations. Quote Link to comment Share on other sites More sharing options...
7empest Posted August 22 Author Share Posted August 22 Attached is an example. The pink lines are the setbacks from which the frontages need to be measured between the two lots. But i would need the lisp to work with other drawings as well, not just this specific one. I have dimensioned this one before so you can unfreeze the layer to see those dimensions. Testcad.dwg Quote Link to comment Share on other sites More sharing options...
7empest Posted August 22 Author Share Posted August 22 To better explain what I want to do: - I want to isolate LOT_LINES and LOT_CHORD FRONTAGE - Select everything - have the lisp spit out the dimensions between each lot along the LOT_CHORD FRONTAGE Quote Link to comment Share on other sites More sharing options...
7empest Posted August 22 Author Share Posted August 22 (edited) https://lee-mac.com/intersectionslength.html This is almost exactly what I need!! I just need it to be dimensions and not mtext Edited August 22 by 7empest Quote Link to comment Share on other sites More sharing options...
pkenewell Posted August 22 Share Posted August 22 3 minutes ago, 7empest said: https://lee-mac.com/intersectionslength.html This is almost exactly what I need!! I just need it to be dimensions and not mtext You should contact @Lee Mac from his contact page and see if he will alter it for you. I personally would prefer not to monkey with his code. Quote Link to comment Share on other sites More sharing options...
7empest Posted August 22 Author Share Posted August 22 (edited) 4 minutes ago, pkenewell said: You should contact @Lee Mac from his contact page and see if he will alter it for you. I personally would prefer not to monkey with his code. Thank you, I have messaged them Edited August 22 by 7empest Quote Link to comment Share on other sites More sharing options...
7empest Posted August 23 Author Share Posted August 23 (edited) https://forums.autodesk.com/t5/visual-lisp-autolisp-and-general/lisp-for-creating-dimension-at-intersections-of-selected-lines/td-p/6800455 So I have found this code, however, I can't seem to get it to work. After I create it in a .lsp format, it prompts when I type in "diminterns" but when I select a line or pline, nothing happens. Is anyone able to see if the same thing is happening to them? Thanks everyone! EDIT: I figured it out. I needed to select the lot lines and the curve it should be measuring from! Edited August 23 by 7empest Quote Link to comment Share on other sites More sharing options...
BIGAL Posted August 24 Share Posted August 24 Thought I posted this yesterday. Tried out lee's code and it seems to do what you want if you understand how it works. Ok why a dim if happy with just the label of distance sitting above line. Re label on top or below line is controlled by the direction of say the pline. Try this change will auto select correct objects. (defun c:IntLenM ( / *error* ss i ) (defun *error* ( msg ) (or (wcmatch (strcase msg) "*BREAK,*CANCEL*,*EXIT*") (princ (strcat "\n** Error: " msg " **"))) (princ) ) (if (= 4 (logand 4 (cdr (assoc 70 (tblsearch "LAYER" (getvar 'CLAYER)))))) (princ "\n--> Current Layer Locked.") (progn (setq lay (cdr (assoc 8 (entget (car (entsel "\nPick object for layer ")))))) (if (setq ss (ssget "X" (list (cons 0 "ARC,CIRCLE,ELLIPSE,LINE,*POLYLINE,SPLINE")(cons 8 lay)(cons 410 "Model")))) (repeat (setq i (sslength ss)) (LM:IntersectionLengths (ssname ss (setq i (1- i)))) ) ) ) ) (princ) ) You need plines else frontages of 2 objects will not work properly. Quote Link to comment Share on other sites More sharing options...
7empest Posted August 28 Author Share Posted August 28 On 23/08/2024 at 23:58, BIGAL said: Thought I posted this yesterday. Tried out lee's code and it seems to do what you want if you understand how it works. Ok why a dim if happy with just the label of distance sitting above line. Re label on top or below line is controlled by the direction of say the pline. Try this change will auto select correct objects. (defun c:IntLenM ( / *error* ss i ) (defun *error* ( msg ) (or (wcmatch (strcase msg) "*BREAK,*CANCEL*,*EXIT*") (princ (strcat "\n** Error: " msg " **"))) (princ) ) (if (= 4 (logand 4 (cdr (assoc 70 (tblsearch "LAYER" (getvar 'CLAYER)))))) (princ "\n--> Current Layer Locked.") (progn (setq lay (cdr (assoc 8 (entget (car (entsel "\nPick object for layer ")))))) (if (setq ss (ssget "X" (list (cons 0 "ARC,CIRCLE,ELLIPSE,LINE,*POLYLINE,SPLINE")(cons 8 lay)(cons 410 "Model")))) (repeat (setq i (sslength ss)) (LM:IntersectionLengths (ssname ss (setq i (1- i)))) ) ) ) ) (princ) ) You need plines else frontages of 2 objects will not work properly. Thank you for your reply.. When I try this lsp I am getting the following error: Quote Link to comment Share on other sites More sharing options...
pkenewell Posted August 28 Share Posted August 28 (edited) 2 hours ago, 7empest said: Thank you for your reply.. When I try this lsp I am getting the following error: You need to download the (LM: intersectionlengths) function from your link above and add it to the lisp file before using BIGAL's code. Edited August 28 by pkenewell Quote Link to comment Share on other sites More sharing options...
7empest Posted August 28 Author Share Posted August 28 59 minutes ago, pkenewell said: You need to download the (LM: intersectionlengths) function from your link above and add it to the lisp file before using BIGAL's code. Got it! Thank you Quote Link to comment Share on other sites More sharing options...
7empest Posted August 29 Author Share Posted August 29 ;;-------------=={ Length Between Intersections }==-----------;; ;; ;; ;; Displays the length of segments of a curve divided at ;; ;; intersections with other objects. ;; ;;------------------------------------------------------------;; ;; Author: Lee Mac, Copyright © 2011 - www.lee-mac.com ;; ;;------------------------------------------------------------;; ;; Version 1.4 - 26-04-2011 ;; ;;------------------------------------------------------------;; (defun c:IntLen ( / *error* _iscurveobject e ) (defun *error* ( msg ) (or (wcmatch (strcase msg) "*BREAK,*CANCEL*,*EXIT*") (princ (strcat "\n** Error: " msg " **"))) (princ) ) (defun _IsCurveObject ( entity / param ) (and (not (vl-catch-all-error-p (setq param (vl-catch-all-apply 'vlax-curve-getendparam (list entity)) ) ) ) param ) ) (if (= 4 (logand 4 (cdr (assoc 70 (tblsearch "LAYER" (getvar 'CLAYER)))))) (princ "\n--> Current Layer Locked.") (while (progn (setvar 'ERRNO 0) (setq e (car (entsel))) (cond ( (= 7 (getvar 'ERRNO)) (princ "\n--> Missed, Try again.") ) ( (eq 'ENAME (type e)) (if (_iscurveobject e) (LM:IntersectionLengths e) (princ "\n--> Invalid Object Selected.") ) t ) ) ) ) ) (princ) ) ;;------------------------------------------------------------;; (defun c:IntLenM ( / *error* ss i ) (defun *error* ( msg ) (or (wcmatch (strcase msg) "*BREAK,*CANCEL*,*EXIT*") (princ (strcat "\n** Error: " msg " **"))) (princ) ) (if (= 4 (logand 4 (cdr (assoc 70 (tblsearch "LAYER" (getvar 'CLAYER)))))) (princ "\n--> Current Layer Locked.") (if (setq ss (ssget '((0 . "ARC,CIRCLE,ELLIPSE,LINE,*POLYLINE,SPLINE")))) (repeat (setq i (sslength ss)) (LM:IntersectionLengths (ssname ss (setq i (1- i)))) ) ) ) (princ) ) ;;------------------------------------------------------------;; (defun LM:IntersectionLengths ( e ;; Entity name / *error* _startundo _endundo _groupbynum _sortbyparam _makereadable _isannotative _uniquefuzz a acspc c d d1 d2 da e i l ll m o ss ta to ts ur x y ) (setq acdoc (cond ( acdoc ) ( (vla-get-activedocument (vlax-get-acad-object)) )) acspc (vlax-get-property acdoc (if (= 1 (getvar 'CVPORT)) 'Paperspace 'Modelspace)) ) (defun *error* ( msg ) (if acdoc (_EndUndo acdoc)) (or (wcmatch (strcase msg) "*BREAK,*CANCEL*,*EXIT*") (princ (strcat "\n** Error: " msg " **"))) (princ) ) (defun _StartUndo ( doc ) (_EndUndo doc) (vla-StartUndoMark doc) ) (defun _EndUndo ( doc ) (if (= 8 (logand 8 (getvar 'UNDOCTL))) (vla-EndUndoMark doc)) ) (defun _GroupByNum ( l n / r) (if l (cons (reverse (repeat n (setq r (cons (car l) r) l (cdr l)) r)) (_GroupByNum l n) ) ) ) (defun _SortbyParam ( e l ) (vl-sort l '(lambda ( a b ) (< (vlax-curve-getParamatPoint e a) (vlax-curve-getParamatPoint e b)))) ) (defun _MakeReadable ( a ) ( (lambda ( a ) (cond ( (and (> a (/ pi 2)) (<= a pi)) (- a pi) ) ( (and (> a pi) (<= a (/ (* 3 pi) 2))) (+ a pi) ) ( a ) ) ) (rem a (* 2 pi)) ) ) (defun _isAnnotative ( style / object annotx ) (and (setq object (tblobjname "STYLE" style)) (setq annotx (cadr (assoc -3 (entget object '("AcadAnnotative"))))) (= 1 (cdr (assoc 1070 (reverse annotx)))) ) ) (defun _uniquefuzz ( lst fuzz ) (if lst (cons (car lst) (_uniquefuzz (vl-remove-if '(lambda ( x ) (equal x (car lst) fuzz)) (cdr lst)) fuzz ) ) ) ) (setq ts (/ (getvar 'textsize) (if (_isAnnotative (getvar 'textstyle)) (cond ( (getvar 'cannoscalevalue) ) ( 1.0 )) 1.0 ) ) ) (_StartUndo acdoc) (vla-getBoundingBox (setq o (vlax-ename->vla-object e)) 'll 'ur) (mapcar '(lambda ( x ) (set x (vlax-safearray->list (eval x)))) '(ll ur)) (if (setq l (_sortbyparam e (_uniquefuzz (apply 'append (repeat (setq i (sslength (ssdel e (setq ss (ssget "_C" (trans ur 0 1) (trans ll 0 1) '((0 . "ARC,CIRCLE,ELLIPSE,*LINE"))) ) ) ) ) (setq l (cons (_groupbynum (vlax-invoke o 'intersectwith (vlax-ename->vla-object (ssname ss (setq i (1- i)))) acextendnone ) 3 ) l ) ) ) ) 1e-8 ) ) ) (if (not (vlax-curve-isClosed e)) (progn (or (equal (vlax-curve-getStartParam e) (vlax-curve-getParamatPoint e (car l)) 0.001) (setq l (cons (vlax-curve-getStartPoint e) l)) ) (or (equal (vlax-curve-getEndParam e) (vlax-curve-getParamatPoint e (last l)) 0.001) (setq l (append l (list (vlax-curve-getEndPoint e)))) ) ) (setq c l) ) (if (vlax-curve-isClosed e) (setq l (list (vlax-curve-getStartPoint e)) c l) (setq l (list (vlax-curve-getStartPoint e) (vlax-curve-getEndPoint e))) ) ) (while (cadr l) (setq x (car l) y (cadr l) l (cdr l)) (setq m (vlax-curve-getPointatDist e (/ (+ (vlax-curve-getDistatPoint e y) (vlax-curve-getDistAtPoint e x)) 2.) ) ) (setq d (abs (- (vlax-curve-getDistatPoint e y) (vlax-curve-getDistAtPoint e x)) ) ) (setq a (angle '(0. 0. 0.) (vlax-curve-getFirstDeriv e (vlax-curve-getParamatPoint e m)) ) ) (setq ta (_makereadable a)) (setq to (vla-AddText acspc (rtos d) (vlax-3D-point '(0. 0. 0.)) ts)) (vla-put-Alignment to acAlignmentMiddleCenter) (vla-put-TextAlignmentPoint to (vlax-3D-point (polar m (+ ta (/ pi 2.)) (* 1.1 ts)))) (vla-put-rotation to ta) ) (if (vlax-curve-isclosed e) (progn (if (= 1 (length c)) (setq c (append c c))) (setq d (+ (setq d1 (vlax-curve-getDistatPoint e (car c))) (setq d2 (- (vlax-curve-getdistatparam e (vlax-curve-getendparam e)) (vlax-curve-getdistatpoint e (last c)))) ) ) (setq m (vlax-curve-getPointatDist e (if (< d1 (setq da (/ (+ d1 d2) 2.))) (setq da (- (vlax-curve-getdistatparam e (vlax-curve-getendparam e)) (- da d1))) (setq da (- da d2)) ) ) ) (setq a (angle '(0. 0. 0.) (vlax-curve-getFirstDeriv e (vlax-curve-getParamatPoint e m)) ) ) (setq ta (_makereadable a)) (setq to (vla-AddText acspc (rtos d) (vlax-3D-point '(0. 0. 0.)) ts)) (vla-put-Alignment to acAlignmentMiddleCenter) (vla-put-TextAlignmentPoint to (vlax-3D-point (polar m (+ ta (/ pi 2.)) (* 1.1 ts)))) (vla-put-rotation to ta) ) ) (_EndUndo acdoc) (princ) ) ;;------------------------------------------------------------;; (vl-load-com) (princ) (princ "\n:: IntLen.lsp | Version 1.4 | © Lee Mac 2011 www.lee-mac.com ::") (princ "\n:: Type \"IntLen\" or \"IntLenM\" to Invoke ::") (princ) ;;------------------------------------------------------------;; ;; End of File ;; ;;------------------------------------------------------------;; It's me again. So, out of the all the lisps I have found that provide dimensions between intersections I think I would prefer to use this one. Credit to Lee Mac with this code (https://lee-mac.com/intersectionslength.html) There are just 3 issues I am encountering that I hope someone here may be able to help with: 1. The text is offset from the the line by what looks to be 2m.. Is there any way to get the text/dim to be placed on the pink line? (see image below) 2. Second, for some reason I can't get it to display the dimensions at 2 decimal places when its a whole number I.e. 12.80 (as above), 9.10, 12.10, etc. but it displays it fine if it is not a whole number i.e. 12.81, 9.11, 12.15, etc. I have tried adjusting "dwgunits" and "units" to 2 decimal places but no luck. Any one have any suggestions for this? 3. Third and final issue, around curves it doesn't seem to do it at the intersecting lines when there is an end point of a line in-between the intersecting points. Instead, it will dimension it to the end point of the line and add another dimension after it to the intersecting point. This is hard to explain but the image below should help explain what I mean. Is there any way to fix this? Quote Link to comment Share on other sites More sharing options...
BIGAL Posted August 30 Share Posted August 30 (edited) 1 need in code to find where the offset value is and override with an extra step at start of program pick 2 points to get offset distance. Maybe (/ (+ (vlax-curve-getDistatPoint e y) (vlax-curve-getDistAtPoint e x)) 2.) 2 may need 2 mods in the code there may be a RTOS function like (rtos x 2 2 ) the 1st 2 is decimal the second is number of decimal places, you can check a value and if its "18.1" force it to be "18.10" 3 as I suggested in earlier post you need continuous plines not segments, then Lee's code will work. The program does not look for connecting objects. 4 Lee often comments here so he may respond to items 1 & 2. Edited August 30 by BIGAL Quote Link to comment Share on other sites More sharing options...
7empest Posted August 30 Author Share Posted August 30 17 hours ago, BIGAL said: 1 need in code to find where the offset value is and override with an extra step at start of program pick 2 points to get offset distance. Maybe (/ (+ (vlax-curve-getDistatPoint e y) (vlax-curve-getDistAtPoint e x)) 2.) 2 may need 2 mods in the code there may be a RTOS function like (rtos x 2 2 ) the 1st 2 is decimal the second is number of decimal places, you can check a value and if its "18.1" force it to be "18.10" 3 as I suggested in earlier post you need continuous plines not segments, then Lee's code will work. The program does not look for connecting objects. 4 Lee often comments here so he may respond to items 1 & 2. Thank you for the explanation. Unfortunately, this is over my head because I know very little about coding haha! Quote Link to comment Share on other sites More sharing options...
BIGAL Posted August 30 Share Posted August 30 Item 1 change the 2. to a value you want. Item 2 change (rtos d) to (rtos d 2 2 ) Item 3 make sure you have one pline covering full frontage of all intersecting lines. Quote Link to comment Share on other sites More sharing options...
7empest Posted September 3 Author Share Posted September 3 On 30/08/2024 at 19:35, BIGAL said: Item 1 change the 2. to a value you want. Item 2 change (rtos d) to (rtos d 2 2 ) Item 3 make sure you have one pline covering full frontage of all intersecting lines. Thank you. Item 1 didn't adjust where the text was place Item 2 did work however! Quote Link to comment Share on other sites More sharing options...
BIGAL Posted September 4 Share Posted September 4 You are right ignore Item 1 comment that is is mid point between 2 points. If you want the text further inside the lots need to rework out the text position. Change the 1.1 or change the (* 1.1 ts) to a offset distance. eg 2.5 number only no brackets. (vla-put-TextAlignmentPoint to (vlax-3D-point (polar m (+ ta (/ pi 2.)) (* 1.1 ts)))) (vla-put-TextAlignmentPoint to (vlax-3D-point (polar m (+ ta (/ pi 2.)) 2.5))) Quote Link to comment Share on other sites More sharing options...
Recommended Posts
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.