_________ __                 __
        /   _____//  |_____________ _/  |______     ____  __ __  ______
        \_____  \\   __\_  __ \__  \\   __\__  \   / ___\|  |  \/  ___/
        /        \|  |  |  | \// __ \|  |  / __ \_/ /_/  >  |  /\___ \
       /_______  /|__|  |__|  (____  /__| (____  /\___  /|____//____  >
               \/                  \/          \//_____/            \/
    ______________________                           ______________________
                          T H E   W A R   B E G I N S
           Stratagus - A free fantasy real time strategy game engine
Stratagus Configuration Language Description: User Interface (UI)
Stratagus
FAQ
PREV
NEXT
LUA Index
DefineButton
DefineButtonStyle
DefineCheckboxStyle
DefineCursor
DefineMenu
DefineMenuGraphics
DefineMenuItem
DefinePanelContents
DefineUI
DefineViewports
SetGameCursor
Icon Frame
Intro - Introduction to UI functions and variables
Everything around the user interface.
Functions
DefineButton({tag1 = value1, tag2 value2, ...})
Define a button in the button panel show during the game. Possible tags:
- Pos = number
- Position number.
0 1 2
3 4 5
6 7 8
 
- Level = number
- Visible when in this button level (0 default, 9 cancel-only)
- Icon = "icon-name"
- Name of the icon to display.
- Action = "action"
- Action to perform when the button is clicked.  Can be any of the following:
  - "move"
- The unit moves to location
- "stop"
- the unit stops. Orders queue is also erased. The unit wait for order but can react by itself.
- "attack"
- The unit attacks target. if target is a unit then it attacks only the unit.
If target is a position, it will move to location by attacking any opponent on the way.
- "repair"
- The unit will repair the target unit.
- "harvest"
- The unit will harvest the ressources.
- "button"
- FIXME. Need Value = number.
- "build"
- The unit will build the unit (building structure)
- "train-unit"
- The unit trains an unit. Generally use for building to create news units.
Need Value = "unit-name".
- "patrol"
- The unit patrol between target position and current position and attack any opponent
on the way.
- "stand-ground"
- The unit doesn't move. The unit stay at its location until it receives a new order.
- "attack-ground"
- The unit attack a location. Usefull for unit with spalsh damage.
- "return-goods"
- The unit with ressources return goods.
- "cast-spell"
- The unit cast a spell.
Need Value = "spell-name"
- "research"
- launch the research of an upgrade. Usefull to add technology.
Need Value = "upgrade-name"
- "upgrade-to"
- The unit will be trasform in an other unit (like polyporm spell).
Need Value = "Unit".
  
- "unload"
- The unit unload unit inside of itself. Usefull for transporter or bunkers.
- "cancel"
- FIXME : difference between cancels.
- "cancel-upgrade"
- FIXME
- "cancel-train-unit"
- FIXME
- "cancel-build"
- FIXME
 
- Value = arg
- Optional value associated with the action.
- Allowed = "check-name"
- Optional check to see if a button is allowed. Can be any of the following:
  
  - "check-true"
- No restriction on this button.
- "check-false"
- this button is forbidden. FIXME : ? to be removed. What is its usage ?
- "check-upgrade"
- This button can be clicked only when a specific upgrade is searched.
  Need Allowarg = {"upgrade-name"}
- "check-units-or"
- this button is available if at least one of the unit are available.
  Need AllowArg = {"unit-name1", "unit-name2"}
- "check-units-and"
- FIXME
- "check-network"
- Button is available only if network is available too.
- "check-no-network"
- Button is available only if network is not available.
- "check-no-work"
- FIXME
- "check-no-research"
- this button is available if the unit is not researching (upgrade-to or upgrade research).
- "check-attack"
- FIXME
- "check-upgrade-to"
- FIXME. No arg
- "check-research"
- FIXME
- "check-single-research"
- FIXME. No arg
 
- AllowArg = {"arg1", ...}
- Optional argument used by the allowed function.
- Key = "char"
- Shortcut key for the button. (FE "c" for key 'c' or "\27" for Escape)
- Hint = "string"
- Hint to be displayed for the button.
- ForUnit = {"unit-name1", ...} or {"*"} 
- List of units the button applies to, or {"*"} for all units.
Example
DefineButton( { Pos = 8, Level = 0, Icon = "icon-build-advanced",
  Action = "button", Value = 2,
  Allowed = "check-units-or", AllowArg = {"unit-elven-lumber-mill", "unit-keep"},
  Key = "v", Hint = "BUILD AD~!VANCED STRUCTURE",
  ForUnit = {"unit-peasant"} } )
DefineButtonStyle(style, {tag = value, ...})
Define a button style. Possible tags:
- Size = {x, y}
- Size of the button.
- Font = font-name
- Name of the font to use.
- TextNormalColor = color, TextReverseColor = color
- Color to use for the normal and reverse text.
- TextAlign = align
- Align the text.  Possible values are "Left", "Right", and "Center".
- TextPos = {posx, posy}
- Set the position of the text relative to the upper left corner of the image.
- Default = {tag = value, ...}, Hover = {}, Selected = {}, Clicked = {}, Disabled = {}
- Set attributes for when the mouse is over the button (Hover), the button is
Selected, Clicked, Disabled, or the Default setting. Possible tags:
  
  - File = file
- The filename.
  
- Size = size
- The size of the image (only needed when using an image with multiple frames).
  
- Frame = frame
- Select the frame number from an image (only needed when using an image with multiple frames).
  
- TextNormalColor = color, TextReverseColor = color
- Color to use for the normal and reverse text (overrides the main colors).
  
- TextPos = {x, y}
- Display the text at this position (overrides the main position).
  
- Border = { Color = color, Size = size}
- Draw a border with the specified color and size, with the border flashing
  
 
- Border = { SolidColor = color, Size = size}
- Draw a border with the specified color and size, without any flashing of the border
  
Example
DefineButtonStyle("main", {
  Size = {128, 20},
  Font = "game",
  TextNormalColor = "yellow",
  TextReverseColor = "white",
  TextAlign = "Center",
  TextPos = {64, 4},
  Default = {
    File = "ui/buttons_1.png", Size = {300, 144}, Frame = 4,
  },
  Hover = {
    TextNormalColor = "white",
  },
  Selected = {
    Border = {
      Color = {252, 252, 0}, Size = 1,
    },
  },
  Clicked = {
    File = "ui/buttons_1.png", Size = {300, 144}, Frame = 5,
    TextNormalColor = "white",
    TextPos = {66, 6},
  },
  Disabled = {
    File = "ui/buttons_1.png", Size = {300, 144}, Frame = 3,
    TextNormalColor = "grey",
    TextReverseColor = "grey",
  },
})
DefineCheckboxStyle(style, {tag = value, ...})
Define a checkbox style. Possible tags:
- Size = {x, y}
- Size of the button.
- Font = font-name
- Name of the font to use.
- TextNormalColor = color, TextReverseColor = color
- Color to use for the normal and reverse text.
- TextAlign = align
- Align the text.  Possible values are "Left", "Right", and "Center".
- TextPos = {posx, posy}
- Set the position of the text relative to the upper left corner of the image.
- Default = {tag = value, ...}, Hover = {}, Selected = {}, Clicked = {}, Disabled = {},
Checked = {}, CheckedHover = {}, CheckedSelected = {}, CheckedClicked = {}, CheckedDisabled = {}
- Set attributes for when the mouse is over the checkbox (Hover), the
checkbox is Selected, Clicked, Disabled, the Default setting, and for when the
checkbox is Checked. Possible tags:
  
  - File = file
- The filename.
  
- Size = size
- The size of the image (only needed when using an image with multiple frames).
  
- Frame = frame
- Select the frame number from an image (only needed when using an image with multiple frames).
  
- TextNormalColor = color, TextReverseColor = color
- Color to use for the normal and reverse text (overrides the main colors).
  
- TextPos = {x, y}
- Display the text at this position (overrides the main position).
  
- Border = { Color = color, Size = size}
- Draw a border with the specified color and size.
  
 
Example
DefineCheckboxStyle("round", {
  Size = {19, 19},
  Font = "game",
  TextNormalColor = "yellow",
  TextReverseColor = "white",
  TextAlign = "Left",
  TextPos = {24, 4},
  Default = {
    File = "ui/buttons_1.png", Size = {300, 144}, Frame = 19,
  },
  Hover = {
    TextNormalColor = "white",
  },
  Selected = {
    Border = {
      Color = {252, 252, 0}, Size = 1,
    },
  },
  Disabled = {
    File = "ui/buttons_1.png", Size = {300, 144}, Frame = 18,
  },
  Clicked = {
    File = "ui/buttons_1.png", Size = {300, 144}, Frame = 20,
    TextNormalColor = "white",
  },
  Checked = {
    File = "ui/buttons_1.png", Size = {300, 144}, Frame = 21,
  },
  CheckedHover = {
    TextNormalColor = "white",
  },
  CheckedSelected = {
    Border = {
      Color = {252, 252, 0}, Size = 1,
    },
  },
  CheckedClicked = {
    File = "ui/buttons_1.png", Size = {300, 144}, Frame = 22,
    TextNormalColor = "white",
  },
  CheckedDisabled = {
    File = "ui/buttons_1.png", Size = {300, 144}, Frame = 18,
  },
})
DefineCursor({tag = value, ...})
Define a cursor.
- Name = "ident"
- Unique identifier of the cursor, used to reference it in config files and
during startup.
- Race = "race-name" or "any"
- Race to use this cursor with or "any" to use with any race.
Possible tags:
- File = "icon-file"
- Path to the image graphic.
- HotSpot = {x, y}
- Hot spot of the cursor in pixels. Relative to the sprite origin {0, 0}. The
hot spot of a cursor is the point to which Stratagus refers in tracking the
cursor's position.
- Size = {width, height}
- Size of the cursor in pixels.
- Rate = millisecond
- Rate of changing the frames if using an animated cursor. The "rate" tells
the engine how many milliseconds to hold each frame of the animation.
Note: Name, File and Size must be filled.Example
DefineCursor({
  Name = "cursor-cross",
  Race = "any",
  File = "ui/cursors/small_green_cross.png",
  HotSpot = {8,  8},
  Size = {18, 18}})
DefineMenu("tag1", value1, ...)
FIXME: incomplete docu
Possible tags:
- "geometry", {x, y, width, height}
- Position and size of the menu.
- "name", "menu-name"
- Name of this menu.
- "panel", "panel-name" or "none"
- Panel name (FIXME: how is it used?).
- "default", number
- Initial selected item number
- "init", "function_name"
- FIXME (function = "save-replay-init" or "scen-select-init" ? )
- "exit", "function_name"
- FIXME ("speed-options-exit" or "load-game-exit" ? )
- "netaction", "menu-action"
- FIXME: which are menu-action ?
  - "terminate-net-connect"
- FIXME
Example
-- menu-sound-options
DefineMenu("name", "menu-sound-options", "geometry", {224, 64, 352, 352},
  "panel", "panel5", "default", 23)
DefineMenuGraphics({{"tag", value, ...}, ...})
Define the menu graphics for each of the races.
FIXME : 1st graph is the 1st race ? ... Explain better
- "file", "filename"
- Path to the file containing the menu graphics.
- "size", {width, height}
- Width and height of an image in the menu graphic.
Example
DefineMenuGraphics({
  {"file", "ui/buttons_1.png", "size", {300, 144}},
  {"file", "ui/buttons_2.png", "size", {300, 144}}})
DefineMenuItem("tag1", value1, ...)
Add an item to a menu. This could be any item, it depends
on the tags used.
FIXME: incomplete docu
- "pos", {x, y}
- position of menuitem (FIXME abolute, or relative to something ?)
- "menu", "menu-name"
- Menu this item belongs to.
- "transparent"
- FIXME. No value
- "flags", {"value",...}
- FIXME
  
  - "active"
- FIXME
- "clicked"
- FIXME
- "selected"
- FIXME
- "disabled"
- FIXME
 
- "font", "font-name"
- Use "game", "small", "large", "small-title", "large-title",
"user1", "user2", "user3", "user4", "user5"
- type, {arg_type}
- type could be :
  - "text", {values, ...}
- The item is a text label.
 The value is a list of tags, allowed tags:
    - "align", "left" or "right" or "center"
- aligns text respectively at left, right or center.
- "caption", "text"
- The text.
- "func", "function-name"
- C handler. FIXME: when called?
- "color-normal", "color-name"
- FIXME.
- "color-reverse", "color-name"
- FIXME.
 
For example:
   "text", {"caption", "Connecting to server",
            "align", "center"}
  - "button" = {values, ...}
- The item is a button.
 The value is a list of tags like:
    - "caption", "text"
- The text.
- "color-normal", "color-name"
- FIXME.
- "color-reverse", "color-name"
- FIXME.
- "hotkey", "key"
- A string like "f8". FIXME
- "func", "function-name" or Lua function
- Called when a button is clicked
- "style", style-name
- Complete list of possible styles-name:
     FIXME (not all for buttons)
    
      - "main"
- FIXME
- "network"
- FIXME
- "gm-half"
- FIXME
- "132"
- FIXME
- "gm-full"
- FIXME
- "gem-round"
- FIXME
- "gem-square"
- FIXME
- "up-arrow"
- FIXME
- "down-arrow"
- FIXME
- "left-arrow"
- FIXME
- "right-arrow"
- FIXME
- "s-knob"
- FIXME
- "s-vcont"
- FIXME
- "s-hcont"
- FIXME
- "pulldown"
- FIXME
- "vthin"
- FIXME
- "folder"
- FIXME
- "sc-gem-round"
- FIXME
- "sc-gem-square"
- FIXME
- "sc-up-arrow"
- FIXME
- "sc-down-arrow"
- FIXME
- "sc-left-arrow"
- FIXME
- "sc-right-arrow"
- FIXME
- "sc-s-knob"
- FIXME
- "sc-s-vcont"
- FIXME
- "sc-s-hcont"
- FIXME
- "sc-pulldown"
- FIXME
- "sc-button-left"
- FIXME
- "sc-button"
- FIXME
- "sc-button-right"
- FIXME
 FIXME: describe them
 
Example.
    "button", {"size",  {224, 27},
               "caption", "~!Surrender",
               "hotkey", "s",
               "func", "surrender-confirm-menu"
               "style", "gm-full"}
  - "pulldown"
- The item is a pulldown menu.
  
    - "size" = (width, height)
- Dimensions.
- "options", {"string1", "string2", ...}
- A list of strings to select from.
- "color-normal", "color-name"
- FIXME.
- "color-reverse", "color-name"
- FIXME.
- "func", function-name
- C handler. FIXME: when called?
- "state", "passive"
- FIXME
- "default", number
- An integer for the default selection id, starting with 0.
- "current", number
- An integer for the current selection id, starting with 0.
- "style" = style-name
- see above. FIXME which are available ?
 
Example:
    "pulldown", {"size", {152, 20},
                 "style", "pulldown",
                 "func", "null",
                 "options", {"Forest", "Winter", "Wasteland", "Orc Swamp"},
                 "default, 0, -- "Forest"
                 "current", 0} -- "Forest"
  - "listbox"
- The item is a list box.
 Allowed tags:
    - "size" = (width, height)
- Dimensions.
- "func", function-name
- C handler. FIXME: when called?
- "handler", function-name
- C handler. FIXME: when is it called?
- "retopt", function-name
- C handler to retrieve the list of options, I guess. FIXME
- "startline", number
- For scrolling, I guess. Probably only used in savegames. FIXME
- "nlines", number
- Number of lines.
- "default", number
- An integer for the default selection id, starting with 0.
- "current", number
- An integer for the current selection id, starting with 0.
- "style" = style-name
- see above. FIXME which are available ?
- "color-normal", "color-name"
- FIXME.
- "color-reverse", "color-name"
- FIXME.
 
Example:
    "listbox", {"size", {288, 108},
                "style", "pulldown",
                "func", "scen-select-lb-action",
                "retopt", "scen-select-lb-retrieve",
                "handler", "scen-select-ok",
                "nlines", 6}
  - "vslider" or "hslider", {values}
- The item is a vertical (or horizontal) slider.
 Allowed tags: size default current style (see above) and:
    - "size" = (width, height)
- Dimensions.
- "func", function-name
- C handler. FIXME: when called?
- "handler", function-name
- C handler. FIXME: when is it called?
- "flags", "up" or "down" or "left" or "right" or "knob" or "cont"
- FIXME: never seen this used.
- "default", number
- An integer for the default selection id, starting with 0.
- "current", number
- An integer for the current selection id, starting with 0.
- "style" = style-name
- see above. FIXME which are available ?
 Examples:
  "vslider", {"size", {18, 108},
              "func", "editor-main-load-vs-action",
              "handler", "editor-main-load-ok"}
  "hslider", {"size", {198, 18},
              "func", "master-volume-hs-action",
              "handler", "scen-select-ok"}
- "drawfunc", function-name
- The item is drawn from a C function.
 Example:
    DefineMenuItem("pos", {0, 0}, "font", "game", "init", "game-setup-init",
      "drawfunc", "game-draw-func",
      "menu" "menu-custom-game")
FIXME.
- "input"
- The item is a text input field.
 Allowed tags: size func style color-normal color-reverse (see above)
and:
    - "size" = (width, height)
- Dimensions.
- "func", function-name
- C handler, seems to be called when a key is pressed
    and just checks whether it is RETURN.
    
- "style" = style-name
- see above. FIXME which are available ?
- "color-normal", "color-name"
- FIXME.
- "color-reverse", "color-name"
- FIXME.
- "maxch", number
- Maximal number of characters. FIXME: never seen this used.
 
Example:
    "input", {"size", {212, 20},
      "func", "enter-master-action",
      "style", "pulldown"}
  - "gem"
- The item is a gem.
 Allowed tags: size func style text color-normal color-reverse (see
above) and:
    - "size" = (width, height)
- Dimensions.
- "func", function-name
- C handler. FIXME: when called?
- "state", "checked" or "unchecked" or "passive" or "invisible"
- FIXME.
- "style" = style-name
- see above. FIXME which are available ?
- "text", "text"
- The text.
- "color-normal", "color-name"
- FIXME.
- "color-reverse", "color-name"
- FIXME.
- "maxch", number
- Maximal number of characters. FIXME: never seen this used.
 
Example:
  "gem", {"size", {18, 18},
          "text", "640 x 480",
          "state", "unchecked",
          "func", "global-options-resolution-gem",
          "style", "gem-round"}
  
Example
    DefineMenuItem("pos", {16, 288 - 40}, "font", "large",
                   "button", {"size", {224, 27},
                              "caption", "Return to Game (~)",
                              "hotkey", "esc",
                              "func", "game-menu-return",
                              "style", "gm-full"},
                   "menu", "menu-game")
DefinePanelContents({flag = value}, ...)
Define panel content when an unit is selected.
  - Ident = "name"
- identifier of the panel.
- Pos = {x, y}- 
  
- position of the panel. The other coordonate are relative to this point.
- DefaultFont = "font-name"- 
  
- Default font used in content if not redefined.
- Condition = {flag = value}
- condition to show the panel.
  
    - ShowOnlySelected = Boolean
- if true, show only if unit is selected (not just pointed).
- HideNeutral = Boolean
- if true, hide for neutral units.
- HideAllied = Boolean
- if true, hide for allied units.
- ShowOpponent = Boolean
- if true, show for opponent units.
- Variable = "only", "false", "true"- 
    
- For variables defined by DefineVariables(), show info if unit correpond with the criteria- 
    
- Flag = "only", "false", "true"- 
    
- For flags defined by DefineBoolFlags(), show info if unit correpond with the criteria- 
  
 
- Contents = {flag = value}
- The info to show, and the method associated.
  
    - Pos = {x, y}
- Coordinate to show element. (relatif to Panel' coordinates)
- Condition = {flag = value}
- Extra condition for content itself. Identic as Panel's condition
- More = {"method-name", ExtraData}
- Tell the method to show informations.
    
      - "Text", "texttodisplay" or {flag = value}
- Show simple text "texttodisplay" and after one optional variable.
      
        - Text = StringDesc
- text to display (See StringDesc in Trigger).
- Font = "font-name"
- font to use.
- Centered = boolean
- if true then text is centered on the position.
- Variable = "variable-name"
- Variable name to show. See DefineVariable() for more details.
- Component = "Name" or "Value" or "Max" or "Increase" or "Diff" or "Percent"
- component of value to show. Diff represent Max - value and Percent represent 100 * Value / Max.
- ShowName = boolean
- if true show the name of the unit and no variable information.
- Stat = boolean
- if true and value != Original value, then show original value + diff else show value.
		Original value is default value with no upgrade.
		
 
- "FormatedText", {flag = value, ...}
- Show text with a given format.
      
        - Format = "texttodisplay"
- format of the text. Must have 1 %d (for number)or %s (for string). Use ~< ~> for reverse mode.
- Font = "font-name"
- font to use.
- Variable = "variable-name"
- Variable name to show. See DefineVariable() for more details.
- Component = "Name" or "Value" or "Max" or "Increase" or "Diff" or "Percent"
- component of value to show. Diff represent Max - value and Percent represent 100 * Value / Max.
- Centered = boolean
- if true then text is centered on the position.
 
- "FormatedText2", {flag = value, ...}
- Similar of FormatedText but with 2 variables.
      
        - Format = "texttodisplay"
- format of the text. Must have 2 %d (for number)or %s (for string). Use ~< ~> for reverse mode.
- Font = "font-name"
- font to use.
- Variable1 = "variable-name"
- 1st Variable name to show. See DefineVariable() for more details.
- Variable2 = "variable-name"
- 2nd Variable name to show. See DefineVariable() for more details.
- Variable = "variable-name"
- Variable name to show(Assume var1 == var2). See DefineVariable() for more details.
- Component1 = "Name" or "Value" or "Max" or "Increase" or "Diff" or "Percent"
- component of the 1st value to show. Diff represent Max - value and Percent represent 100 * Value / Max.
- Component2 = "Name" or "Value" or "Max" or "Increase" or "Diff" or "Percent"
- component of 2nd value to show. Diff represent Max - value and Percent represent 100 * Value / Max.
- Component = "Name" or "Value" or "Max" or "Increase" or "Diff" or "Percent"
- Assume that component1 == component2.
- Centered = boolean
- if true then text is centered on the position.
 
- "Icon", {flag = value, ...}
- Draw the icon of a specified unit.
      
        - Unit = "ItSelf" or "Inside" or "Container" or "Worker" or "Goal"
- which unit to draw : itself or first unit inside or its container
            or the unit which is building it or the goal objective.
 
- "LifeBar", {flag = value, ...}
- Draw a bar which represent the variable. Change color depend of the percent.
      
        - Variable = "variable-name"
- Variable name to show. See DefineVariable() for more details.
- Height = value
- Height of the bar.
- Width = value
- width of the bar.
- Border = boolean
- if true then add a border to the bar. Default is true.
- Colors = list
- A list of {percentage, color-name} pairs. The default is equivalent
          to {{75, "dark-green"}, {50, "yellow"}, {25, "orange"}, {0,
          "red"}}. The last element must start with "0". The meaning of the
          number is the percentage above which the associated color takes
          effect.
        
 
- "CompleteBar", {flag = value, ...}
- Draw a bar which represent the variable.
      
        - Variable = "variable-name"
- Variable name to show. See DefineVariable() for more details.
- Height = value
- Height of the bar.
- Width = value
- width of the bar.
- Border = boolean
- if true then add border for the bar.
 
 
 
DefineUI("race-name", screen-width, screen-height, tag1, value1, tag2, value2, ...)
- "race-name"
- FIXME
- screen-width, screen-height
- FIXME
All of those tags should be given:
- "normal-font-color", "color-name"
- FIXME
- "reverse-font-color", "color-name"
- FIXME
- "filler", {tag, value, ...}
- FIXME:
  - "file", "path"
- FIXME
- "pos", {x, y}
- FIXME
 
- "resource-line", {"file-name", x, y}
- 
FIXME
  - "file-name"
- FIXME
- x, y
- FIXME
 
- "resources", {"ressource-name", {tag, value, ...}, ...}
- 
  - "ressource-name" or "food" or "score"
- FIXME
 FIXME
  - "file", "file-name"
- FIXME
- "frame", number
- FIXME
- "pos", {x, y}
- FIXME
- "size", {width, height}
- FIXME
- "text-pos", {x, y}
- FIXME
 
- "info-panel", {tag, value, ...}
- 
  - "panel", {tag, value}
- FIXME
  
    - "file", "file-name"
- FIXME
- "pos", {x, y}
- FIXME
- "size", {width, height}
- FIXME
 
- "panels", "panel-ident" or {"panel-ident1", ...}
- Panel ident to show when unit is selected. (see DefinePanels() for more details)
- "selected", {tag, value}
- FIXME
  
    - "single", {tag, value}
- FIXME
    
      - "text", {tag, value}
- FIXME
- "icon", {tag, value}
- FIXME
 
- "multiple", {tag, value}
- FIXME
    
      - "icons", {{tag, value}, ...}
- FIXME, see above (icon)
- "max-text", {tag, value}
- FIXME, see above (text)
 
 
- "training", {tag, value}
- FIXME
  
    - "single", {tag, value}
- FIXME
    
      - "icon", {tag, value}
- FIXME
 
- "multiple", {tag, value}
- FIXME
    
      - "text", {tag, value}
- FIXME
- "icons", {{tag, value}, ...}
- FIXME, see above (icon)
 
 
- "upgrading", {tag, value}
- FIXME
  
    - "icon", {tag, value}
- FIXME
 
- "researching", {tag, value}
- FIXME
  
    - "icon", {tag, value}
- FIXME
 
- "transporting", {tag, value}
- FIXME
  
    - "icons", {{tag, value}, ...}
- FIXME, see above (icon)
 
- "completed-bar", {tag, value}
- FIXME
  
    - "color", {r, g, b}
- FIXME
- "has-shadow"
- FIXME
 
 
- "button-panel", {tag, value, ...}
- 
  - "panel", {tag, value, ...}
- FIXME
  
    - "file", "filename"
- FIXME
- "pos", {x, y}
- FIXME
 
- "icon", {tag, value, ...}
- FIXME
  
    - FIXME
- FIXME
 
 
- "pie-menu", {tag, value, ...}
- 
  - "radius", radius
- The radius in pixels of the pie menu.
- "file", "filename"
- The image file for the background of the pie menu.
- "mouse-button", "buttonname"
- Which mouse button pops up the pie menu. Can be "right", "middle" or "left".
  
 
- "map-area", {"pos", {x, y}, size, {w, h}}
- FIXME
- "menu-panel", {tag, value}
- FIXME
  - "panel", {tag, value, ...}
- FIXME
  
    - "file", "filename"
- FIXME
- "pos", {x, y}
- FIXME
 
- type-menu-button, {tag, value, ...}
- type-menu-button is one of the following :
  
    - "menu-button"
- FIXME
- "network-menu-button"
- FIXME
- "network-diplomacy-button"
- FIXME
 
 And tag and value :
    - "caption" , "text"
- FIXME
- "pos", {x, y}
- FIXME
- "style", "style-name"
- FIXME, see above
 
 
- "minimap", {tag, value}
- 
There is a minimap panel an the minimap on it. The panel graphic has
certain palette restrictions (FIXME: exactly? probably the same as the
tileset?).
  - "file", filename
- FIXME
- "panel-pos", {x, y}
- FIXME
- "pos", {x, y}
- Pos is the absoloute position of the minimap on the screen
  (the upper left corner of it).
  
- "size", {w, h}
- FIXME
- "transparent"
- If you give "transparent", the panel
  graphic will be displayed on unexplored terrain, black otherwise.
  
 
- "status-line", {tag, value}
- FIXME
  - "file", "file-name"
- FIXME
- "pos", {x, y}
- FIXME
- "text-pos", {x, y}
- FIXME
- "font", "font-name"
- FIXME
 
- "cursors", {tag, name}
- FIXME
  - "point", "name"
- FIXME
- "glass", "name"
- FIXME
- "cross", "name"
- FIXME
- "yellow", "name"
- FIXME
- "green", "name"
- FIXME
- "red", "name"
- FIXME
- "scroll", "name"
- FIXME
- "arrow-e" or "arrow-ne" or "arrow-n" or "arrow-nw" or "arrow-w" or "arrow-sw" or "arrow-s" or "arrow-se", "name"
- FIXME
 
- "menu-panels", {"panel-name1", "file1", ...}
- FIXME: this really needs docu or change, if you dig out the
requirement of the pictures, write them down here. Example:
- "victory-background", "file-name"
- Background image for the victory screen. The image will be scaled.
- "defeat-background", "file-name"
- Background image for the victory screen. The image will be scaled.
DefineViewports("mode", mode, "viewport", {mapx, mapy}, ...)
Define the viewports. Only used in savegames, but could be useful for
scenarios.
- "mode", number
- Number corresponding to the viewport mode.  See the ViewportMode enum. FIXME
- "viewport", {mapx, mapy}
- X, Y coordinate of the map tile.
Example
-- Defines the viewports to use mode 1 (split horizontal) with the first
-- viewport having map coordinates 82,31 and the second having coordinates 64,31.
DefineViewports("mode", 1, "viewport", {82, 31},
                           "viewport", {64, 31})
SetGameCursor("cursor-ident")
Set the game cursor.
- "cursor-ident"
- Unique identifier of the cursor.
Example
-- Set the game cursor to 'cursor-point'.
SetGameCursor("cursor-point")
Icon Frame
Set a custom frame to be drawn around icons. Note that "IconsShift" has to be true.
Example
Preference.IconsShift = true
Preference.IconFrameG = CGraphic:New("ui/" .. race .. "/icon_border.png", 62, 48)
Preference.PressedIconFrameG = CGraphic:New("ui/" .. race .. "/icon_border.png", 62, 48)
(C) Copyright 2002-2015 by The Stratagus Project under the GNU General Public License.
All trademarks and copyrights on this page are owned by their respective owners.