All Activity
- Past hour
- 
	Steven P started following AUTOLISP FIELD AREA FOR PL BUG
- 
	AUTOLISP FIELD AREA FOR PL BUGSteven P replied to Gabriel Paixão's topic in AutoLISP, Visual LISP & DCL If it was me I would allow the user to select an entity on the layer rather than typing it in, or use something like BigAls multi getvals to select the layer from a list - saves typing errors. You can add to filters in the selection set: (setq allPolylines (ssget "_X" (list (0 . "*POLYLINE")(cons 8 MyLayerName)))) Note here that list is used if you want any of the filters to be programmatically. 'cons' used to construct the list and MyLayerName is a variable you might want to work out earlier in the LISP. Lee Mac has a very good explanation on his website for ssget. You can loop through your selection set and perhaps this snippet will help: ;;https://www.cadtutor.net/forum/topic/66091-centre-of-hatch/ ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; (defun c:CtrCoo (/ findctr a apt) ;;Center point of a hatch or a rectangle (defun findctr (en / pt) (command "_.Zoom" "_Object" en "") (setq pt (getvar 'viewctr)) (command "_.Zoom" "_Previous") pt ) (setq a (car (entsel "Select Rectangle: : ")) apt (findctr a) ) (command "_Text" "_Justify" "_MC" apt 0.1 0 apt) (princ) ) Copy FindCtr and use that to get the centre point of each object, using that as the insert point for the mtext. Maybe this will help you along?
- Today
- 
	symoin started following Lisp for to get y value of police based on datum value and line.
- 
	Lisp for to get y value of police based on datum value and line.symoin replied to Ish's topic in AutoLISP, Visual LISP & DCL hi This is a very good lisp, can this be still upgraded to show the station of the selected lines also, at a certain distance south. like 20 or something.
- 
	The result looks geometrically perfect I also started writing something on Friday with a similar approach. I'll post it when I finish it.
- 
	The result looks geometrically perfect I also started writing something on Friday with a similar approach. I'll post it when I finish it.
- 
	GP_ started following Hybrid parallel
- 
	
- 
	
- 
	sachindkini started following Help me create a annotative dimension style and text style style
- 
	  annotative text style Help me create a annotative dimension style and text style stylesachindkini posted a topic in AutoLISP, Visual LISP & DCL Dear All, im trying create a annotative dimension style and text style style . annotation text style link to annotation dimstyle . create text style and dimethyl but annotative symbole not shown in dimension style and also text style )DIM-100 & DIM-200 is annotative dimension style) (defun c:TEST () (setvar "cmdecho" 0) (setvar "expert" 0) (command "undo" "be") (princ "\nFunction: Quickly create new dimension styles.\n") (if (not (tblsearch "STYLE" "STANDARD")) (command "style" "Standard" "txt" "" "1" "" "" "") ) (if (not (tblsearch "STYLE" "STANDARD")) (command ".-style" "STANDARD" "TXT" "0" "1" "0" "N" "N" "N") ) (command "dimadec" "2" "dimalt" "off" "dimalttz" "1" "dimaltu" "2" "dimassoc" "2" "dimasz" "1" "dimatfit" "3" "dimaunit" "0" "dimazin" "0" "dimblk" "_ARCHTICK" "dimcen" "0" "dimclrd" "0" "dimclre" "0" "dimclrt" "0" "dimdec" "2" "dimdle" "0.00" "dimdli" "0.05" "dimdsep" "." "dimexe" "0.35" "dimexo" "0.35" "dimfxlon" "off" "dimgap" "0.5" "dimjust" "0" "dimldrblk" "_ARCHTICK" "dimlfac" "1" "dimlunit" "2" "dimscale" "1" "dimtad" "1" "dimtdec" "2" "dimtfac" "1" "dimtfill" "0" "dimtfillclr" "0" "dimtih" "off" "dimtix" "off" "dimtmove" "0" "dimtofl" "on" "dimtol" "off" "dimtolj" "1" "dimtxsty" "Standard" "dimtxt" "2.5" "dimtzin" "1" "dimupt" "off" "dimzin" "1" ) (if (not (tblsearch "dimstyle" "TEST-123")) (command "dimstyle" "S" "TEST-123") ) ;; -------------------------------------- (if (not (tblsearch "STYLE" "TEST-100")) (command ".-style" "TEST-100" "Calibri" "0" "1" "0" "N" "N" "N") ) (setvar "DIMTOL" 1) (setvar "DIMTM" 0.05) (setvar "DIMTP" 0.05) (setvar "DIMTXSTY" "TEST-100") ;; Create or update dimension style (if (not (tblsearch "dimstyle" "DIM-100")) (progn (command ".-dimstyle" "S" "DIM-100") ) (command ".-dimstyle" "R" "DIM-100") ) ;; -------------------------------------- (if (not (tblsearch "STYLE" "TEST-200")) (command ".-style" "TEST-200" "ARIAL" "0" "1" "0" "N" "N" "N") ) (setvar "DIMTOL" 1) (setvar "DIMTM" 0.10) (setvar "DIMTP" 0.10) (setvar "DIMTXSTY" "TEST-200") (if (not (tblsearch "dimstyle" "DIM-200")) (progn (command ".-dimstyle" "S" "DIM-200") ) (command ".-dimstyle" "R" "DIM-200") ) (command "undo" "e") (alert "\nPrompt:\nDimension style creation completed!\n") (princ) )
