Visual LISP, AutoLISP and General Customization
cancel
Showing results for 
Show  only  | Search instead for 
Did you mean: 

Run seperate Function after action_tile selection

11 REPLIES 11
SOLVED
Reply
Message 1 of 12
tcoley95E9Z
539 Views, 11 Replies

Run seperate Function after action_tile selection

I have been going at this code for over a week trying to get this to work...

I have a pretty big LISP file with individual routines defined within it to assist my coworkers in their drafting process. I realized as this routine is expected to grow and it would take a bit for my coworkers to memorize all of the commands, I made a quick DCL with a handful of image slides to make it easier for them. This is where I'm stuck though..

 

I want the original DCL to close before opening the next programs DCL, anything I've tried has given me all types of error codes, or has been able to run but the original DCL was stuck on the screen. Below is my code and a snip of the first DCL.

 

(defun c:BNS()
   ; code here works as normal
)

(defun c:ULT (/ Dcl_Id% what_next cnt)
  (vl-load-com)
  (setq Slides@ (list nil "BNS" "BTOOLS" "LYRFRZ" "VPLU" "WIP" "WIP" "CMD7" "CMD8" "CMD9") ;; NAME OF THE .SLD FILE
        Slide1$ (nth 1 Slides@)
        Slide2$ (nth 2 Slides@)
        Slide3$ (nth 3 Slides@)
        Slide4$ (nth 4 Slides@)
        Slide5$ (nth 5 Slides@)
        Slide6$ (nth 6 Slides@)
        Folder$ (strcat "Z:/" "5. Documents/Programs/Autodesk/Auto & Visual LISP/Programs/AutoLISP Ultimate/AutoULT Slides/") 
        Return$ "")
  
  (setq *commands_to_execute* '((c:ULT) (c:BTOOLS) (c:LYRFRZ)))
  
  (setq Dcl_Id% (load_dialog "AutoLISP Ultimate.dcl"))
  (setq what_next 2)
  
  (while (>= what_next 2)
    (if (null (new_dialog "autoULT" Dcl_Id%))
      (exit)
    )
    (set_tile "Title" "AutoLISP Ultimate")

    (start_image "Slide1")(setq X# (- (dimx_tile "Slide1") 2))
    (setq Y# (- (dimy_tile "Slide1") 2))(end_image)   
    (start_image "Slide1")(slide_image -12 -3 175 Y# (strcat Folder$ Slide1$))(end_image) ; -X= << || -Y= ^^
    (start_image "Slide2")(slide_image 0 -6 X# Y# (strcat Folder$ Slide2$))(end_image)
    (start_image "Slide3")(slide_image 0 -7 X# Y# (strcat Folder$ Slide3$))(end_image)
    (start_image "Slide4")(slide_image -2 -6 X# Y# (strcat Folder$ Slide4$))(end_image)
    (start_image "Slide5")(slide_image -2 -6 X# Y# (strcat Folder$ Slide5$))(end_image)
    (start_image "Slide6")(slide_image -2 -6 X# Y# (strcat Folder$ Slide6$))(end_image)

    (action_tile "Slide1" "(setq Return$ Slide1$) (c:BNS) (done_dialog 4)")
    (action_tile "Slide2" "(setq *command_index* 1)(setq *commands_requested* t)")  
    (action_tile "Slide3" "(progn (done_dialog 4)(setq Return$ (strcat \"c:\" Slide3$)))")
    (action_tile "Slide4" "(progn (done_dialog 4)(setq Return$ (strcat \"c:\" Slide4$)))")
    (action_tile "accept"
          "(setq *commands_requested* nil)
            (done_dialog 1)
            (if (setq idx *command_index*)
                (progn
                  (mapcar '(lambda (cmd) (if (= idx (car cmd)) (eval (cadr cmd)))) *commands_to_execute*)
                  (setq *command_index* nil)
                )
            )"
      )
    ; (action_tile "accept" "(done_dialog 1) (princ \"OK button clicked\")")
    (setq what_next (start_dialog)) 
    (cond
        ((= what_next 4)       
          (done_dialog 4)
        )
        ((= what_next 0)
          (prompt "\nuser cancelled dialog")
        )
      )
    )
    (unload_dialog Dcl_Id%) 
    (if (= what_next 4)
        (progn
          (setq Return$ Slide1$)
          (c:BNS))
    )
    (princ)  
)

tcoley95E9Z_0-1712604323168.png

 

Labels (4)
11 REPLIES 11
Message 2 of 12
paullimapa
in reply to: tcoley95E9Z

Assuming the following is what you want:

1. click on the slide image

2. the dialog to close

3. then run (c:BNS)

And you don't need to return to the original dialog after (c:BNS) finishes, then there's no need for this while loop:

(while (>= what_next 2)

Your action call back code needs to just have done_dialog and the # in this case 4:

(action_tile "Slide1" "(setq Return$ Slide1$)(done_dialog 4)")

This instructs the dialog to close. Then you can have your cond statement check what was the return # and run the code there:

(cond
        ((= what_next 4)       
          (c:BNS)
        )

Which means you don't need this last section of the code:

    (if (= what_next 4)
        (progn
          (setq Return$ Slide1$)
          (c:BNS))
    )

FYI, you don't need progn in your action call back code unless you have an if statement first. Since you don't in your case then you can just leave the progn out like this:

    (action_tile "Slide3" "(done_dialog 4)(setq Return$ (strcat \"c:\" Slide3$))")
    (action_tile "Slide4" "(done_dialog 4)(setq Return$ (strcat \"c:\" Slide4$))")

Paul Li
IT Specialist
@The Office
Apps & Publications | Video Demos
Message 3 of 12
Sea-Haven
in reply to: tcoley95E9Z

You can make library dcl's say a 3x2 DCl that are loaded, you only need a list of slide names, the slides are populated using a loop reading the list, the tile selected is again read out of a function then action taken.

 

You can also do Child dcl's so select master bolts then sub child dcl is opened for more options. 

SeaHaven_1-1712638396086.png

 

 

Pop menus may be even easier to use

SeaHaven_0-1712638357746.png

 

Will have a look at your code may be simplified. In a single big piece of code I have there are 14 calls to individual DCl's, sounds like your heading that way. See child image above.

 

Your welcome to use these. May save you a lot of dcl making time.

 

 

Message 4 of 12
tcoley95E9Z
in reply to: paullimapa

Paul, thank you so much! I cannot thank you enough for the help you've been!

Message 5 of 12
tcoley95E9Z
in reply to: Sea-Haven

You are amazing sir!

Message 6 of 12
tcoley95E9Z
in reply to: paullimapa

How would I get this program to run a conditional for every slide? There are 6 total. Would I just be able to make done_dialog 4-10?

Message 7 of 12
scot-65
in reply to: tcoley95E9Z

Your unload_dialog should be outside the while loop.
Looking a little closer, it appears as if you do not need the while loop at all.
Each image tile corresponds to a custom command - why do we need to reenter this dialog?

(defun MyProg_Dialog ()
When looping, isolate the entire section between new_dialog and start_dialog.
);end MyProg_Dialog
;*** Dashboard ***
(setq sd 2)
(try to load_dialog here)
(while (> sd 0)
(cond
(( )(call to the dialog or other actions))...
);cond
);while
Now unload_dialog here.

Simplify your action_tile:
If you use "sd" as the carrier _what_next_:
(action_tile "Slide1" "(done_dialog 1)")
(action_tile "Slide99" "(done_dialog 99)")
is all that you need.
-- then --
Associate the "sd" value to the command now that the dialog is closed.
(cond
((= sd 1) (c:ULT))
...
((= sd 99) (c:CMD99))
(t (alert "None found. "))
);cond

Scot-65
A gift of extraordinary Common Sense does not require an Acronym Suffix to be added to my given name.


Message 8 of 12
paullimapa
in reply to: tcoley95E9Z

This is what I would do:

1. Just drop the $ character & make a list of those slides like this:

 

  (setq Slides@ (list nil "BNS" "BTOOLS" "LYRFRZ" "VPLU" "WIP" "WIP" "CMD7" "CMD8" "CMD9") ;; NAME OF THE .SLD FILE
        Slide1 (nth 1 Slides@)
        Slide2 (nth 2 Slides@)
        Slide3 (nth 3 Slides@)
        Slide4 (nth 4 Slides@)
        Slide5 (nth 5 Slides@)
        Slide6 (nth 6 Slides@)
        Folder (strcat "Z:/" "5. Documents/Programs/Autodesk/Auto & Visual LISP/Programs/AutoLISP Ultimate/AutoULT Slides/") 
        Return ""
        Slidelst (list "Slide1" "Slide2" "Slide3" "Slide4" "Slide5" "Slide6")
   )

 

 Then all you need is a single action call back statement using the tile key to equate to Return$ like this:

 

(foreach tile Slidelst
 (action_tile tile "(setq Return$ $key)(done_dialog 4)")
)

 

Then your cond statement for 4 looks like this and works for all 6 slides:

 

    (cond
        ((= what_next 4)       
          (c:BNS)
        )
        ((= what_next 0)
          (prompt "\nuser cancelled dialog")
        )
      )

 

This is because you already have the Return$ value set previously in the call back statement:

 

(setq Return$ $key)

 

Now this assumes your c:BNS lisp function checks to see what the Return$ is (Slide1 through Slide6) and then runs something different for each.

 


Paul Li
IT Specialist
@The Office
Apps & Publications | Video Demos
Message 9 of 12
tcoley95E9Z
in reply to: Sea-Haven

How do I look into these Pop Menus? I am really interested but cannot find any resources on them.. are they .Mnu files?

Message 10 of 12
Sea-Haven
in reply to: tcoley95E9Z

Yes they are mnu files. You use menuload to load them, you make them with say Notepad NOT Word. 

 

Here is an example.

 

 

***MENUGROUP=TRAFFIC

***POP19
**2016TRAFFIC
[TRAFFIC]
[Num carparks]^C^C(load "how many carparks") carpark
[Carpark 0]^C^C(load "simple carpark") npark90 
[Carpark 30]^C^C(load "simple carpark") npark30 
[Carpark 45]^C^C^p(load "simple carpark") npark45
[Carpark 60]^C^C(load "simple carpark") npark60
[Carpark 90]^C^C(load "simple carpark") npark90

 

There is 100+ functions here

SeaHaven_0-1713486075195.png

You can do custom toolbars as well

SeaHaven_1-1713486124735.png

 

If you get stuck PM me.

 

 

  

Message 11 of 12
perfectprajwal1
in reply to: Sea-Haven

i am a noob on lisp, will you plz explan how can i add quick selection criteria in each radio button for multi quick select help needed

Message 12 of 12
Sea-Haven
in reply to: perfectprajwal1

It may be best to start a new topic not sure what you mean. In new topic explain more image etc what it is you want. Show dcl.

Can't find what you're looking for? Ask the community or share your knowledge.

Post to forums  

Forma Design Contest


Autodesk Design & Make Report