Jump to content

Search the Community

Showing results for tags 'lisp'.

  • Search By Tags

    Type tags separated by commas.
  • Search By Author

Content Type


Forums

  • CADTutor
    • News, Announcements & FAQ
    • Feedback
  • AutoCAD
    • AutoCAD Beginners' Area
    • AutoCAD 2D Drafting, Object Properties & Interface
    • AutoCAD Drawing Management & Output
    • AutoCAD 3D Modelling & Rendering
    • AutoCAD Vertical Products
    • AutoCAD LT
    • CAD Management
    • AutoCAD Bugs, Error Messages & Quirks
    • AutoCAD General
    • AutoCAD Blogs
  • AutoCAD Customization
    • The CUI, Hatches, Linetypes, Scripts & Macros
    • AutoLISP, Visual LISP & DCL
    • .NET, ObjectARX & VBA
    • Application Beta Testing
    • Application Archive
  • Other Autodesk Products
    • Autodesk 3ds Max
    • Autodesk Revit
    • Autodesk Inventor
    • Autodesk Software General
  • Other CAD Products
    • BricsCAD
    • SketchUp
    • Rhino
    • SolidWorks
    • MicroStation
    • Design Software
    • Catch All
  • Resources
    • Tutorials & Tips'n'Tricks
    • AutoCAD Museum
    • Blocks, Images, Models & Materials
    • Useful Links
  • Community
    • Introduce Yourself
    • Showcase
    • Work In Progress
    • Jobs & Training
    • Chat
    • Competitions

Categories

  • Programs and Scripts
  • 2D AutoCAD Blocks
  • 3D AutoCAD Blocks
  • Images
    • Backgrounds

Find results in...

Find results that contain...


Date Created

  • Start

    End


Last Updated

  • Start

    End