- 
	This is kind of close, I split each line into some number of segments, then use closest point. Simplify reduces the number of segments, but changes the precision. Not sure if you can do this in lisp import traceback from pyrx import Db, Ed, Ge, Ap, Rx, Gs @Ap.Command() def centline(): try: ps1, id1, _ = Ed.Editor.entSel("\nPick 1") ps2, id2, _ = Ed.Editor.entSel("\nPick 2") pl1 = Db.Polyline(id1) pl2 = Db.Polyline(id2) crv1 = pl1.getAcGeCurve() crv2 = pl2.getAcGeCurve() # 200 can be a function of lenth, both must be the same smp1, _ = crv1.getSamplePoints(100) smp2, _ = crv2.getSamplePoints(100) spl1 = pl1.getSplitCurves(smp1) spl2 = pl2.getSplitCurves(smp2) pnts = [] for l, r in zip(spl1, spl2): cl = l.getAcGeCurve() cr = r.getAcGeCurve() poc1, poc2 = cl.getClosestPointsTo(cr) p1 = poc1.point3d() p2 = poc2.point3d() pnts.append(p1 + (p2 - p1) * 0.5) db = Db.curDb() cs = db.currentSpace(Db.OpenMode.kForWrite) npl = Db.Polyline(pnts) npl.simplify(0.01) npl.setLayer("0") npl.setColor(1) cs.appendAcDbEntity(npl) except Exception as err: traceback.print_exception(err) drawing AxisExample_dan.dwg
- 
	wobo joined the community
- 
	menakerelous joined the community
- 
	adel ahmed hagras joined the community
- 
	Saxlle started following Extract Polyline Lengths with Associated Text Labels in AutoCAD
