Jump to content

Recommended Posts

Posted

Hi all,

as i shown in the drawings, i have centerlines and winglines,

now what i want is from centerline i want to draw winglines at different distances

(i.e.10m,25m,45m it could be any distance means not ON proper interval)

and corridor at the end

Is there any lisp that could solve my prob.

 

Thankx a lot in advance

1111.dwg

  • Replies 23
  • Created
  • Last Reply

Top Posters In This Topic

  • Tharwat

    7

  • crisraj99

    7

  • satishrajdev

    4

  • pBe

    2

Posted

An alternative solution is to draw that as multiline after define an apropriate style.

Posted (edited)

Try this piece of code .

 

(defun c:Test (/ *error* d e s k)
 (vl-load-com)
;;; Tharwat 09. Oct. 2012 ;;;
 (defun *error* (x)
   (princ "\n*Cancel*")
 )
 (if (and (not (tblsearch "LAYER" "SURVEY LIMIT"))
          (not (tblsearch "LAYER" "SURVEY LINES"))
     )
   (progn
     (alert " One or two layers [sURVEY LIMIT , SURVEY LINES] are not found in the drawing")
     (exit)
   )
 )
 (if (and (setq s (ssget "_+.:S:L" '((0 . "LINE"))))
          (progn
            (initget "WINGLINES CORRIDOR")
            (setq k
                   (cond ((getkword
                            "\n Choose one [Winglines/Corridor] <Winglines> :"
                          )
                         )
                         ("Winglines")
                   )
            )
          )
     )
   (while
     (setq d (getdist "\n Specify offset distance :"))
      (progn
        (foreach x (list d (- d))
          (vla-offset
            (vlax-ename->vla-object (ssname s 0))
            x
          )
          (vla-put-layer
            (vlax-ename->vla-object (entlast))
            (if (eq k "Winglines")
              "SURVEY LIMIT"
              "SURVEY LINES"
            )
          )
        )
      )
   )
 )
 (princ)
)

Edited by Tharwat
name of layers added to alert function
Posted

OMG......Thanx a lot tharwat

that is working beautifully...........but still need little correction

when i m trying to draw corridor, the line which is drawn must have corridor line properties (i.e. Layer-Survey limit, Color-Blue, Line type-dashed)

but corridor it draws has wingline properties (i.e. Layer-Survey lines, Color-magenta, Line type-conti.)

 

other than this it is working fabulously.....This what i was looking for

Posted
OMG......Thanx a lot tharwat

that is working beautifully...

 

 

You're welcome . :)

 

when i m trying to draw corridor, the line which is drawn must have corridor line properties (i.e. Layer-Survey limit, Color-Blue, Line type-dashed)

but corridor it draws has wingline properties (i.e. Layer-Survey lines, Color-magenta, Line type-conti.)

 

 

It does that , and when you have the prompt of [Winglines/Corridor] , just enter Corridor or the first letter C is enough . ;)

Posted

i tried that...

i entered C after that prompt but still magenta line is appearing

can u tell why it is happening?

 

i have modified this routine, which is as follow

(defun c:Test (/ *error* d e s k)
 (vl-load-com)
;;; Tharwat 09. Oct. 2012 ;;;
 (defun *error* (x)
   (princ "\n*Cancel*")
 )
 (if (and (not (tblsearch "LAYER" "SURVEY LIMIT"))
          (not (tblsearch "LAYER" "SURVEY LINES"))
     )
(command "layer" "m" "Survey Limit" "lt" "dashed" "" "c" "5" "" "")
(command "layer" "m" "Survey Lines" "lt" "continuous" "" "c" "6" "" "")
 )
 (if (and (setq s (ssget "_+.:S:L" '((0 . "LINE"))))
          (progn
            (initget "WINGLINES CORRIDOR")
            (setq k
                   (cond ((getkword
                            "\n Choose one [Winglines/Corridor] <Winglines> :"
                          )
                         )
                         ("Winglines")
                   )
            )
          )
     )
   (while
     (setq d (getdist "\n Specify offset distance :"))
      (progn
        (foreach x (list d (- d))
          (vla-offset
            (vlax-ename->vla-object (ssname s 0))
            x
          )
          (vla-put-layer
            (vlax-ename->vla-object (entlast))
            (if (eq k "Winglines")
              "SURVEY LIMIT"
              "SURVEY LINES"
            )
          )
        )
      )
   )
 )
 (princ)
)

 

but still same error is coming

Posted

i entered C after that prompt but still magenta line is appearing

can u tell why it is happening?

 

 

Check the Color Control of the current layer , it might be changed to others than ByLayer .

Posted
(defun c:Test (/ *error* d e s k)
 (vl-load-com)
;;; Tharwat 09. Oct. 2012 ;;;
 (defun *error* (x)
   (princ "\n*Cancel*")
 )
(setvar 'cmdecho 0)  
[color="#4169e1"](defun Lyr (/ x)
    (initget "WINGLINES CORRIDOR")
    (setq x
           (cond ((getkword
                    "\n Choose one [Winglines/Corridor] <Winglines> :"
                  )
                 )
                 ("Winglines")
           )
    ) x
  )[/color]
[color="#4169e1"](foreach lyr '(("SURVEY LIMIT" "5" "DASHED")
       ("SURVEY LINES" "6" "CONTINUOUS"))
 	(if (not (tblsearch "LAYER" (car lyr)))
 	(command "_Layer" "_N"
		 (car lyr)  "_Color"
		 (cadr lyr) (car lyr)
		 "_Ltype"
		 (last lyr) (car lyr)
		 ""
	)))[/color]
     
 (if (and (setq s (ssget "_+.:S:L" '((0 . "LINE"))))
          (setq k (lyr))
     )
   (while
     [color="#4169e1"](progn (initget "L")[/color]
    [color="#4169e1"] (setq d (getdist "\n Specify offset distance/L To change layer :")))[/color]
	(cond
	 [color="#4169e1"] ((eq d "L")(setq k (lyr)))[/color]	
     		  [color="#4169e1"]((eq (Type d) 'Real)[/color] 
	         (foreach x (list d (- d))
	           (vla-offset
	             (vlax-ename->vla-object (ssname s 0))
	             x
	           )
	           (vla-put-layer
	             (vlax-ename->vla-object (entlast))
	             (if (eq k "Winglines")
	               "SURVEY LIMIT"
	               "SURVEY LINES"
	             )
	           )
	         )
	   )
      )
   )
 )
 (princ)
)

Posted

it working perfectly now for me without any error

 

@pBe and Tharwat.....you guys are real genius.... thankx a lot for your interest and help..... your work is really appreciated.

 

I want one more help from u (Sorry for making u to work again)

 

In winglines segment, i want the prompt of Specify Distance [same/Different]

1. at same distance i want to specify distance once and then it should draw line at proper interval of that distance.

(e.g. If i specified distance 2 then

1st offset will be @- 2,

2nd offset will be @- 4,

3rd offset will be @- 6.

 

Just like Offset command (after selecting object it ask Specify through point or [Exit/Multiple/Undo] :

When we give Multiple command it draws line at proper interval of that specified distance)

 

2.For different distance it should work how it is working now.

i.Select object

ii. specify distance

iii. offsetting the line

Posted

That sounds like fun. But its tharwats' code really :popcorn:

 

Cheers

  • 7 months later...
Posted

hi,

 

i need same lisp but i don't want to mention the layers, irrespective of layers i need tool please help me.

Posted
hi,

 

i need same lisp but i don't want to mention the layers, irrespective of layers i need tool please help me.

 

Are these layers CONFIDENTIAL ?

 

Can you please stop reviving threads and start a new thread showing what you are looking for and if anyone has the willing to help , that would be great and we should thank them .

Posted

HI Tharwat ,

 

Autually in each drawing i found different layer names thats why i don't mentioned the names.

for example find the attachment and can you please help me to make center lines for HVAC pipes.

Example.dwg

Posted
HI Tharwat ,

 

Autually in each drawing i found different layer names thats why i don't mentioned the names.

for example find the attachment and can you please help me to make center lines for HVAC pipes.

 

 

Try this draft and select only two lines to create center line between both of them ( if I understood your goal well )

 

(defun c:cl (/ _Mid ss i sn e1 e2 p1 p2 p3 p4)
 (defun *error* (x) (princ "\n *Cancel*"))
 (if
   (eq
     4
     (logand 4
             (cdr
               (assoc 70 (entget (tblobjname "LAYER" (getvar 'clayer))))
             )
     )
   )
    (progn
      (alert "<!> Current layer is LOCKED <!>")
      (exit)
    )
 )
 (defun _Mid (pt1 pt2)
   (mapcar (function (lambda (j k) (* (+ j k) 0.5))) pt1 pt2)
 )
 (if (and (setq ss (ssget "_:L" '((0 . "LINE"))))
          (if (eq 2 (setq i (sslength ss)))
            t
            (progn
              (alert "Please select only two lines , OKAY ? ")
              nil
            )
          )
     )
   (progn
     (setq e1 (entget (ssname ss 0))
           e2 (entget (ssname ss 1))
           p1 (cdr (assoc 10 e1))
           p2 (cdr (assoc 11 e1))
           p3 (cdr (assoc 10 e2))
           p4 (cdr (assoc 11 e2))
     )
     (if (not (inters p1 p3 p2 p4))
       (entmakex (list '(0 . "LINE")
                       (cons 10 (_Mid p1 p3))
                       (cons 11 (_Mid p2 p4))
                 )
       )
       (entmakex (list '(0 . "LINE")
                       (cons 10 (_Mid p1 p2))
                       (cons 11 (_Mid p3 p4))
                 )
       )

     )
   )
 )
 (princ "\n Written By Tharwat Al Shoufi")
 (princ)
)

Posted

Wow thanks a lot Tharwat,

 

it's working well but i need centre lines for "LWPOLYLINE" closed also what i have to do for those closed LWPOLYLINE's. any help..???

 

and one more request

 

i need total count of the drawing file by each layer... could you please help me on this.

Posted
Wow thanks a lot Tharwat,

 

You're welcome .

 

it's working well but i need centre lines for "LWPOLYLINE" closed also what i have to do for those closed LWPOLYLINE's. any help..???

 

Explode them if you don't need them as polylines and use my code to center them . ;)

 

i need total count of the drawing file by each layer... could you please help me on this.

 

Although that is not clear , I would leave the chance to the other to help you with it . :)

 

Tharwat

Posted

once again thanks a lot but for polylines u r code is not working.

Posted
but for polylines u r code is not working.

I know that , that's why I said explode them if you don't want them as polylines in my previous reply .

Posted

Here's one I wrote a while back...

 

(defun c:LBL (/ foo AT:GetSel _pnts _pline _lwpline _dist e1 e2)
 ;; Draw (LW)Polyline between two selected curves (at midpoint of vertices).
 ;; Alan J. Thompson, 09.29.10

 (vl-load-com)

 (defun foo (e)
   (and (wcmatch (cdr (assoc 0 (entget (car e)))) "LINE,*POLYLINE,SPLINE")
        (not (vlax-curve-isClosed (car e)))
   )
 )

 (defun AT:GetSel (meth msg fnc / ent)
   ;; meth - selection method (entsel, nentsel, nentselp)
   ;; msg - message to display (nil for default)
   ;; fnc - optional function to apply to selected object
   ;; Ex: (AT:GetSel entsel "\nSelect arc: " (lambda (x) (eq (cdr (assoc 0 (entget (car x)))) "ARC")))
   ;; Alan J. Thompson, 05.25.10
   (while
     (progn (setvar 'ERRNO 0)
            (setq ent (meth (cond (msg)
                                  ("\nSelect object: ")
                            )
                      )
            )
            (cond ((eq (getvar 'ERRNO) 7) (princ "\nMissed, try again."))
                  ((eq (type (car ent)) 'ENAME)
                   (if (and fnc (not (fnc ent)))
                     (princ "\nInvalid object!")
                   )
                  )
            )
     )
   )
   ent
 )

 (defun _pnts (e / p l)
   (if e
     (cond ((wcmatch (cdr (assoc 0 (entget e))) "ARC,LINE,SPLINE")
            (list (vlax-curve-getStartPoint e) (vlax-curve-getEndPoint e))
           )
           ((wcmatch (cdr (assoc 0 (entget e))) "*POLYLINE")
            (repeat (setq p (1+ (fix (vlax-curve-getEndParam e))))
              (setq l (cons (vlax-curve-getPointAtParam e (setq p (1- p))) l))
            )
           )
     )
   )
 )

 (defun _pline (lst)
   (if (and (> (length lst) 1)
            (entmakex '((0 . "POLYLINE") (10 0. 0. 0.) (70 . ))
            (foreach x lst (entmakex (list '(0 . "VERTEX") (cons 10 x) '(70 . 32))))
       )
     (cdr (assoc 330 (entget (entmakex '((0 . "SEQEND"))))))
   )
 )

 (defun _lwpline (lst)
   (if (> (length lst) 1)
     (entmakex (append
                 (list '(0 . "LWPOLYLINE")
                       '(100 . "AcDbEntity")
                       '(100 . "AcDbPolyline")
                       (cons 90 (length lst))
                       (cons 70 (* (getvar 'plinegen) 128))
                 )
                 (mapcar (function (lambda (p) (list 10 (car p) (cadr p)))) lst)
               )
     )
   )
 )

 (defun _dist (a b) (distance (list (car a) (cadr a)) (list (car b) (cadr b))))

 (if
   (and
     (setq e1 (_pnts (car (AT:GetSel entsel "\nSelect first open curve: " foo))))
     (setq e2 (_pnts (car (AT:GetSel entsel "\nSelect next open curve: " foo))))
     (not (initget 0 "Lwpolyline Polyline"))
     (setq *LBL:Opt* (cond ((getkword (strcat "\nSpecify line to draw: [Lwpolyline/Polyline] <"
                                              (cond (*LBL:Opt*)
                                                    ((setq *LBL:Opt* "Lwpolyline"))
                                              )
                                              ">: "
                                      )
                            )
                           )
                           (*LBL:Opt*)
                     )
     )
   )
    ((if (eq *LBL:Opt* "Lwpolyline")
       _lwpline
       _pline
     )
      (vl-remove nil
                 (mapcar (function (lambda (a b)
                                     (if (and a b (not (grdraw (trans a 0 1) (trans b 0 1) 1 1)))
                                       (mapcar (function (lambda (a b) (/ (+ a b) 2.))) a b)
                                     )
                                   )
                         )
                         e1
                         (if (< (_dist (car e1) (car e2))
                                (_dist (car e1) (last e2))
                             )
                           e2
                           (reverse e2)
                         )
                 )
      )
    )
 )
 (princ)
)

Posted

Wow thank you very much alanjt it's working now.

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...