VASSAL Reference Manual
Map Window
A Map Window contains the main interface for playing games with VASSAL. It displays the playing surface on which the players move Game Pieces by dragging and dropping with the mouse. It is possible to have two or more Map Windows; the players may drag and drop pieces between the different windows. A Map Window should be configured with at least one Map Board (in the "Map Boards" component).
To add additional Map Windows to your module, use the Editor to navigate to the [Module] entry at the very top of the Editor’s configuration window hierarchy. Right click on the [Module] entry and select Add Map Window. Your new Map Window will be added to the very bottom of your Module’s list of components. You can then open the [Map Window] entry, where you should right click on the [Map Boards] subcomponent and add at least one Board. You can also add additional subcomponents by right-clicking the [Map Window] entry and selecting one of the appropriate Add options. See Sub-Components, below.
SEE ALSO: Player Hands and Private Windows are specialized forms of Map Window and share most of its properties and subcomponents. They are designed for holding pieces and cards that are private to one player or side.
Map Name: The name of this map window. Mark pieces that move: If checked, then any pieces with the Mark When Moved trait will be marked whenever being moved in this map window. The module designer can also allow players to control this option in their preferences. "Mark unmoved" button: Configuring button text and/or a button icon causes a button to appear on the map window’s Toolbar; clicking this button clears the movement history for all Game Pieces on the map: this removes the movement "mark" from any such Game Pieces, and also clears their Movement Trails if they also contain a Movement Trails trait. Tooltip text can also be configured for this button. Vertical/Horizontal padding: The amount of blank space surrounding the boards in the window. Background color: The color to use in the blank space padding. Can Contain Multiple Boards: If checked, this map window can contain several boards arranged into rows and columns. Border color for selected counters: The color of the border to draw around pieces that have been selected. Border thickness for selected counters: The thickness of the border to draw around pieces that have been selected. Include toolbar button to show/hide: If checked, then this map window will not be automatically shown when a game begins. Instead, a button to show/hide this window will be added to the main module Toolbar. NOTE: changing this option will not take effect until the module has been reloaded (exit from the Module Editor and restart it). Button text: The name of the show/hide Toolbar button Tooltip text: Optional tooltip text for the show/hide Toolbar button Button icon: An icon for the show/hide Toolbar button Hotkey: The hotkey (or Named Key Command) for the show/hide Toolbar button Auto-report format for movement within this map: A Message Format that will be used to automatically report movement of pieces completely within this map window:f $pieceName$ is the name of the piece being moved, $location$ is the location to which the piece is being moved (in the format specified below), $previousLocation$ is the location from which the piece is being moved. NOTE: These reports are separate from, and in addition to, any reports the piece itself generates with Report Action traits in response to the Key Command applied by the bottom field. Auto-report format for movement to this map: A Message Format that will be used to report movement of pieces to this map window from another map window: In addition to the properties noted for the above item, $previousMap$ is the name of the map from which the piece is being moved. Auto-report format for units created in this map: A Message Format that will be used to report pieces that are dragged to this map window directly from a Game Piece Palette: The properties mentioned in the previous two items may be referenced as appropriate. Auto-report format for units modified on this map: When a Report Action trait of a Game Piece on this map is activated, this Message Format will be used to format the message that trait requests to display. $message$ is the text message from the Report Action trait. It could optionally be modified to include e.g. the name of this Map. Key Command to apply to all units ending movement on this map: The Key Command or Named Key Command to be automatically applied to each piece that ends movement on this map, whether it is moved by drag-and-drop or by a Send To Location trait. This Key Command can be used, for example, to trigger actions that need to be taken when a piece enters or leaves a new space (for example maintaining piece type counts in a Zone — see Example 4 in the Trigger Action trait), or to generate more elaborate Report Action chat log messages than can be created with the Auto-report format (for example, ensuring that the message is only displayed if the piece has actually changed regions rather than merely being adjusted in its space). |
|
Sub-Components
Map are created with several default sub-components, but new ones can be added. To add sub-components to a map, navigate to the [Map Window] component entry in the Editor, right click on the [Map Window] component, and select the appropriate Add option for the sub-component you would like to add. Once you configure it, your new sub-component will appear at the bottom of the Map’s list of sub-components.
Map Boards
This component contains all the boards that may appear in this map window. It contains Board components and defines the dialog that is used to select boards when a new game is started. Dialog Title: The title of the dialog window for choosing boards on this map. "Select Boards" prompt: The prompt message in the drop-down menu for selecting boards Cell scale factor: The relative size of the boards in the dialog compared to their final size during play. Cell width: The width of a cell when no board has been selected. Cell height: The height of a cell when no board has been selected. Default Board Setup: Click this button to choose a default set of boards. When a default has been set, the dialog will not be shown to players when a new game is begun. Instead, the game will always be started with the boards you select. If you click this button and then clear the boards, then dialog will again be shown at the start of each game. |
Stacking Options
This component controls how stacking is handled in this Map Window. It may not be removed.
Disable stacking: If checked, then pieces will never form stacks in this window Horizontal Separation when expanded: The distance in pixels from the left edge (right edge if negative) of a piece in a stack to the edge of the piece above it when the stack is expanded. Vertical Separation when expanded: The distance in pixels from the bottom edge (top edge if negative) of a piece in a stack to the edge of the piece above it when the stack is expanded. Horizontal Separation when not expanded: The distance in pixels from the left edge (right edge if negative) of a piece in a stack to the edge of the piece above it when the stack is compact. Vertical Separation when not expanded: The distance in pixels from the bottom edge (top edge if negative) of a piece in a stack to the edge of the piece above it when the stack is compact. Color of pieces when not expanded: If set, then pieces below the top piece in a compact stack will be drawn as plain squares of this color and a black border. If not set (click the "Select" button and cancel the color-selection dialog to "unset" this) then pieces will be drawn normally. |
Overview Window, or "Mini Map"
Adds a separate "Mini Map" subwindow that will be displayed whenever the Map Window is displayed. A Toolbar button to turn this subwindow on and off will be placed on the Map Window’s toolbar - it can be configured with any combination button text, a button icon, and tooltip text. A hotkey or Named Key Command can also be supplied to open the mini map subwindow.
The subwindow will contain a view of the entire playing area at a smaller scale than displayed in the parent map window. The area of the map currently visible in the map window is highlighted in the overview map with a colored rectangle. A player may click on the Overview window to center the Map Window at the point clicked on.
The scale of the overview window relative to the map window can be specified in the "Scale Factor" property. You may also specify the color of the rectangle indicating the area visible in the main Map Window.
Line of Sight Thread
Adds a button to the Toolbar of the Map Window. Clicking the button will allow the player to drag the mouse between any two points in the window, drawing a line between those two points. Hotkey: Specifies a keyboard shortcut or Named Key Command for the Toolbar button. Button text: The label on the Button in the Map Window’s Toolbar Draw Range: If checked, draws the range between the two points, in hexes or squares, as appropriate for the board in use. Pixels per range unit: If drawing the range on a board without a grid, this determines how many pixels on the screen equal a single unit of range. Round fractions: For distances that are a fraction of a range unit, specify whether to round fractions up, down, or to the nearest whole number. Hide Pieces while drawing: If checked, then all game pieces in the map will be hidden (or transparent) while the thread is being drawn. Opacity of hidden pieces: Set the transparency of game pieces while the thread is being drawn. 0 is completely transparent, 100 is completely opaque. Thread color: Specifies the color the thread on the screen. If set to null (by clicking the "Select" button and then the "Cancel" button in the color-choosing dialog), then a Preferences option will determine the color of the thread at game time. |
Toolbar Menu
Groups buttons in the toolbar into a single drop-down menu. See full article for details. |
Hide Pieces Button
Adds a button to the Toolbar of the Map Window. Clicking the button will temporarily hide all pieces on the map, until the button is clicked again.
Button text: Specifies the button text for the Toolbar button Tooltip text: Specifies optional tooltip text for the Toolbar button Hotkey: Specifies a keyboard shortcut for the Toolbar button Icon when pieces are showing: Configures an icon which is shown when pieces on the map are currently visible. Icon when pieces are hidden: Configures an icon which is shown when pieces on the map have currently been hidden by this button. |
Zoom capability
Adds the ability to zoom in and out of the Map. Toolbar buttons for "Zoom in", "Zoom out", and "Select Zoom Level" are added to the Map Window’s toolbar.
Preset Zoom Levels: Configures a series of fractional scale factors for display of the Map Window. In the list on the right hand side, all of the currently configured scale factors are listed. The one with an asterisk () indicates the scale factor at which the Map Window will begin when the module is started. The other scale factors represent the settings along a range which clicking the "Zoom in" and "Zoom out" buttons will move the zoom level. *Add: To add a new scale factor, type it into the blank and then click the "Add" button. The new scale factor will appear in the list to the right. Remove: To remove an unwanted scale factor from the list, select it in the list at right and then click the "Remove" button. Set Initial: To select the scale factor at which the Map Window will begin when the module is started, select it from the list at right and click the "Set Initial" button. An asterisk () will appear next to the new at-start scale factor. *Zoom In: Configures a Toolbar button and/or hotkey that cause the Map Window scale factor to jump to the next higher magnification level. Tooltip Text: Configures optional tooltip text for the Toolbar button. Button Text: Configures button text for the Toolbar button. Button Icon: Configures an icon for the Toolbar button. Hotkey: Designates a keyboard shortcut or Named Key Command for zooming in. Zoom Select: Configures a Toolbar button and/or hotkey that will allow the player to pick a specific scale factor, including by typing in an arbitrary scale factor manually. Tooltip Text: Configures optional tooltip text for the Toolbar button. Button Text: Configures button text for the Toolbar button. Button Icon: Configures an icon for the Toolbar button. Hotkey: Designates a keyboard shortcut or Named Key Command for selecting the zoom level. Zoom Out: Configures a Toolbar button and/or hotkey that cause the Map Window scale factor to jump to the next smaller magnification level. Tooltip Text: Configures optional tooltip text for the Toolbar button. Button Text: Configures button text for the Toolbar button. Button Icon: Configures an icon for the Toolbar button. Hotkey: Designates a keyboard shortcut or Named Key Command for zooming out. |
Mouse-over Stack Viewer
Adds a tool that displays the contents of a stack when the player leaves the mouse resting over it, after a specified delay.
Recommended Delay before display: When the mouse has been stationary for this many milliseconds, the viewer will appear. This can be overridden in the preferences. Keyboard shortcut to display: Players may display the viewer without waiting by pressing this shortcut key. This can be disabled in the preferences. Background color: Pieces/text are drawn against a background of this color. Border/text color: Color of any text drawn and the border around the overall viewer. Display when at least this many pieces will be included: If set to 0, then the viewer will display even if the location is empty. Otherwise, it will display only if 1 or 2 pieces have been included via the settings below. Always display when zoom level is less than: Regardless of the above "at least this many" setting, the viewer will also display when the map’s magnification factor is less than this number. Draw pieces: If selected, then the included pieces will be draw in the viewer. Draw pieces using zoom factor: The magnification factor to use to draw the pieces in the viewer. Width of gap between pieces: Empty space in pixels to place between each drawn piece. Display text: If selected, then the viewer will draw some summary text and some individualized text for each piece. Font size: Fort size for the text drawn by the stack viewer. Summary text above pieces: A Message Format specifying the text to display above the drawn pieces in the viewer. In addition to standard Properties, you can include $countPieces$ to count the pieces included in the display. You can also include a property with the name sum(propertyName) where propertyName is a property defined on a Game Piece. The sum of the numeric values of this property for all included pieces will be substituted. Text below each piece: A Message Format specifying the text to display below each included piece. Text for empty location: A Message Format specifying the text to display when no pieces have been selected. Include individual pieces: Specifies how pieces are to be selected for inclusion in the viewer. You may restrict the pieces according to the Game Piece Layer that they belong. Alternatively, you may specify an Property Match Expression to match desired values of one or more Properties in order for a piece to be included. Include non-stacking pieces: If selected, then pieces with a Does not stack trait are eligible for inclusion in the viewer. Otherwise they are excluded regardless of any other filters. Show pieces in unrotated state: If selected, then pieces that can rotate are drawn in the viewer as they look when not rotated. Include top piece in Deck: If selected, then the top piece of a Deck is eligible for inclusion. Show all pieces overlapping the first piece found: If selected, then all Game Pieces that overlap the mouse cursor location are eligible to be displayed; otherwise only pieces at the exact X,Y position of the top piece found are displayed. |
Last Move Highlighter
Draws a colored border around the last piece to have been moved, added, or deleted in a logfile or by an opponent during live play. Color is the color of the border and Thickness is the border thickness. The highlight is cleared by clicking on the map. |
Game Piece Layers
Allows you designate certain "layers" of Game Pieces to be drawn before others. Pieces in higher layers are always drawn on top of lower layers, and pieces never combine into stacks with pieces from other layers. See full Game Piece Layers article for details. |
Image Capture Tool
Adds a "Camera" button to the Toolbar of the Map Window. Clicking the button will dump the contents of the Map Window to an image file. This allows you to take a screen shot even if the Map Window is too large to fit entirely on the screen. |
Text Capture Tool
Adds a "Save Text" Button to the Map Window’s Toolbar. Clicking the button will write a plain text summary of the contents of the map to a text file, using the names assigned to the pieces and the appropriate numbering and/or naming of the board’s grid. |
Deck
A deck of cards, a bag of chits, or a fixed supply of counters. Decks are versatile containers for collections of pieces — especially the kind that need to be shuffled, randomized, hidden, and drawn from. See full article for details. |
At-Start Stack
A group of one or more pieces which begin the game on the map. See full article for more details. |
Recenter Pieces Button
Adds a button to the map window’s Toolbar. Clicking the button will shift the position of all pieces on the map such that they are centered around the middle of the map as much as possible. This is useful for games where there are no absolute terrain features, such as some air and naval games. |
Startup Global Key Command
Can print a welcome message, or perform some other task that needs to be done whenever the module is started up.
An extension of Global Key Command that fires automatically upon completion of module load, once all the key listeners are started up. All fields behave identically to the corresponding ones in Global Key Command, except that those pertaining to the physical representation of a Toolbar button are suppressed as being inapplicable. If multiple start-up commands need to be run in a particular order, they should be combined in a MultiAction Button and then launched from a single instance of Startup Global Key Command, as the sequence in which multiple instances of StartupGlobalKeyCommand are fired is undetermined. NOTE: Startup Global Key Commands fire every time the module starts up, whether it is to begin a new game or to load and continue an existing one. Thus if you need the Startup GKC to initiate an activity that should only be done once at the very beginning of a game, then it would need to send a key command to a pre-designated piece, which could then check a Global Property (called, perhaps, "StartupDone") to determine whether the game had already been started — if it hadn’t, the piece could then perform those tasks and set "StartupDone" to true, which would prevent the actions from being taken on a subsequent load of a saved game. |
Global Key Command
Adds a button to the map window’s Toolbar. Clicking the button will pick certain pieces from the map window and apply the same key command to all of them.
|
|
Map Shading
Applies a semi-transparent solid color or image tiling to the Map. In background mode, can be used to overlay a repeating image over solid-color boards. In foreground mode, the area is determined by the pieces on the map that name this Map Shading in an Area of Effect trait.
Name: A short name of this shading for reference by pieces with the Area of Effect trait. Shading Always On: If selected then the shading is always drawn. Otherwise, visibility is controlled by a button on the Toolbar. Shading Starts turned on: If true, then the shading will begin visible when the module is loaded. Button text: Text for the Toolbar button. Tooltip text: Optional rollover text for the Toolbar button. Button icon: Icon for the Toolbar button. Hotkey: Keyboard shortcut or Named Key Command for the Toolbar button. All boards in map get Shaded: Allows you to select which Boards in the map to apply the shading to. Type: If set to Background then the shaded area includes the entire board, minus the areas attached to any Area of Effect traits. If set to Foreground, then the shaded area includes only the areas attached to Area of Effect traits. Draw Shade on top of Counters: If selected, then the shading will be drawn over any pieces on the map. Otherwise, it will be drawn underneath all pieces. Shade Pattern: Choose between 100/75/50/25 % hatch patterns, or choose a custom image. Color: The color of the shading (if not using a custom image). Opacity: The opacity of the shading. 0 is completely transparent, 100 is completely opaque. Border: If selected, will draw a border around the shading area. You can specify the thickness, color, and opacity of the border. |
Global Properties
Maps can have their own Global Properties, which apply to and are accessible by pieces on that map.
To add a Global Property to your map, find the [Global Properties] subcomponent in the Editor, right-click it, and select Add Global Property. This will let you define the initial value and any numeric constraints. Then, you can right-click on the [Global Property] entry to optionally Add Change-property Toolbar Button, the configuration dialog for which is shown at left. See the article on the Global Property trait of pieces for more details and examples. |
Additional Selection Highlighters
Allows you to define additional ways to highlight the selected piece on a map. The additional highlighters are drawn only if the selected piece matches the specified properties. If a piece matches the properties of more than one highlighter, all will be drawn, in addition to the highlighting color/border specified in the Map’s properties. To add an Additional Selection Highlighter to your map, locate the [Additional Selection Highlighters] subcomponent of your map in the Editor. Right-click it and select Add Highlighter. You can then configure your Highlighter using the dialog described below. Name: A short name for reference in the editor. Active if Properties Match: The highlighter will be drawn for all pieces on the map that match the given Property Match Expression. The expression can refer to Properties of the pieces to determine which ones are an appropriate match. Use Image: Specify an optional image to be overlaid on top of the selected piece. The center of the image will be offset from the center of the piece by the given number of pixels. Border Color: The color of the border to be drawn around selected pieces. Border thickness: The thickness of the border |
|
Flare
A Flare lets players their opponents' attention to something that has happened on the map by clicking a with certain modifier keys held down. The flare will be visible to other players both in online games and in play-by-email games using a log file.
A Flare component is automatically added to each Map, so you will not normally need to add more. However, to add a Flare to your map, find your [Map] component in the Editor, right-click it, and select Add Flare. See the full Flare article for more details. |