(defun c: capdew()
    (setq pt1(getpoint "\nEnter first point: ")); Ask the user to select the first point
        (setq pt2(getpoint "\nEnter second point: ")); Ask the user to select the second point
    ; Get the X and Y coordinates of pt1
        (setq pt1_x(car pt1))
        (setq pt1_y(cadr pt1))
    ; Get the X and Y coordinates of pt2
        (setq pt2_x(car pt2))
        (setq pt2_y(cadr pt2))
    ; Calculate the middle point
        (setq mid_pt_x(/ (+ pt1_x pt2_x) 2.0))
            (setq mid_pt_y(/ (+ pt1_y pt2_y) 2.0))
  
  ; Calculate vertical distance relative to mid_pt_x
    (setq vertical_distance(* -0.5(/ (- pt2_x pt1_x) 2.0)))
  
  ; Calculate the Y coordinate of the perpendicular point
    (setq mid_pt_y_perpendicular(+ mid_pt_y vertical_distance))
    (setq mid_pt(list mid_pt_x mid_pt_y)); Create a list for the middle point
        (setq perpendicular_pt(list mid_pt_x mid_pt_y_perpendicular)) ; Create a list for the perpendicular point
            (setq extended_line_end(list pt2_x mid_pt_y_perpendicular)) ; Create a list for the end point of the extended line
                (command "line" pt1 perpendicular_pt pt2); Draw the lines
  
)
(defun c: capdev()
    (setq pt1(getpoint "\nEnter first point: ")); Ask the user to select the first point
        (setq pt2(getpoint "\nEnter second point: ")); Ask the user to select the second point
    ; Get the X and Y coordinates of pt1
        (setq pt1_x(car pt1))
        (setq pt1_y(cadr pt1))
    ; Get the X and Y coordinates of pt2
        (setq pt2_x(car pt2))
        (setq pt2_y(cadr pt2))
    ; Calculate the middle point
        (setq mid_pt_x(/ (+ pt1_x pt2_x) 2.0))
            (setq mid_pt_y(/ (+ pt1_y pt2_y) 2.0))
  
  ; Calculate vertical distance relative to mid_pt_x
    (setq vertical_distance(* 0.5(/ (- pt2_x pt1_x) 2.0)))
  
  ; Calculate the Y coordinate of the perpendicular point
    (setq mid_pt_y_perpendicular(+ mid_pt_y vertical_distance))
    (setq mid_pt(list mid_pt_x mid_pt_y)); Create a list for the middle point
        (setq perpendicular_pt(list mid_pt_x mid_pt_y_perpendicular)) ; Create a list for the perpendicular point
            (setq extended_line_end(list pt2_x mid_pt_y_perpendicular)) ; Create a list for the end point of the extended line
                (command "line" pt1 perpendicular_pt pt2); Draw the lines
                    (princ(strcat "\nThe middle point coordinates are: "(rtos mid_pt_x) ","(rtos mid_pt_y)))
                    (princ(strcat "\nThe perpendicular point coordinates are: "(rtos mid_pt_x) ","(rtos mid_pt_y_perpendicular)))
)
dissabte, 23 de març del 2024
Representación gràfica de bobinados (Autocad)
Subscriure's a:
Comentaris del missatge (Atom)

 
Cap comentari:
Publica un comentari a l'entrada