| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869 |
- using BansheeEngine;
- namespace BansheeEditor
- {
- /// <summary>
- /// Displays GUI for a serializable property containing a color. Color is displayed as a GUI color field that allows
- /// the user to manipulate the color using a color picker.
- /// </summary>
- public class InspectableColor : InspectableField
- {
- private Color propertyValue;
- private GUIColorField guiField;
- /// <summary>
- /// Creates a new inspectable color GUI for the specified property.
- /// </summary>
- /// <param name="title">Name of the property, or some other value to set as the title.</param>
- /// <param name="depth">Determines how deep within the inspector nesting hierarchy is this field. Some fields may
- /// contain other fields, in which case you should increase this value by one.</param>
- /// <param name="layout">Parent layout that all the field elements will be added to.</param>
- /// <param name="property">Serializable property referencing the array whose contents to display.</param>
- public InspectableColor(string title, int depth, InspectableFieldLayout layout, SerializableProperty property)
- : base(title, depth, layout, property)
- {
- }
- /// <inheritoc/>
- protected internal override void BuildGUI(int layoutIndex)
- {
- if (property.Type == SerializableProperty.FieldType.Color)
- {
- guiField = new GUIColorField(new GUIContent(title));
- guiField.OnChanged += OnFieldValueChanged;
- layout.AddElement(layoutIndex, guiField);
- }
- }
- /// <inheritdoc/>
- public override bool IsModified()
- {
- Color newPropertyValue = property.GetValue<Color>();
- if (propertyValue != newPropertyValue)
- return true;
-
- return base.IsModified();
- }
- /// <inheritdoc/>
- protected internal override void Update(int layoutIndex)
- {
- // TODO - Skip update if it currently has input focus so user can modify the value in peace
- propertyValue = property.GetValue<Color>();
- if (guiField != null)
- guiField.Value = propertyValue;
- }
- /// <summary>
- /// Triggered when the user selects a new color.
- /// </summary>
- /// <param name="newValue">New value of the color field.</param>
- private void OnFieldValueChanged(Color newValue)
- {
- property.SetValue(newValue);
- }
- }
- }
|