- 
	Extract Polyline Lengths with Associated Text Labels in AutoCADSaxlle replied to Tamim's topic in AutoLISP, Visual LISP & DCL @Tamim Try this code and see if it helpful: (prompt "\nTo run a LISP type: LPL") (princ) (defun c:LPL ( / ss len circ txt_height lst i minPt maxPt midPt circle inc ang num ptlist k pt ssn pl_len ins_pt) (prompt "\nSelect all TEXT entities:\n") (setq ss (ssget (list (cons 0 "TEXT"))) len (sslength ss) circ 0.05 ;; radius of the circle can be changeable txt_height 0.01 ;; mtext height can be changeable lst (list) i 0 ) (while (< i len) (vla-GetBoundingBox (vlax-ename->vla-object (ssname ss i)) 'minPt 'maxPt) (setq minPt (vlax-safearray->list minPt) maxPt (vlax-safearray->list maxPt) midPt (mapcar '* (mapcar '+ minPt maxPt) (list 0.5 0.5)) ) (entmake (list (cons 0 "CIRCLE") (cons 100 "AcDbEntity") (cons 100 "AcDbCircle") (cons 8 (getvar 'clayer)) (cons 10 midpt) (cons 40 circ))) (setq circle (entlast) inc 0.25 ang 0 num (fix (/ (* pi 2) inc)) ptlist (list) k 0 ) (repeat num (setq pt (polar midPt ang circ) ptlist (append (list pt) ptlist) ang (+ ang inc) ) ) (setq ssn (ssget "_F" ptlist (list (cons 0 "LWPOLYLINE"))) pl_len (getpropertyvalue (ssname ssn k) "Length") ) (entdel circle) (setq lst (cons (list (cdr (assoc 1 (entget (ssname ss i)))) "\t " (rtos pl_len 2 3) "\\P") lst) i (1+ i) ) ) (setq lst (vl-sort lst (function (lambda (x e) (< (atoi (substr (car x) 3 (strlen (car x)))) (atoi (substr (car e) 3 (strlen (car e)))))))) lst (cons (list "\\fArial|b0|i0|c0|p34;S.No\tLength Ft\\P") lst) ins_pt (getpoint "\nPick the insertation point:") ) (entmake (list (cons 0 "MTEXT") (cons 100 "AcDbEntity") (cons 100 "AcDbMText") (cons 8 (getvar 'clayer)) (cons 10 ins_pt) (cons 40 txt_height) (cons 72 1) (cons 1 (apply 'strcat (mapcar '(lambda (x) (apply 'strcat x)) lst))))) (prompt "\nThe labels and the length of the polylines were added as MTEXT!") (princ) ) Also, you can see the short video example of how it works. LengthPolylineMtext.mp4 Best regards.
- 
	Thanks @Danielm103 That seems pretty accurate, although geometrically massive. It seems like there are a lot of points that aren't necessary. I guess something elegant should be only what's geometrically necessary. But I wonder what the result looks like when the geometry of the reference polylines is more extensive and varied.
- 
	Danielm103 started following Hybrid parallel
- 
	Shapley or geopandas can create this, there’s artifacts though. The algorithm is some sort of Voronoi https://centerline.readthedocs.io/en/latest/# https://gis.stackexchange.com/questions/474810/how-to-get-the-centerline-of-a-polygon-without-artefacts-in-python a bit wonky
- Yesterday
- 
	No, the program is required to define the reactors used to update the textbox position.
- 
	  Python, Extract Polyline Lengths with Associated Text Labels in AutoCADDanielm103 replied to Danielm103's topic in .NET, ObjectARX & VBA I used a similar approach here, the user wanted to set the elevation of the contour lines to the nearest label. This is where KD-Trees really start to shine as they can handle millions of points, with millions of searches
- 
	  Python, Extract Polyline Lengths with Associated Text Labels in AutoCADDanielm103 replied to Danielm103's topic in .NET, ObjectARX & VBA Yeah, I chose to search for the closest polyline to the text. BricsCAD has ssget crossing circle , (ssget "CC" point1 point2), could be similar to a radius search. Caveat, you’d have to call ssget for every mtext There’s a .DWG in the original post in the lisp forums
- 
	  Python, Extract Polyline Lengths with Associated Text Labels in AutoCADBIGAL replied to Danielm103's topic in .NET, ObjectARX & VBA Just a comment done a lot of find object next to text, just used get text insertion point, then use "ssget "F" pts" the pts are say 10 points made via a polar defun looking like a circle . I noticed you go the other way around looking around the pline for the text. Would be good to get a true sample dwg.
