The Dfind
unit in the EPA SWMM project is a dialog form that helps users search for specific objects (such as subcatchments, nodes, and links) in the study area map. It allows users to find and select objects by their ID, and the form will highlight the found object on the map and display relevant information in the Data Browser.
Key Features of the Dfind
Unit:
-
Search for Objects:
- The form allows the user to search for objects based on their ID. The objects can be:
- Subcatchments (first option in the
ComboBox1
). - Nodes (second option).
- Links (third option).
- Subcatchments (first option in the
- When a valid object ID is entered and the search is performed, the form finds the corresponding object and highlights it on the map.
- The form allows the user to search for objects based on their ID. The objects can be:
-
ComboBox for Object Type:
- A
TComboBox
allows the user to choose the object type they are searching for: Subcatchment, Node, or Link. - The caption of the adjacent objects list (
Label3
) changes based on the selected object type.
- A
-
ListView for Adjacent Objects:
- A
TListBox
displays adjacent objects for the found object:- For a subcatchment, it shows the associated outlet.
- For a link, it shows the connected nodes.
- For a node, it shows the linked nodes.
- The user can select one of these adjacent objects, and it will be highlighted both on the map and in the Data Browser.
- A
-
Date/Time Validation:
- The form allows searching based on an object’s ID, which is essential for identifying specific entities in the model (e.g., subcatchments, nodes, and links) and analyzing their properties over time.
-
Map Integration:
- Once an object is found, the form highlights it on the study area map, and the map is panned to bring the object into view if necessary.
- The
UpdateMapDisplay
function handles this, ensuring that the found object is centered on the map.
-
Navigation and Selection:
- When an object is found, the
UpdateMapDisplay
function zooms in on the object and updates the Data Browser to show its details. - The object can be selected directly from the
ListBox
of adjacent objects.
- When an object is found, the
-
Search for a Specific Object:
- The
SearchFor
function can be used to directly load a specific object into the form, based on its type (subcatchment, node, or link) and index, and it optionally accepts a custom object name.
- The
-
User Interface:
- The form contains the following controls:
- Edit Box: For entering the object ID to search.
- ComboBox: For selecting the object type (subcatchment, node, or link).
- ListBox: For displaying adjacent objects to the found object.
- Find Button: To trigger the search for the object.
- Help Button: Provides help on how to use the find functionality.
- Status Message: Displays information about the search result (e.g., no object found).
- The form contains the following controls:
Detailed Breakdown of Functions:
-
FormCreate:
- This method positions the form relative to the
MainForm
and prepares the initial state for the combo box and list box controls.
- This method positions the form relative to the
-
FormShow:
- Sets up the form for displaying the results and highlights the first item in the list.
-
FormClose:
- When the form is closed, it is hidden rather than destroyed, which is useful for preserving its state between interactions.
-
Clear:
- Clears the search fields and resets the list of adjacent objects.
-
Button1Click:
- This method handles the action of searching for the object based on the entered ID. It checks the
ComboBox
to determine the object type (subcatchment, node, or link) and attempts to find it in the project. If the object is found, it callsGetAdjacentObjects
to list its adjacent items, andUpdateMapDisplay
to highlight the object on the map.
- This method handles the action of searching for the object based on the entered ID. It checks the
-
GetAdjacentObjects:
- This method retrieves and lists the adjacent objects for the selected object type:
- For subcatchments, it lists the outlet node.
- For nodes, it lists the connected links.
- For links, it lists the connected nodes.
- This method retrieves and lists the adjacent objects for the selected object type:
-
UpdateMapDisplay:
- Highlights the found object on the map and ensures it is in view by panning the map to the object’s location.
-
ComboBox1Change:
- Updates the caption of the adjacent objects list based on the selected object type in the combo box.
-
FormKeyPress:
- This method enables the user to press
Enter
to trigger the search andEsc
to close the form.
- This method enables the user to press
-
ListBox1Click:
- This method handles the selection of an adjacent object from the list. When an item is selected, it highlights the object on the map and updates the Data Browser to show its details.
-
SearchFor:
- This method is used to directly search for and highlight a specific object, either from the Data Browser or other parts of the program.
Use Cases:
- Find and Highlight Objects: The
TFindForm
is primarily used for quickly locating objects in the study area and zooming in on them on the map. - View Adjacent Objects: It allows users to view adjacent objects (e.g., the connected nodes or links for a given node or link) and navigate to them.
- Efficient Navigation: It helps users efficiently navigate large models by providing a fast way to find and focus on specific objects based on their ID.
Key Variables:
- FoundObject: Stores the ID of the found object.
- FoundIndex: Stores the index of the found object in the project’s list.
- ComboBox1: Allows the user to select the object type to search for (subcatchment, node, or link).
- Edit1: The text input field where the user enters the object ID.
- ListBox1: Displays the adjacent objects of the found object.
This unit is a crucial part of the SWMM interface as it enhances the user experience by providing an intuitive way to search for and navigate between various objects in the model. It integrates seamlessly with the map and the Data Browser, allowing users to quickly locate and inspect any object in the study area.