Skip to content

GiDHome/gid_smart_wizard

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

26 Commits
 
 
 
 
 
 
 
 

Repository files navigation

GiD Smart Wizards

The idea

The main idea of this package is to allow GiD problemtype developers to create a wizard interface easy, just configuring an xml file an defining a few tcl procs. Check the example here -> CMas2D CustomLib Wizard.

About this package

This tcl package is included in the 14th version of the GiD pre and post processor. It uses the following packages:

  • gid_wizard: Available in the scripts folder of GiD.
  • wcb: The Widget CallBack. A package that checks the input of an entry field, by Csaba Nemethi, available here.
  • tdom: A package to handle xml documents. Available here.

All the packages defined here are distributed inside GiD, and the library import them. The developers do not need to require them.

Usage:

First thing to do is to define your steps. You can create all your steps using this easy way, but you can also code a step manually. There are no restrictions if you code the step manuelly, you are allowed to use all the elements in TK, but this package helps you only if you try to do something "standard" like asking the user to insert: * input * integers * doubles * strings * combobox - selector * button * text label * image

XML configuration:

A wizard layout is defined in a xml file. This is the basic structure:

XML Tags

  • Wizard: Is the root node, it must contain:
    • version: For version controlling.
    • wizardid: Identifier of the wizard. will be used in the internal data structures and in the window naming.
    • title: Will be placed in the top of the wizard window.
    • icon: In Windows, it will be used as window icon.
  • Steps: Just a container of steps. It has no attributes.
  • Step: They belong to the Steps container. The system will create a 'window' for each of this steps. They must be placed here in order and must contain:
    • id: Will be used in the internal data structures.
    • title: Public name shown in the top of the window.
    • subtitle: Will be shown below the title.
  • Data: Just a container inside a step. It has no attributes.
  • Frame: We split the window layout in 2 sections, left and right. We can define as many frames as we want and place them in one of these sections. Mapping to a html component, a frame is like a div. Must contain:
    • n: Internal name, will be used in the internal data structures. Must be unique in a step.
    • postion: left or right.
    • title: (optional) If title exists, a ttk:labelframe will be placed, else, a normal bordered ttk::frame.
  • Item: They belong to a frame. Mapping to a html component, a item is like a input. It must contain:
    • n: Internal name, will be used in the internal data structures. Must be unique in a step.
    • pn: Public name. Will be converted into a ttk::label and placed in the first position (left align).
    • v: Value of the item. It's the default value.
    • state: Visibility of the item. Can be "normal" or "hidden" (optional)
    • type: As a html input, we can define item types:
      • integer: v must be an integer, and the wcb package will prevent user to insert any strange character. It will be displayed as a ttk::entry.
      • double: v must be an double, and the wcb package will prevent user to insert any strange character. It will be displayed as a ttk::entry. It can contain:
        • units: String that will be displayed next to the entry, to inform about units.
      • string: v can be anything. It will be displayed as a ttk::entry.
      • label: v can be anything. It will be displayed as a ttk::label.
      • combo: v can be one of the options defined in values. Mapping to a html component, a combo is like a select. It will be displayed as ttk::combobox. It must contain:
        • values: Defines the available values in the dropdown. Values can be defined as a static list, separated by commas, or as a dynamic list, using a tcl function that must return a commas separated string (see example NumberOfLoads).
        • onchange: (optional) TCL function called when the combo va.lue is changed by the user. Usefull to create dependencies manually.
      • image: v must the the imagename (picture.png) NOT THE PATH

XML conventions

  • Steps will be shown in the same order they appear in the XML.
  • Frames will be shoen in the same order they appear in the step.
  • I recommend to use titleless frames to place images.
  • Use \n in labels to create line breaks.
  • Use png or jpg images. Animated gifs will not move, don't try it... 😢

TCL implementation

💡 Disclaimer: If you are here, I assume that you know how to create a problemtype in GiD, and know the basics of TCL.

To create a wizard on your problemtype, you need to create all the problemtype files (spd, tcl, bat...) and another to implement the wizard controller.

Initialize

After loading the gid_smart_wizard package, you need to initialize some data, calling the functions:

  • smart_wizard::SetWizardNamespace your_wizard_namespace -> In your wizard controller file, all the functions must be implemented in a namespace.
  • smart_wizard::SetWizardWindowName your_wizard_window_name -> just a name where to place the tk window.
  • smart_wizard::SetWizardImageDirectory your_image_directory -> the path to find the images for the wizard.
  • smart_wizard::LoadWizardDoc your_wizard_xml_file -> the path to find the wizard definition xml file.
  • smart_wizard::ImportWizardData -> method to load your_wizard_xml_file.
  • smart_wizard::CreateWindow -> starts the wizard in the first step. See an example in the function Cmas2d::StartWizard of the example.

Controller

In the controller, all the functions must belong to the namespace declared in smart_wizard::SetWizardNamespace. See an example in the file Wizard_Steps.tcl of the example.

For each step defined in the xml, you must define the function that implements that step:

  • your_wizard_namespace::your_wizard_step_id window_tk_path -> You receive the tk path, of the main frame of the wizard window. There you can place in tcl/tk the widgets that you want, or use the automatic system (This is why this package is useful). To create the step in the automatic way, just call:
  • smart_wizard::AutoStep window_tk_path your_wizard_step_id and let the xml work for you.

Extra (optional): You can bind a procedure to the Next button of a step. In order to implement it, just create a function called:

  • your_wizard_namespace::Next{your_wizard_step_id} For example: Cmas2d::Wizard::NextData -> (The step id is Data). This is useful to implement some action like storing data in the tree, draw something, change the view for the next step...

Extra functions

There are some functions that you can call anywhere in your code, in the begining, in a step load function, or somewhere else. They are, of course, optional.

Window management
  • smart_wizard::SetWizardTitle your_title -> Just that, change the wizard window title (not the step title!).
  • smart_wizard::SetWizardIcon your_icon_name -> An image file must exist inside your image directory. It will be placed as icon of the wizard window.
  • smart_wizard::SetWindowSize x y -> Changes the wizard window size. Make sure your contents fit inside!
  • smart_wizard::DestroyWindow -> It just destroys the wizard window.
Data API
  • smart_wizard::SetProperty step_id item_id value -> Do you remember the items in the xml? They define the fields of a step in the wizard. We can change the value using this function.
  • smart_wizard::GetProperty step_id item_id -> Gets the value of the item.
  • smart_wizard::GetStepProperties step_id -> Gets all the items of a step (not the values, just the item_id, so you can use the function above).
Example

In tcl, having a step called 'Geom' and an item called 'Lenght':

smart_wizard::SetProperty Geom Length,value 7
smart_wizard::SetProperty Geom Length,state hidden
set v [smart_wizard::GetProperty Geom Length,value]
# output: v = 7

Conclusion

After this amazing documentation, maybe you need to procrastinate for a couple of minutes watching this classic fairytale: The little red ridning hood and the wolf Little red ridning hood

Maybe checking the example provided by GiD makes all this take some sense...