- 
	  Python, Extract Polyline Lengths with Associated Text Labels in AutoCADDanielm103 replied to Danielm103's topic in .NET, ObjectARX & VBA Yep, easier too, since there would be not need to format the string for MText. Even though Python has robust string operations, it’s still weird to get it perfect https://docs.python.org/3/library/string.html I was just following along the original sample. The part I wanted to illustrate was, using a hashmap for mapping points to objects, and using the KD-Tree to do the spatial search I wrote the same KD-Tree and map for AutoLISP, I’m just really bad at lisp, so it’s hard for me to make samples lol https://github.com/CEXT-Dan/ads_geo
- 
	  Python, Extract Polyline Lengths with Associated Text Labels in AutoCADBIGAL replied to Danielm103's topic in .NET, ObjectARX & VBA Would a table answer be perhaps neater than Mtext ? Just ask for text size for table.
- 
	Gabriel Paixão joined the community
- 
	I am trying to adapt an AutoLISP that automates the creation of fields linked to polyline areas. My goal is that based on a layer pre-established by the user, the program creates an MTEXT with a field linked to the area at its center for all closed polylines. Código original: My adapt: (defun c:A2FL ( / *error* fmt targetLayer allPolylines filteredSel idx ename obj str minPt maxPt minX minY maxX maxY centerPnt ) ;; Define the default formatting string for the Field. ;; "%lu6%qf1" generally means length units with 6 decimal places and zero suppression. ;; You can adjust this according to your needs (e.g., "%lu2%qf1" for 2 decimal places). (setq fmt "%lu6%qf1") ;; --- Local Error Handler for A2FL Command --- (defun *error* ( msg ) (LM:endundo (LM:acdoc)) ;; Ensures that the UNDO group is closed (if (not (wcmatch (strcase msg T) "*break,*cancel*,*exit*")) (princ (strcat "\nError: " msg)) ;; Displays the error message (unless it's a user interruption) ) (princ) ;; Suppresses the output of the last evaluated value ) (princ "\n--- Command: A2FL (Individual Polyline Areas by Layer) ---") ;; --- Step 1: Request Target Layer Name from User --- (setq targetLayer (getstring T "\nPlease enter the layer name for closed polylines: ")) ;; Check if the layer name was provided. (if (= "" targetLayer) (progn (princ "\nLayer name cannot be empty. Exiting 'A2FL'.") (exit) ;; Aborts command execution ) ) ;; Convert the layer name to uppercase to ensure case-insensitive comparison. (setq targetLayer (strcase targetLayer)) ;; --- Step 2: Automatically Select and Filter Closed Polylines in Target Layer --- ;; 'ssget "_X"' selects all entities in the drawing. ;; The filter '((0 . "*POLYLINE"))' restricts the initial selection to polylines only (2D, 3D and Lightweight). (setq allPolylines (ssget "_X" '((0 . "*POLYLINE")))) ;; Initialize an empty selection set to store only the filtered polylines. (setq filteredSel (ssadd)) ;; If there are polylines in the drawing to check: (if allPolylines (progn ;; Iterate over each polyline in the 'allPolylines' selection. (repeat (setq idx (sslength allPolylines)) (setq ename (ssname allPolylines (setq idx (1- idx)))) ;; Get the entity name (setq obj (vlax-ename->vla-object ename)) ;; Convert entity name to VLA object ;; Check if the polyline is in the target layer AND if it is closed. (if (and (= (strcase (vla-get-layer obj)) targetLayer) (eq :vlax-true (vla-get-closed obj)) ) (ssadd ename filteredSel) ;; Add the polyline to our filtered selection set ) ) ) ) ;; --- Step 3: Check if Any Suitable Polyline Was Found --- ;; If the 'filteredSel' selection set is empty after filtering: (if (zerop (sslength filteredSel)) (progn (princ (strcat "\nNo closed polylines found in layer '" targetLayer "'. Exiting 'A2FL'.")) (exit) ;; Aborts command execution ) ) (LM:startundo (LM:acdoc)) ;; Start an UNDO group so all operations can be easily undone. ;; --- Step 4: Process Each Filtered Polyline --- (repeat (setq idx (sslength filteredSel)) (setq ename (ssname filteredSel (setq idx (1- idx)))) ;; Get the entity name of current polyline (setq obj (vlax-ename->vla-object ename)) ;; Convert to VLA object ;; --- 4.1: Calculate the Central Point (approximate) for MText --- ;; We use the bounding box of the polyline to find an approximate center. ;; For complex or concave polylines, this point may not be "inside" the geometry, ;; but it's a simple and generally effective method for text placement. (vla-GetBoundingBox obj 'minPt 'maxPt) ;; Get the minimum and maximum corners of the bounding box (setq minX (vlax-safearray-get-element minPt 0) minY (vlax-safearray-get-element minPt 1) maxX (vlax-safearray-get-element maxPt 0) maxY (vlax-safearray-get-element maxPt 1) ) ;; Calculate the midpoint of the bounding box. (setq centerPnt (list (/ (+ minX maxX) 2.0) (/ (+ minY maxY) 2.0) 0.0)) ;; Z always 0 for 2D ;; --- 4.2: Build the Field Expression String for Current Polyline --- ;; This string is the same used for a single object in the original 'A2F' command, ;; ensuring correct field interpretation by AutoCAD. (setq str (strcat "%<\AcObjProp Object(%<_ObjId " (LM:ObjectID obj) ;; Use the ID of the *current* polyline ">%).Area \f "" fmt "">%" ) ) ;; --- 4.3: Create and Insert the MText Object in the Drawing --- ;; The MText is always added to Modelspace in this command, at the calculated center point. (vla-addmtext (vlax-get-property (LM:acdoc) 'modelspace) ;; Add to Modelspace (vlax-3D-point centerPnt) ;; Insertion point (the centroid) 0.0 ;; Text height (uses default height or annotative scale) str ;; The generated field string ) ) (LM:endundo (LM:acdoc)) ;; End the UNDO group. (princ (strcat "\nCommand 'A2FL' completed. " (itoa (sslength filteredSel)) " area fields inserted.")) (princ) ;; Suppress the output of the last evaluated value in the command line. ) ;; The auxiliary functions (LM:ObjectID, LM:getcell, LM:startundo, LM:endundo, LM:acdoc) ;; and COM loading (vl-load-com) (princ) are assumed to be already defined ;; and available in your original 'Areas2FieldV1-3.txt' file. ;; Do not redefine them here if they are already in the same file.
