Below is an overview of Dlid.pas, a Delphi unit from SWMM 5.2 that provides a dialog (TLidControlDlg) to create or edit an LID Control definition. SWMM uses Low Impact Development (LID) controls—such as bioretention cells, rain barrels, permeable pavement, etc.—to model best management practices in a watershed.
1. Purpose and Context
Each LID Control in SWMM represents a reusable design template that can be assigned to multiple subcatchments. This dialog enables the user to:
- Specify the LID type (e.g., Rain Garden, Green Roof, Permeable Pavement, etc.)
- Provide layer properties (surface layer, pavement layer, soil layer, storage layer, drain layer, etc.)
- Handle pollutant removals in the underdrain outflow.
These controls reflect how infiltration, storage, and outflow are handled for a particular type of LID.
2. Main Form: TLidControlDlg
2.1 Key Controls
- NameEdit: The name of the LID control (must be unique among LID controls).
- TypeCombo: A dropdown listing the LID process types (Bio Cell, Rain Garden, Green Roof, etc.).
- PageControl1 with multiple TTabSheet pages, each containing TNumEdit controls for layer properties:
- TabSheet1: Surface layer (e.g., Berm Height, Surface Storage, Vegetative cover, etc.)
- TabSheet2: Pavement layer (thickness, void ratio, impervious surfaces)
- TabSheet3: Soil layer (thickness, porosity, infiltration rates, etc.)
- TabSheet4: Storage layer (thickness, void ratio, infiltration, optional “rain barrel” coverage)
- TabSheet5: Drain layer (flow coefficient, offset, underdrain capacity)
- TabSheet6: Drainage mat (for Green Roofs)
- TabSheet7: Roof Disconnection (downspout parameters)
- TabSheet8: Pollutant Removals (optional percent removals for underdrain outflow)
- RemovalsEditor: A
TValueListEditor
containing a row for each pollutant, storing underdrain removal efficiency. - CoveredCheckBox: An option for a covered rain barrel.
- OK, Cancel, and Help buttons.
3. Data Structures
3.1 TLid Object
A single TLid object has:
ProcessType
: integer matching the selected item inTypeCombo
.- SurfaceLayer: array of up to 5 strings.
- PavementLayer: array of up to 7 strings.
- SoilLayer: array of up to 7 strings.
- StorageLayer: array of up to 5 strings (four numeric + “YES/NO” for rain barrel coverage).
- DrainLayer: array of up to 7 strings (6 numeric + 1 reference to a control curve).
- DrainMatLayer: array of 3 strings (for Green Roof drainage mat).
- DrainRemovals: string list of Key=Value entries for each pollutant’s removal efficiency.
Note: Many fields are stored as strings so that SWMM can parse them at runtime without losing formatting or the user’s numeric precision.
4. Form Lifecycle
4.1 SetData(Index, aLID)
- Called to initialize the dialog:
- If
Index >= 0
, fetch the LID’s name fromProject.Lists[LID].Strings[Index]
and place it inNameEdit
. - Set
TypeCombo.ItemIndex := aLID.ProcessType
. - Fill each relevant TNumEdit (e.g.,
SurfaceEdit1..SurfaceEdit5
,PavementEdit1..PavementEdit7
, etc.) fromaLID.SurfaceLayer[]
,aLID.PavementLayer[]
, etc. - Assign the underdrain pollutant removals into
RemovalsEditor
. - Update which tab sheets (
TabSheet1..TabSheet8
) are visible or hidden based on the chosen LID type (viaTypeComboClick
). - Mark
Modified := False
.
- If
4.2 TypeComboClick
- Adjusts TabSheet visibility based on the selected LID type. For example:
- Rain Barrel hides the surface layer tab, makes the storage tab more specialized, etc.
- Green Roof hides the storage tab, shows the drain mat tab.
- Roof Disconnection shows a simpler layout, no drain or storage tab.
- Vegetative Swale hides the storage/drain tabs, modifies surface label usage.
- Also updates the icon in
LIDImage
to reflect the chosen type.
4.3 User Interaction
- The user edits layer parameters in the TNumEdits across multiple tabs.
- Optionally checks the
CoveredCheckBox
for a Rain Barrel. - Edits pollutant removal percentages in
RemovalsEditor
. - Switches LID type from the drop-down, which triggers re-configuration of visible tabs.
4.4 Validation
OkBtnClick:
- Checks that NameEdit is non-empty and not duplicated.
- Runs
LayerDepthsValid
to ensure certain layer thickness fields (soil, pavement, storage, drainage mat) are > 0 if required by the chosen LID type. - If invalid, displays an error message, sets focus to the offending field, and does not close.
- Otherwise, sets
ModalResult := mrOK
.
4.5 GetData
- Called after OK is pressed and validation passes, to store the final results into the
TLid
object:- LID name is read from
NameEdit.Text
. ProcessType
fromTypeCombo.ItemIndex
.- The numeric TNumEdits from each layer tab are written back into e.g.
aLID.SurfaceLayer[i-1]
,aLID.PavementLayer[i-1]
, etc. - The pollutant removal Key=Value pairs from
RemovalsEditor.Strings
go intoaLID.DrainRemovals
. - The “Covered” rain barrel option is saved as
aLID.StorageLayer[4] := 'YES' or 'NO'
.
- LID name is read from
5. Notable Procedures
5.1 LayerDepthsValid
- Checks that certain layer thickness TNumEdits are greater than zero, depending on LID type:
- Biocell/Rain Garden/Green Roof => soil layer must be > 0.
- Permeable Pavement => pavement layer must be > 0.
- If infiltration trench => storage layer must be > 0.
- Green Roof => drainage mat must be > 0.
- Vegetative Swale => berm height must be > 0.
If any are 0, it shows an error message and makes the form remain open.
5.2 RemovalsEditorValidate
- Ensures the user’s entered removal fraction is numeric and in [0..100].
- If invalid, it reverts to the prior value.
5.3 NumEditExit
- For certain fraction-based fields (e.g., infiltration fraction), ensures it’s < 1.0. If not, prompts an error.
6. Summary
Dlid.pas provides a multi-tabbed dialog to define or edit a Low Impact Development template, specifying layering and outflow pollutant removals. The LID control can then be reused in subcatchments. By splitting parameters across separate tabs (Surface, Pavement, Soil, Storage, Drain, etc.), the form makes it clearer to configure the LID’s layered structure and internal drainage properties. Validation ensures consistent entries for thickness, name uniqueness, and pollutant removal rates.