Showing posts with label SWMM5 Delphi GUI Dprefers.pas Summary. Show all posts
Showing posts with label SWMM5 Delphi GUI Dprefers.pas Summary. Show all posts

Sunday, December 29, 2024

SWMM5 Delphi GUI Dprefers.pas Summary

 Below is an overview of Dprefers.pas, a Delphi unit from SWMM 5.2 that provides a dialog (TPreferencesForm) for setting various program preferences in the SWMM user interface. These preferences include:

  • General UI behaviors (e.g., blinking map highlighters, confirming deletions, auto backups).
  • Decimal precision for displayed subcatchment, node, and link results.
  • Whether to display a start page on launch, how to handle auto-saving, and more.
  • The application’s visual Style (Delphi VCL theme).

1. Purpose and Context

SWMM allows users to customize various preferences that affect the user interface and certain behaviors not directly related to model computations. The TPreferencesForm is a tabbed dialog that aggregates all these settings, letting the user adjust them in one place. Upon confirmation, these settings are saved to SWMM’s global variables and persist between sessions (e.g., stored in an .ini file or registry).


2. Main Form: TPreferencesForm

2.1 Tabs

TPageControl organizes the preferences into two tabs:

  • TabSheet1: General UI settings
    • Blinking map highlighter, map flyovers, confirm on delete, automatic backup, tab-delimited project file, reporting time in elapsed format, auto-save results, showing the startup/welcome screen, clearing the recent projects list, etc.
  • TabSheet2: Decimal precision / output display
    • Allows the user to set how many decimals are shown for each subcatchment, node, and link output variable.

2.2 Controls

  1. Check Boxes (CheckBox1..CheckBox9) for general preferences like blinking map highlighter, confirm deletions, etc.
  2. Combo Boxes for default variable selection (e.g., NodeVarBox, LinkVarBox, SubcatchVarBox) and a numeric spin edit (TUpDnEditBox) that determines the decimal precision of each variable.
  3. StylesCombo: A drop-down listing available VCL Styles (TStyleManager.StyleNames), letting the user pick a different UI theme.
  4. Buttons: OK, Cancel, Help.

3. Internal Data Management

Within TPreferencesForm, there are arrays storing the decimal digits to be displayed for each set of variables:

  • SubcatchDigits[]: For subcatchment view variables (SUBCATCHOUTVAR1..SUBCATCHVIEWS).
  • NodeDigits[]: For node variables (NODEOUTVAR1..NODEVIEWS).
  • LinkDigits[]: For link variables (LINKOUTVAR1..LINKVIEWS).

When the user changes the spin edit for, say, a subcatchment variable, it updates SubcatchDigits[SubcatchVarBox.ItemIndex]. After hitting OK, these arrays get written back into SWMM’s global data structures:

  • SubcatchUnits[i].Digits := SubcatchDigits[...]
  • NodeUnits[i].Digits := NodeDigits[...]
  • LinkUnits[i].Digits := LinkDigits[...]

4. Event Flow

4.1 FormCreate

  • Initializes the check box captions from PrefersList[] (like “Blinking Map Highlighter,” “Flyover Map Labeling,” etc.).
  • Sets each check box according to the existing global preference variables (Uglobals.Blinking, Uglobals.FlyOvers, etc.).
  • Populates StylesCombo with all available VCL styles. Selects the current style’s name.
  • Fills the subcatch/node/link combo boxes (SubcatchVarBox, etc.) with the names of their output variables and copies the current decimal precision into local arrays (SubcatchDigits[], etc.).

4.2 (User Interaction)

  • The user toggles check boxes for UI behavior.
  • Chooses a subcatchment/node/link variable from the combo box and changes the spin edit to define the decimal places.
  • Possibly picks a different theme from StylesCombo.

4.3 OKBtnClick

  • Calls SetPreferences, which updates Uglobals variables:

    • Uglobals.Blinking := CheckBox1.Checked;
    • Uglobals.FlyOvers := CheckBox2.Checked;
    • … etc.
  • If the user checks “Clear Recent Project List” (CheckBox9), it clears Uglobals.MRUList.

  • Writes new decimal digits for each output variable’s display.

  • Returns mrOK.

4.4 RetrieveStyleName

  • Returns StylesCombo.Text so the main code can apply the chosen VCL style (e.g., TStyleManager.SetStyle(...)).

5. Summary

Dprefers.pas provides a straightforward way for SWMM users to customize how the software behaves and displays data, including:

  • UI behaviors (blinking highlighter, confirm on delete, etc.).
  • Project file formats (tab-delimited or normal).
  • Decimal precision for each subcatchment/node/link result variable.
  • The application’s VCL theme.

By saving these preferences to SWMM’s global variables, the user’s choices persist across sessions, ensuring a consistent, personalized experience.

Banach-Tarski paradox and SWMM5 modeling.

Banach-Tarski paradox and SWMM5 modeling.  Let's elaborate on how the principles underlying Banach-Tarski could inspire practical hydrau...