- 
	Merge Dimstyle & Text style after removing of binding prefix $0$LeoManu replied to nababeer's topic in AutoLISP, Visual LISP & DCL Hi there, It’s been a long time since this post, but I’m trying to do the same thing and I’m having trouble merging all the text styles. Here’s some progress on the routine that fixes the ActiveX server returned an error: type mismatch! error. thanks to komondormrex. However, I still can’t merge all the text styles. I’m attaching a sample file. Cheers! (defun c:mergedimtxt (/ cmd doc pos str) (setq doc (vla-get-activedocument (vlax-get-acad-object))) (foreach col '(textstyles dimstyles) (mergedimtxt:processcollection (vlax-get-property doc col)) ) (vlax-for blk (vla-get-blocks doc) (if (= :vlax-false (vla-get-isxref blk)) (vlax-for obj blk (if (and (wcmatch (vla-get-objectname obj) "AcDb*Text,AcDb*Dimension") (setq str (vla-get-stylename obj) pos (vl-string-position 36 str nil t) ) (vlax-write-enabled-p obj) ) (vla-put-stylename obj (substr str (+ 2 pos))) ) ) ) ) (setq cmd (getvar 'cmdecho)) (setvar 'cmdecho 0) (setvar 'textstyle "Standard") (command "_.-dimstyle" "_r" "Standard" "_.-purge" "_r" "*" "_n" "_.-purge" "_a" "*" "_n") (setvar 'cmdecho cmd) (vla-regen doc acAllViewports) (princ) ) (defun mergedimtxt:processcollection (col / pos str obj_dxf) (vlax-for obj col (if (and (setq str (vla-get-name obj) pos (vl-string-position 36 str nil t) ) (vl-catch-all-error-p (vl-catch-all-apply 'vla-item (list col (substr str (+ 2 pos)))) ) ) (entmod (subst (cons 2 (substr str (+ 2 pos))) (assoc 2 (setq obj_dxf (entget (vlax-vla-object->ename obj)))) obj_dxf)) ;komondormrex ) ) ) (vl-load-com) (princ) Drawing6.dwg
- 
	I've disabled some lines of your code that weren't working and added some new lines of code. I hope this helps.
- 
	Your code, ready. (defun C:bm (/ obj num i obj1 db ct rd ang1 ang2 p1 p2 r ptlist) (setvar "osmode" 0) ; Turn off OSNAP (setq obj (ssget '((0 . "LWPOLYLINE,ARC")))) (setq num (sslength obj)) (setq i 0) (repeat num (setq obj1 (ssname obj i)) (setq db (entget obj1) ptlist (mapcar 'cdr (vl-remove-if-not '(lambda (x) (= (car x) 10)) db)) i 0 ) (if (= (cdr (assoc 0 db)) "ARC") (progn (setq ct (cdr (assoc 10 db))) (setq rd (cdr (assoc 40 db))) (setq ang1 (* (cdr (assoc 50 db)) (/ 180.0 pi)) ang2 (* (cdr (assoc 51 db)) (/ 180.0 pi)) ) (setq p1 (polar ct ang1 rd)) (setq p2 (polar ct ang2 rd)) (command "_.dimradius" "_non" p1 "_non" p2 "") (command "_.dimarc" "_non" p1 "_non" p2 "") ) ;progn ;;; (progn ;polyline arc segment ;;;;;code (foreach l db (if (= (car l) 10) (if p1 (if bulge (progn (command "_.dimradius" "_non" p1 "_non" (cdr l) "") (command "_.dimarc" "_non" p1 "_non" (setq p1 (cdr l)) "") ; ) ) (setq p1 (cdr l)) ) (if (= (car l) 42) (setq bulge (/= (cdr l) 0.0))) ) ;;; (if (/= bulge 0.0) ;;; (progn ;;; (setq p1 (nth i ptlist)) ;;; (setq p2 (nth (+ i 1) ptlist)) ;;; ;;; (command "_.dimradius" "_non" p1 "_non" p2 "") ;;; (command "_.dimarc" "_non" p1 "_non" p2 "") ; ;;; ) ;progn ;;; ) ;if ) ;progn ) (setq i (1+ i)) ) ;repeat end ; Turn off OSNAP (setvar "osmode" 511) (princ) )
- 
	dannonino joined the community
- 
	  Associative Textbox (Lee Mac)sachindkini replied to sachindkini's topic in AutoLISP, Visual LISP & DCL Dear sir one question after i save the drg and again open the drg without this lisp load text or mtext not working... its possible one time used the code and this Associative text are working without upload the code everytime..
- 
	  Associative Textbox (Lee Mac)sachindkini replied to sachindkini's topic in AutoLISP, Visual LISP & DCL thanks sir, its perfect
- 
	Lee Mac started following Associative Textbox (Lee Mac)
- 
	It will require more modification than just extending the bulge list - you also need to calculate the positions of the additional vertices. However, I really liked your suggestion (and it's also consistent with my existing Box Text program), and so I've updated the program to Version 1.3 to incorporate a new Filleted Rectangle textbox option (you may need to refresh the page to view the new version). Enjoy!
- 
	BlackBox started following PERFORMANCE ISSUE WITH READ-LINE ON LARGE CSV FILES
- 
	  PERFORMANCE ISSUE WITH READ-LINE ON LARGE CSV FILESBlackBox replied to JuniorNogueira's topic in AutoLISP, Visual LISP & DCL https://forums.autodesk.com/t5/visual-lisp-autolisp-and-general/performance-issue-with-read-line-on-large-csv-files/td-p/13865858

 
	 
	 
                     
					
						 
                     
                     
                     
                     
	 
					
						 
                     
                    