Split text input into its own event.

This commit is contained in:
Paul Chote
2013-10-30 17:40:12 +13:00
parent ae8475620d
commit d1c9c6d76d
5 changed files with 49 additions and 18 deletions

View File

@@ -19,6 +19,7 @@ namespace OpenRA
void ModifierKeys(Modifiers mods);
void OnKeyInput(KeyInput input);
void OnMouseInput(MouseInput input);
void OnTextInput(string text);
}
public enum MouseInputEvent { Down, Move, Up }

View File

@@ -17,6 +17,7 @@ namespace OpenRA
// ignore all input
public void ModifierKeys(Modifiers mods) { }
public void OnKeyInput(KeyInput input) { }
public void OnTextInput(string text) { }
public void OnMouseInput(MouseInput input) { }
}
@@ -38,6 +39,11 @@ namespace OpenRA
Sync.CheckSyncUnchanged(world, () => Ui.HandleKeyPress(input));
}
public void OnTextInput(string text)
{
Sync.CheckSyncUnchanged(world, () => Ui.HandleTextInput(text));
}
public void OnMouseInput(MouseInput input)
{
Sync.CheckSyncUnchanged(world, () => Ui.HandleInput(input));

View File

@@ -154,27 +154,24 @@ namespace OpenRA.Widgets
return true;
}
TypeChar(e);
return true;
}
public void TypeChar(KeyInput key)
{
if (key.Key == Keycode.BACKSPACE && CursorPosition > 0)
if (e.Key == Keycode.BACKSPACE && CursorPosition > 0)
{
CursorPosition--;
Text = Text.Remove(CursorPosition, 1);
}
else if (key.IsValidInput())
return true;
}
public override bool HandleTextInput(string text)
{
if (MaxLength > 0 && Text.Length >= MaxLength)
return;
Text = Text.Insert(CursorPosition, key.UnicodeChar.ToString());
return true;
Text = Text.Insert(CursorPosition, text);
CursorPosition++;
}
return true;
}
protected int blinkCycle = 10;

View File

@@ -104,9 +104,15 @@ namespace OpenRA.Widgets
if (KeyboardFocusWidget != null)
return KeyboardFocusWidget.HandleKeyPressOuter(e);
if (Root.HandleKeyPressOuter(e))
return true;
return false;
return Root.HandleKeyPressOuter(e);
}
public static bool HandleTextInput(string text)
{
if (KeyboardFocusWidget != null)
return KeyboardFocusWidget.HandleTextInputOuter(text);
return Root.HandleTextInputOuter(text);
}
public static void ResetAll()
@@ -334,12 +340,30 @@ namespace OpenRA.Widgets
if (child.HandleKeyPressOuter(e))
return true;
// Do any widgety behavior (enter text etc)
// Do any widgety behavior
var handled = HandleKeyPress(e);
return handled;
}
public virtual bool HandleTextInput(string text) { return false; }
public virtual bool HandleTextInputOuter(string text)
{
if (!IsVisible())
return false;
// Can any of our children handle this?
foreach (var child in Children.OfType<Widget>().Reverse())
if (child.HandleTextInputOuter(text))
return true;
// Do any widgety behavior (enter text etc)
var handled = HandleTextInput(text);
return handled;
}
public virtual void Draw() {}
public virtual void DrawOuter()

View File

@@ -130,6 +130,9 @@ namespace OpenRA.Renderer.SdlCommon
else
inputHandler.OnKeyInput(keyEvent);
if (keyEvent.IsValidInput())
inputHandler.OnTextInput(keyEvent.UnicodeChar.ToString());
break;
}
}