Mercurial > repos > IBBoard.WarFoundry.GUI.GTK
view UIControl/Interfaces/IBaseEquipmentUI.cs @ 98:fac0636ae13b
Re #308: Make GTK# UI translatable
* Make undo/redo menus translate on language change
* Organise English language file
* Resolve warnings by adding in dialogs that use translated strings when equipment amounts are out of range
author | IBBoard <dev@ibboard.co.uk> |
---|---|
date | Sun, 02 Jan 2011 21:03:15 +0000 |
parents | 4b82515586ac |
children |
line wrap: on
line source
// This file (IBaseEquipmentUI.cs) is a part of the IBBoard.WarFoundry.GUI.GTK project and is copyright 2010 IBBoard // // The file and the library/program it is in are licensed and distributed, without warranty, under the GNU Affero GPL license, either version 3 of the License or (at your option) any later version. Please see COPYING for more information and the full license. using System; namespace IBBoard.WarFoundry.GUI.GTK.UIControl.Interfaces { /// <summary> /// The base interface that all "UI control" controlled interfaces implement. It provides common definitions for all classes /// </summary> public interface IBaseEquipmentUI : IDisposable { /// <summary> /// Occurs when the unit equipment amount type changes (e.g. percentage to numeric) /// </summary> event MethodInvoker UnitEquipmentAmountTypeChanged; /// <summary> /// Occurs when the unit equipment amount changes /// </summary> event MethodInvoker UnitEquipmentAmountChanged; /// <summary> /// Causes the UI to listen to its widgets and fire events /// </summary> void ListenToWidgets(); /// <summary> /// Causes the UI to ignore the widgets so that changes do not fire events /// </summary> void IgnoreWidgets(); /// <summary> /// Sets the limits for the currently selected equipment item /// </summary> /// <param name='isRatioLimit'> /// <code>True</code> if the current limit is a ratio limit, else <code>false</code> for absolute limits /// </param> /// <param name='minPercent'> /// The minimum limit as a percentage /// </param> /// <param name='maxPercent'> /// The maximum limit as a percentage /// </param> /// <param name='minNumber'> /// The minimum number as an absolute figure /// </param> /// <param name='maxNumber'> /// The maximum number as an absolute figure /// </param> void SetUnitEquipmentLimits(bool isRatioLimit, double minPercent, double maxPercent, int minNumber, int maxNumber); /// <summary> /// Sets whether the unit equipment limit UI components should be enabled and able to accept input. This will /// generally pass the values on to the <see cref="SetNumericAmountEnabledState(bool)"/> and /// <see cref="SetPercentageAmountEnabledState(bool)"/> methods and is included for convenience /// </summary> /// <param name='isEnabled'> /// <code>True</code> if the UI components should accept input, else <code>false</code> /// </param> void SetUnitEquipmentLimitsEnabled(bool isEnabled); /// <summary> /// Shows the control and awaits a user action (close or okay) /// </summary> /// <returns> /// <code>true</code> if the control was closed with "Okay", else <code>false</code> /// </returns> bool ShowControl(); /// <summary> /// Gets a value indicating whether the equipment amount is a ratio or an absolute number. /// </summary> /// <value> /// <c>true</c> if the selected amount is a ratio type (percentage or "all"); otherwise, <c>false</c>. /// </value> bool IsRatioEquipmentAmount { get; } /// <summary> /// Gets and sets the numeric amount for the current equipment amount. This number is meaningless if <see cref="IsRatioEquipmentAmount"/> is <code>true</code> /// </summary> /// <value> /// The absolue number of items taken. /// </value> int EquipmentNumericAmount { get; set; } /// <summary> /// Gets and sets the percentage amount for the current equipment amount. This number is meaningless if <see cref="IsRatioEquipmentAmount"/> is <code>false</code> /// </summary> /// <value> /// The number of items taken as a percentage of the unit size. /// </value> double EquipmentPercentageAmount { get; set; } /// <summary> /// Sets the state of the Okay button. /// </summary> /// <param name='enabled'> /// <code>true</code> to enable the button, else <code>false</code> /// </param> void SetOkayEnabledState(bool enabled); /// <summary> /// Sets the state of the numeric equipment amount control. /// </summary> /// <param name='enabled'> /// <code>true</code> to enable the control, else <code>false</code> /// </param> void SetNumericAmountEnabledState(bool enabled); /// <summary> /// Sets the state of the percentage equipment amount control. /// </summary> /// <param name='enabled'> /// <code>true</code> to enable the control, else <code>false</code> /// </param> void SetPercentageAmountEnabledState(bool enabled); } }