Filter by number of...

  1. Dear Members, I have a ployline with dautm text value and datum line , I want text label of pline start vertex, intersection pont and end vertex, based on datum. If any have plz share need only y value, elevation, level of pline . Thanks See attached cad file Thanks POLYLINE Y VALUE.dwg
  2. I am pretty new to lisp programming and have only been working in it for a few months and I am pretty stuck on how to get this lisp program I've hacked together into what I need. Any help would be greatly appreciated. I would like help optimizing the lisp to be more like autocad's save as an old dxf way of converting an ellipse to a polyline. The current way I am converting an ellipse to poly line is by moving a static degree of distance between each point, the way I cannot figure out and the ideal way for me to do this is by specifying the maximum gap between the true ellipse and the polyline version. I have looked at other lisp programs out there and they are not high resolution enough for what I need, I need the data to be extremely close to the actual ellipse. I would appreciate help in pointing me towards how to do this mathematically, help implement that into a lisp, and any tips on best practice lisp programming that I might be really messing up here. Below is the function I have written to handle this so far, it takes in el which is the vla ellipse object and angleIncrement which is the degree difference between two points of the polyline. In a perfect world the second argument would be changed to be the maximum distance between the true ellipse and the polyline version. This is a function used in another script that then chains the data and does a few other things as well. (defun EllipseToLine (el angleIncrement / majorradius minorradius startangle endangle startpoint endpoint centerpoint tempVar) (vl-load-com) (setvar "cmdecho" 0) (setq majorradius (vla-get-MajorRadius el)) (setq minorradius (vla-get-MinorRadius el)) (setq startangle (* (vla-get-StartAngle el) (/ 180 pi))) (setq endangle (* (vla-get-EndAngle el)(/ 180 pi))) (setq startpoint (vlax-safearray->list (vlax-variant-value (vla-get-startpoint el)))) (setq endpoint (vlax-safearray->list (vlax-variant-value (vla-get-endpoint el)))) (setq centerpoint (vlax-safearray->list (vlax-variant-value (vla-get-center el)))) (setq centerx (nth 0 centerpoint)) (setq centery (nth 1 centerpoint)) (princ "End angle: ")(princ endangle)(princ "\n") (princ "Start angle: ")(princ startangle)(princ "\n") (setq startx (nth 0 startpoint)) (setq starty (nth 1 startpoint)) (setq endx (nth 0 endpoint)) (setq endy (nth 1 endpoint)) ; make sure we convert the ellipse on the correct layer and then later return to the layer we were on (setq ellipseLayer (vla-get-layer el)) (setq currentLayer (getvar "clayer")) (setvar "clayer" ellipseLayer) ; calculate angle between start angle and start point because the start point ; is not at the start angle so we have to adjust so numbers match up (setq angleOffset (- (* (angle centerpoint startpoint) (/ 180 pi)) startangle)) (setq radianOffset (* angleOffset (/ pi 180))) ; a = major radius ; b = minor radius (setq ecc (sqrt (- 1 (/ (expt minorradius 2) (expt majorradius 2))))) (setq angleInverted 0) (setq done 0) (setq i 0) (setq currentAngle startangle) (setq nintyDegrees 90.0) (setq twoHundredSeventyDegrees 270.0) (while (= done 0) (if (< currentAngle 0) (progn (setq currentAngle (+ currentAngle 360)) (setq angleInverted 1) ) ) (if (> currentAngle 360) (progn (setq currentAngle (- currentAngle 360)) (setq angleInverted 1) ) ) (cond ((or (and (> startangle endangle) (= angleInverted 0)) (and (> endangle startangle) (= angleInverted 1))) (if (< currentAngle endangle) (setq currentAngle endangle) ) ) ((or (and (> endangle startangle) (= angleInverted 0)) (and (> startangle endangle) (= angleInverted 1))) (if (> currentAngle endangle) (setq currentAngle endangle) ) ) ) (setq newAngle currentAngle) (if (or (> newAngle 0) (< newAngle 0)) (setq newAngle (* newAngle (/ pi 180))) ) (setq factor -1) (if (or (<= currentAngle nintyDegrees) (>= currentAngle twoHundredSeventyDegrees)) (setq factor 1) ) ; using the origional un rotated angle get the next point on the ellipse (setq x2 (/ (* majorradius minorradius) (* factor (sqrt (+ (expt minorradius 2) (* (expt majorradius 2) (expt (/ (sin newAngle) (cos newAngle)) 2))))))) (setq y2 (* x2 (/ (sin newAngle) (cos newAngle)))) (setq x2 (+ x2 centerx) y2 (+ y2 centery) ) ; rotate point on the ellipse by radian/angle offset so it matches the cad data (setq rotatedx (+ (- (* (cos radianOffset) (- x2 centerx)) (* (sin radianOffset) (- y2 centery))) centerx)) (setq rotatedy (+ (+ (* (sin radianOffset) (- x2 centerx)) (* (cos radianOffset) (- y2 centery))) centery)) (setq x2 rotatedx y2 rotatedy ) (if (= currentAngle endangle) (setq done 1) ) (if (> i 0) (if (= i 1) (command "_.line" (strcat (rtos startx) "," (rtos starty)) (strcat (rtos x2) "," (rtos y2)) "") (if (= done 1) (command "_.line" (strcat (rtos x1) "," (rtos y1)) (strcat (rtos endx) "," (rtos endy)) "") (command "_.line" (strcat (rtos x1) "," (rtos y1)) (strcat (rtos x2) "," (rtos y2)) "") ) ) ) (setq x1 x2 y1 y2 ) (setq currentAngle (+ currentAngle angleIncrement) i (+ 1 i) ) ) ; delete the origional ellipse (vla-delete el) (setvar "clayer" currentLayer) (princ) )
  3. Hello Everyone, I need some help; here is my list in csv 1,21.188,19.762,0.000,L1S 2,31.804,7.629,0.000,L2S 3,44.106,18.077,0.000,L2 4,32.984,30.378,0.000,L1 5,45.117,40.995,0.000,L1 6,56.239,26.671,0.000,L2 7,68.878,36.782,0.000,L2E 8,57.587,50.937,0.000,L1E 9,49.168,65.549,0.000,L1S 10,43.612,72.164,0.000,L1 11,50.491,77.059,0.000,L1 12,55.253,70.179,0.000,L1C 13,41.363,59.993,0.000,L2S 14,34.616,68.460,0.000,L2 15,27.472,64.094,0.000,L2 16,33.954,55.495,0.000,L2C And I want to make that list into something like this, (setq pt (list (nth 1 ln) (nth 2 ln) (nth 3 ln))) (setq mylist '( (("L1S" (list pt)) ("L1" (list pt))...("L1E" (list pt))) (("L2S" (list pt)) ("L2" (list pt))...("L2E" (list pt))) (("L1S" (list pt)) ("L1" (list pt))...("L1C" (list pt))) (("L2S" (list pt)) ("L2" (list pt))...("L2C" (list pt))) ) ) In order to plot the lines into groups by creating another set of group of points if the description has "S" or start at the end, say L1S for Line 1 Start. Thank you in advance.Line1 and 2 Group List.csv
  4. Hi all, I was wondering if someone could help me with a lisp modyfication. I need to modify CopyBlockStoCurve lisp so I don't need to select each block individually co copy it to the curve. I thought why not copy a function from numpol, which numbers blocks according to a polyline. So I need the new CopyBlockStoCurve to arrange blocks on a curve, but in accordance with how the blocks are positioned on another polyline basiclly. Can anyone help? numpol.lspCopyBlocksToCurve.lsp
  5. Morning All, Is the a lisp or some code to delete a hatch from every block in a drawing. The super market chain I'm working with use the same blocks over and over on different projects but there is a hatch on most of the blocks which interferes with my phasing drawings. I've tried Freezing/Turning Off the layer but as they have not set the blocks up with layer intelligence that doesn't work. I'm not worried about loosing the information contained within there blocks as I'm working for the builder producing CAD files that are only issued in PDF format. I don't want to explode the blocks! Look forward to your comments
  6. Hello, I'm here again. I have already created a few independent Lisp programs. I want to add a registration feature using a combination of the computer name, volume serial number, and a secret code. I'm thinking of creating a main Lisp file that all the other Lisp files will depend on. The idea is that if the main file detects that the computer's details don't match the registration code, the entire program won't run. Is it possible to implement this?" Please, can anyone help me?
  7. About 2 weeks into my use of AutoLISP. I understand that mapcar evaluates each item seperately, and lamda is used as an undefined function, but: In what situation would you need to use mapcar and lamda? Why would you need an output of a string of values other than presenting the output to the user?
  8. What is your opinion on the best way, or any way really, to learn to optimize your code? Or maybe a better way to state that I'm looking for a way to learn how to write cleaner, more streamlined code. Short of posting what I write here and asking for suggestions is there a decent way to learn more efficient coding strategies, or do you just muddle along visit forums like this one and stumble on approaches you can implement and try to apply them to the code you've written? I hardly write code, and I am not a coder but I find it interesting and a love to learn and am excited about using it to make the rest of my work life, and possibly anyone else's who finds it useful, better.
  9. I have scoured the net for a way to select all objects within a selected closed polyline as well objects that are touching the polyline, which i have found, but i need to be able to select more than one closed polyline at a time ,as I work on thousand of circles (drill holes) and shapes at any given time a lot of the time. If someone could please help me it would be greatly greatly appreciated. I am hoping for a modified lisp file that has been out there already.
  10. used chatgpt to get me this code but it generates this error "error: Automation Error. Problem in loading application" any ideas? (defun c:MGC ( / filePath fileLine fileHandle parts ptNum north east elev desc fileName newLayerName acadApp doc layMan layObj civApp civDoc pointsObj groupColl newGroup lastPoint centerPt lineCount existingGroup) ;; Step 1: Open file (setq filePath (getfiled "Select CSV File" "" "csv" 0)) (if (not filePath) (progn (alert "No file selected.") (exit) ) ) ;; Step 2: Save file name (setq fileName (vl-filename-base filePath)) ;; Step 3: Create new layer (setq newLayerName (strcat "Points - " fileName)) (setq acadApp (vlax-get-acad-object)) (setq doc (vla-get-ActiveDocument acadApp)) (setq layMan (vla-get-Layers doc)) (if (not (tblsearch "LAYER" newLayerName)) (progn (setq layObj (vla-Add layMan newLayerName)) (vla-put-Color layObj 3) ) ) ;; Step 4: Make new layer active (vla-put-ActiveLayer doc (vla-Item layMan newLayerName)) ;; Step 5: Civil 3D setup + Point Group (setq civApp (vla-getInterfaceObject acadApp "AeccXUiLand.AeccApplication.24")) (setq civDoc (vla-get-ActiveDocument civApp)) (setq groupColl (vla-get-PointGroups civDoc)) ;; Delete existing group with same name if it exists (vlax-for g groupColl (if (= (strcase (vla-get-Name g)) (strcase fileName)) (vla-Delete g) ) ) ;; Create new group (setq newGroup (vla-Add groupColl fileName)) (vla-put-IncludeAllPoints newGroup :vlax-true) ;; Step 6: Read and import points (setq pointsObj (vla-get-Points (vla-get-Points civDoc))) (setq fileHandle (open filePath "r")) (if (not fileHandle) (progn (alert "Unable to open the selected file.") (exit) ) ) (setq lineCount 0) (while (setq fileLine (read-line fileHandle)) (setq parts (vl-string->list fileLine ",")) (if (>= (length parts) 5) (progn (setq ptNum (nth 0 parts)) (setq north (atof (nth 1 parts))) (setq east (atof (nth 2 parts))) (setq elev (atof (nth 3 parts))) (setq desc (nth 4 parts)) (setq lastPoint (vlax-3d-point (list east north elev))) (vla-Add pointsObj lastPoint desc) (setq lineCount (1+ lineCount)) ) ) ) (close fileHandle) ;; Warn if no valid points were imported (if (= lineCount 0) (alert "No valid points were imported. Please check the file format.") ) ;; Step 7: Zoom to last point (if lastPoint (progn (setq centerPt (vlax-get lastPoint 'Coordinates)) (vla-ZoomCenter acadApp (vlax-3d-point (list (car centerPt) (cadr centerPt) 0)) 50.0) ) ) (princ) ) MGC.lsp
  11. Hello, I need some help regarding Layouts to DWGs and DWGPROPS. I'm currently using the original layouts to dwg command that Bijucad09 posted. Everything runs good until I open the new drawings, and all of my DWGprop links have been removed. They are replaced with "#'s" Any insight would help. Thank you!
  12. Hello, I found a lisp made by third parties and I wanted to adapt it, tried to make the changes myself, but the lisp doesn't work at all. The original lisp (VPGRID.lsp) creates a coordinate grid when selecting the viewport, however the coordinate labels come with the E/N suffix and I want the "X="/"Y=" prefix. (Line 258 and line 318 from original code) I would also like to be able to choose the size of the lines and text (Variables "gr_btick", "gr_ctick" and "gr_txthgt"). I tried to make the changes (QUADRICULA_VP.lsp) without success. Can someone help me. vpgrid.lsp QUADRICULA_VP.lsp
  13. Hello everyone, I’ve inherited an AutoLisp file from my predecessor. So far, the file works, though I can’t really judge if it has been optimally written. However, it saves both my colleagues and me a lot of time, and I can adjust most parts of it to my needs. That said, I’m running into issues with a specific section of the code: ;======================================== W A S S E R L A Y E R ======================================== ;*******************TEST Start (command "_-layer" "N" "Bezugslinie-Text" "") ;*******************TEST End ;======================================== L A Y E R Z U W E I S U N G ======================================== ;*******************TEST Start ;BT - Bezugslinie Text (setq BT (ssget "X" '( (0 . "MTEXT") (6 . "Continuous") (370 . 180) ))) (command "_CHANGE" BT "" "EI" "LA" "Bezugslinie-Text" "F" "VonLayer" "LTY" "VonLayer" "LS" "VonLayer" "") ;*******************TEST End The goal is to select MTEXT objects with a line thickness of 0.18 mm and assign them to the appropriate layer. Using the Quick Select tool works fine for this, but the LISP code doesn't seem to behave as expected. Before I share the full LISP file, I wanted to check if my approach makes sense. Is the issue with my plan clear, or have I provided too few details? Thanks in advance for any help! The Full code: (defun c:sweWASSER () ;***** TO-DO***** ;Wasser Bezugslinie der Beschriftung aus Auswahl ausschließen über Linienstärke möglich? ;======================================== V A R I A B L E N ======================================== (setq oldsnap (getvar "osmode")) ;save snap settings (setq oldblipmode (getvar "blipmode")) ;save blipmode setting ;Switch OFF System Variables (setvar "osmode" 0) ;Switch OFF snap (setvar "blipmode" 0) ;Switch OFF Blipmode ;======================================== A U S W A H L ======================================== (setq wasser1 (ssget "X" '((-4 . "<OR") (8 . "Ebene 290") (8 . "W_Anlage") (8 . "W_Anlage_Beschriftung") (8 . "W_Armatur") (8 . "W_Armatur_Beschriftung") (8 . "W_freie_Linie") (8 . "W_freier_Text_Beschriftung") (8 . "W_freies_Symbol") (8 . "W_HA_Abgang") (8 . "W_HA_Leitungsabschnitt_Beschriftung") (8 . "W_HA_Anschluss") (8 . "W_HA_Knoten") (8 . "W_HA_Schieber") (8 . "W_HA_Zähler") (8 . "W_Hydrant") (8 . "W_KKS_Isoliertrennstelle_Messkontakt") (8 . "W_Knoten") (8 . "W_Konstruktionspunkt") (8 . "W_Lagepunkt") (8 . "W_Messwagen") (8 . "W_Messzone") (8 . "W_Rohrkreuzung") (8 . "W_Schemazeichnung") (8 . "W_Schieber") (8 . "W_Schieber_Beschriftung") (8 . "W_Zähler") (8 . "Wasser-Detail") (8 . "Wasser-Rest") (8 . "W_HA_Zähler_Beschriftung") (-4 . "OR>")))) ;======================================== F U N K T I O N S A B L Ä U F E ======================================== (command "-xref" "l" "*" ) ;End Command (command "_-PURGE" "_all" "*" "_n" ) ;End Command (command "ZOOM" "GRENZEN" ) ;End Command (command "_ERASE" wasser1 "" ) ;End Command (command "_-PURGE" "_all" "*" "_n" ) ;End Command (command "REGENALL" ) ;End Command ;======================================== W A S S E R L A Y E R ======================================== ;*******************TEST Anfang (command "_-layer" "N" "Bezugslinie-Text" "") ;*******************TEST ENDE (command "_-layer" "N" "SWE_V_Wasser_VW_SWE" "") (command "_-layer" "N" "SWE_V_Wasser_Text_SWE" "") (command "_-layer" "N" "SWE_V_Wasser_HW_SWE" "") (command "_-layer" "N" "SWE_V_Wasser_AW_SWE" "") (command "_-layer" "N" "SWE_V_Wasser_stillgelegt_SWE" "") (command "_-layer" "N" "SWE_V_Wasser_HA_SWE" "") (command "_-layer" "N" "SWE_V_Wasser_Schutzrohr_SWE" "") (command "_-layer" "N" "SWE_V_Wasser_Bemaßung_SWE" "") (command "_-layer" "SE" "0" "") (command "REGENALL") ;======================================== L A Y E R Z U W E I S U N G ======================================== ;*******************TEST Anfang ;BT - Bezugslinie Text (setq BT (ssget "X" '( (0 . "MTEXT") (6 . "Continuous") (370 . 180) ))) (command "_CHANGE" BT "" "EI" "LA" "Bezugslinie-Text" "F" "VonLayer" "LTY" "VonLayer" "LS" "VonLayer" "") ;*******************TEST ENDE ;VW - Versorgungsleitung (setq VW (ssget "X" '( (6 . "Continuous") (8 . "W_VL_HL_Leitungsabschnitt") ))) (command "_CHANGE" VW "" "EI" "LA" "SWE_V_Wasser_VW_SWE" "F" "VonLayer" "LTY" "VonLayer" "LS" "VonLayer" "") ;WaB - Wasserleitung außer Betrieb (setq WaB (ssget "X" '( (6 . "30") (8 . "Wasser-Stillgelegt") ))) (command "_CHANGE" WaB "" "EI" "LA" "SWE_V_Wasser_stillgelegt_SWE" "F" "253" "LTY" "VonLayer" "LS" "VonLayer" "") ;WaBT - Wasser außer Betrieb Text (setq WaBT (ssget "X" '( (0 . "MText") (8 . "Wasser-Stillgelegt") ))) (command "_CHANGE" WaBT "" "EI" "LA" "SWE_V_Wasser_stillgelegt_SWE" "F" "253" "LTY" "VonLayer" "LS" "VonLayer" "") ;Beschriftung (setq BES (ssget "X" '( (8 . "W_VL_HL_Leitungsabschnitt_Beschriftung") ))) (command "_CHANGE" BES "" "EI" "LA" "SWE_V_Wasser_Text_SWE" "F" "VonLayer" "LTY" "VonLayer" "LS" "VonLayer" "") ;Schutzrohre und Bemaßung sprengen (setq SBS (ssget "X" '((-4 . "<OR")(8 . "W_Schutzrohr")(8 . "Wasser-Bemassung")(-4 . "OR>") ))) (setq a (getvar "qaflags")) (setq b (setvar "qaflags" 1)) (command "_EXPLODE" SBS "") (setvar "qaflags" a) ;Schutzrohr (setq SR (ssget "X" '((-4 . "<OR")(8 . "W_Schutzrohr")(8 . "W_Schutzrohr_Beschriftung")(-4 . "OR>") ))) (command "_CHANGE" SR "" "EI" "LA" "SWE_V_Wasser_Schutzrohr_SWE" "F" "VonLayer" "LS" "VonLayer" "") ;Bemaßung (setq BEM (ssget "X" '( (-4 . "<OR")(8 . "W_freier_Text")(8 . "Wasser-Bemassung")(-4 . "OR>") ))) (command "_CHANGE" BEM "" "EI" "LA" "SWE_V_Wasser_Bemaßung_SWE" "F" "253" "") ;Hausanschlüsse (setq HA (ssget "X" '( (8 . "W_HA_Leitungsabschnitt") ))) (command "_CHANGE" HA "" "EI" "LA" "SWE_V_Wasser_AW_SWE" "F" "VonLayer" "LTY" "VonLayer" "LS" "VonLayer" "") ;Auswahl (setq wasser2 (ssget "X" '((-4 . "<OR")(8 . "Wasser-Stillgelegt")(-4 . "OR>")))) (command "_ERASE" wasser2 "" ) ;End Command (command "_-PURGE" "_all" "*" "_n" ) ;End Command ;Modell Regenerieren (command "REGENALL") ;======================================== T E X T S T I L C H A N G E ======================================== ;; Alle Texte und MText in der Zeichnung auswählen (setq ss (ssget "X" '((0 . "TEXT,MText")))) ;; Wenn Texte vorhanden sind, den Stil ändern (if ss (progn (setq i 0) (while (< i (sslength ss)) (setq e (entget (ssname ss i))) ; Entität der Auswahl bekommen (setq eneu (subst (cons 7 "STANDARD") (assoc 7 e) e)) ; Stil auf "STANDARD" ändern (entmod eneu) ; Entität mit dem neuen Stil aktualisieren (setq i (1+ i)) ) (princ "\nAlle Texte auf den Stil 'STANDARD' gesetzt.") ) (princ "\nKeine Texte in der Zeichnung gefunden.") ) ;======================================== R E S E T V A R I A B L E ======================================== (setvar "osmode" oldsnap) ;Reset snap (setvar "blipmode" oldblipmode) ;Reset blipmode (princ) ;finish cleanly ) ;Ende defun (princ) ;load cleanly
  14. I have a drawing with multiple rotated dimensions and some are quite small resulting in text being offset to the leader. I was wondering if there is an easy way to change all the text box components of the dimensions to fit the actual size of the text so that it isn't so offset from the leader without exploding all the dimensions. I've included some snap shots below for reference. There are quite a few in the file so I want to try and avoid having to do them manually one by one. Any help would be greatly appreciated. Regards, Ryan
  15. Hi every one, good day to all, I have a very interesting concept to do in autocad with lisp. To automate the creation of multiple concrete profiles based on existing profile points (lines, polylines, curves, or ellipses) and extend these profiles further using predefined data (e.g., in an Excel or CSV file). This process will reduce manual effort and save significant time. My series of operation to achieve this by using the excel/.csv file, Steps are, 1. Get the existing profiles point locations (End points of polylines, line. Radius of curve, ellipse) for example 5 profiles, by that we can get changes as series. Step 1: Extract Existing Profile Points - Identify key points (endpoints of polylines or lines, radius points of curves, center points of ellipses, etc.) from the existing profiles in AutoCAD. These points are the foundation for generating the additional profiles. Export these point data (coordinates: X, Y, Z if needed) into a CSV file or Excel sheet for further processing. Step 2: Generate New Profile Data in Excel - Use the exported data from Step 1 to calculate or define new profiles. For example, if there are 5 existing profiles, Excel can create the data for 50 or more additional profiles using with how the series. Each new profile will have its unique point locations defined as individual profiles. Step 3: Automate Profile Creation in AutoCAD - covert those as lines, curves with LISP routine to: Read the new profile data from the CSV/Excel file. Iterate through the data to create polylines, lines, arcs, or other entities that represent the new profiles. Ensure the new profiles are drawn incrementally (e.g., Profile 1, Profile 2, and so on) and are clearly labeled or grouped. I think it bit complicated, Thanks in advance every one I have attached the example dwg file. Profile Example.dwg
  16. Hi everyone , I want to automate the process of converting multiple DWG files into PDFs, where each layout is saved as a separate PDF with a unique name and stored in specific directories. For example, if one DWG file has three layouts, those three layouts should be saved as three separate PDFs in one folder, and another DWG file's layouts should go to a different folder. Right now, Im doing this manually using the Plot command, but it’s repetitive and time-consuming. Although I tried using the Sheet Set Manager, it results in darker PDFs compared to those created through the regular plotting method. Im looking for a way to automate this while keeping the quality of the plotted PDFs intact and i search for lisp and i can't find it. Thanks in advance for everyone...
  17. Dear, sir, Any trick,code, VBA, Excel for publish pdf and etransmit also. I have many cad drawings, every drawing have a folder I want to make pdf & etransmit at time ( if in 2 step pdf first and etransmit second no issue) but at same path . But Without opening the drawings. ---_-----------------+++++---- Publish PDF and etransmit at same location of drawing For publish everything is already set, page set-up, ctb etc. Thanks
  18. Dear sir, I need a program for to draw hatching as per condition, multiple selection at time. If separate, separate lisp no issue, if add option for 2 line and 3line Cad file attached with situation and require solution. Thanks HATCHING PATTERN AS PER CONDITION.dwg
  19. The current routine works but requires 2 major changes (1) and (2). So... basically what I would like to accomplish would be: 1) find a way so that the filtering process accounts for a specific block throughout the drawing instead of :L , but no success on this regard: (if (setq s (ssget "_X" '((0 . "INSERT") (66 . 1) (2 . "`*U*,POTEAUX_PLAN_BLK1")))) (repeat (setq i (sslength s)) (setq o (vlax-ename->vla-object (setq ent (ssname s (setq i (1- i)))))) (if (and (vlax-property-available-p o 'effectivename) (= "poteaux_plan_blk1" (strcase (vla-get-effectivename o) t)) ) (progn ... It works as is, but cannot find a way to incorporate (2 . "`*U*,POTEAUX_PLAN_BLK1") for the dynamic block "POTEAUX_PLAN_BLK1". So I ended up selecting the blocks one by one as an alternative. 2) The attributes on the block are arranged in the same manner as displayed on the tags list. Is it possible to move tags downward by say 2.5 units to re-arrange the position after tags are removed (Photo before & after)? (defun c:foo (/ s tags) ;; List of tags to target (setq tags '( "ENDOMAGÉ" "FISSURÉ" "BANDEJAUNE" "COUPÉ" "TRANSFERT" "<1M" "<3M" "INC.+5" ) ) ;; Select attributed blocks (if (setq s (ssget ":L" '((0 . "INSERT") (66 . 1)))) (foreach e (vl-remove-if 'listp (mapcar 'cadr (ssnamex s))) ; Loop through selected entities (foreach tag tags (if (vl-catch-all-error-p (vl-catch-all-apply (function (lambda () ;; Get the current value of the attribute (cond ;; Case 1: Empty or "NON" -> Set value to "" ((or (eq "" (getpropertyvalue e tag)) (eq "NON" (strcase (getpropertyvalue e tag)))) (setpropertyvalue e tag "")) ;; Case 2: "OUI" -> Set value to the tag name ((eq "OUI" (strcase (getpropertyvalue e tag))) (setpropertyvalue e tag tag)) ) ) ) ) ) (princ (strcat "\nError handling tag: " tag)) ; Error Handling );end if ) ) ); end if (princ) ); end defun Any help is appropriated! Before... After... my wish...
  20. A while back AutoCAD introduced semi-parametric extrusions, you could alter the polyline and the extrusion would update. It's a great feature, but has anyone heard of a way of replacing the polyline profile with a different one? This would be very handy for cabinetmakers who use a variety of profiles to their doors. It's a shame 2D blocks can't be extruded as blocks can be replaced...
  21. I got this code from chatgpt, that chatgpt got from a defunct post from autocad website forums. Whenever I tried going to the website or googling, the link seems broken so I don't know how this code exactly works. I am trying to make a Lisp that creates dimstyles from scratch. everything is working except for changing between annotative and non annotative. The code below does a good job of setting the created dimension style to annotative. But when I ask chat gpt to make it in reverse, i.e. make a code that makes the created dimstyle non annotative, it can't. (defun set-dimstyle-annotative (dimstyle-name / ent entdata xdata) ;; Ensure the dimension style exists (if (and (setq ent (tblobjname "dimstyle" dimstyle-name)) (setq entdata (entget ent))) (progn ;; Check if XData for "AcadAnnotative" exists (if (not (assoc -3 entdata)) (progn ;; Add XData to set the dimension style as annotative (setq xdata '((-3 ("AcadAnnotative" (1000 . "AnnotativeData") (1002 . "{") (1070 . 1) ; Version number (1070 . 1) ; Annotative flag: 1 = Yes, 0 = No (1002 . "}") ) ) ) ) ;; Apply the XData to the dimension style (entmod (append entdata xdata)) (princ (strcat "\nDimension style '" dimstyle-name "' set to annotative.")) ) (princ (strcat "\nDimension style '" dimstyle-name "' is already annotative.")) ) ) (princ (strcat "\nDimension style '" dimstyle-name "' not found.")) ) (princ) ) Basically when a dimstyle is created, I put this at the end of the code to make it annotative. However, after making an annotative dimstyle, I can make a dimstyle, but because the previous was annotative, I cannot set the new dimstyle to non annotative. Chat gpt gave me a code but it seems it just butchered the code and it doesn't work. I attached the lisp file. Thanks!! DimStyles.lsp
  22. I would like some help to create a function that would allow me to select a point in between two horizontal and/or vertical lines and it would give me the vertical and horizontal dimensions between those lines. It's a 2D drawing but some lines are of different z value. I have tried using chatgpt to create a code but it is not able to properly select the nearest line from my specified point (after running the command). This function is there in the new sketchup. I was hoping to use it to create internal dimensions in an architectural plan.
  23. Hi all, Again I have found a lisp Lee Mac made that copies a field into a dimension, "copyfield", but it requires that the field already exists... So is there a way to create a field from an attribute in a block and then insert the field directly into a dimension? Thanks in advance.
  24. "I'm interested in using Lisp for a project involving rope simulations. Can you recommend a Lisp implementation capable of rendering rope-like curves with realistic physics-based deformations?" bandicam 2024-11-21 13-23-17-231.mp4
  25. Hi my friends , Happy day.... I'm trying to solve an issue to help my non-coder friends. I'm using a Lisp file that contains all my routines, but I can't explain everything every time. So, I want to create a table inside AutoCAD that lists the shortcut commands and their descriptions, similar to how the TEXT COUNTER command works by Lee Mac. Any other suggestions could help me a lot. Thanks in advance my friends.... Attached is my lisp file Lisp Routine.lsp
×
×
  • Create New...