Dear forum users! In compliance with the new European GDPR regulations, we'd just like to inform you that if you have an account, your email address is stored in our database. We do not share your information with third parties, and your email address and password are encrypted for security reasons.

New to the forum? Say hello in this topic! Also make sure to read the rules.

Scripting 15 - Listening on player input

A smaller forum with a few tutorials how to get started with the ScriptAPI.
Forum rules
By using the forum you agree to the following rules.
Post Reply
User avatar
Gurt
Lead Programmer
Lead Programmer
Posts: 1884
Joined: Sun Feb 28, 2016 3:22 pm
Title: Lead programmer
Started SFD: Made it!
Location: Sweden
Gender:
Age: 34

Scripting 15 - Listening on player input

Post by Gurt » Tue Aug 06, 2019 3:52 pm

Scripting 15 - Listening on player input

Scripting in SFD assumes you have a fair knowledge of C#.

The following code demonstrates how to listen on player key input. Available in v.1.3.1b.

Code: Select all

// Example script to listen on player key input
public void OnStartup()
{
	// This registers key input from players as long as the players exist in the game. This will register input from dead and disabled players too (but not removed players)!
	Events.PlayerKeyInputCallback.Start(OnPlayerKeyInput);
}

public void OnPlayerKeyInput(IPlayer player, VirtualKeyInfo[] keyEvents) 
{
	
	for (int i = 0; i < keyEvents.Length; i ++) 
	{
		Game.WriteToConsole(string.Format("Player {0} keyevent: {1}", player.UniqueID, keyEvents[i].ToString()));
		
		// Spawn a chair at the player if the player pressed the block button while holding WALK
		if (keyEvents[i].Event == VirtualKeyEvent.Pressed && keyEvents[i].Key == VirtualKey.BLOCK && player.KeyPressed(VirtualKey.WALKING)) 
		{
			Game.CreateObject("Chair00", player.GetWorldPosition(), 0f, Vector2.Zero, 0f, player.FacingDirection);
		}
		
		// Example code to move a tile named "ABC" around by 8 units using the movement keys from any player:
		if (keyEvents[i].Event == VirtualKeyEvent.Pressed) 
		{
			Vector2 posChange = Vector2.Zero;
			switch (keyEvents[i].Key) 
			{
				case VirtualKey.AIM_RUN_RIGHT: posChange = Vector2.UnitX; break;
				case VirtualKey.AIM_RUN_LEFT: posChange = -Vector2.UnitX; break;
				case VirtualKey.AIM_CLIMB_UP: posChange = Vector2.UnitY; break;
				case VirtualKey.AIM_CLIMB_DOWN: posChange = -Vector2.UnitY; break;
			}
			if (posChange != Vector2.Zero) 
			{
				IObject obj = Game.GetObject("ABC");
				if (obj != null) {
					obj.SetWorldPosition(obj.GetWorldPosition() + posChange * 8f);
				}
			}
		}
	}
}
To listen on key input you must have a player instance to listen to (a technical limitation from the very first Pre-Alpha of the game).
If you don't care about the player you could set input mode to ReadOnly for the player and disable the nametags and move the player outside the camera area.

Code: Select all

	foreach(IPlayer plr in Game.GetPlayers()) 
	{
		//plr.SetInputMode(PlayerInputMode.ReadOnly);
		//plr.SetNametagVisible(false);
	}
You can also check pressed keys yourself using the IPlayer.KeyPressed(..) function without using Events.PlayerKeyInputCallback depending on your needs.

Code: Select all

	IPlayer plr = ...
	
	if (plr.KeyPressed(VirtualKey.SPRINT)) 
	{
		...
	}
	

Note: You can only read the pressed player action key. You can NOT read which physical button was pressed (e.g. if it's a keyboard/gamepad or which button it is). So if you're doing any sort of text prompt always refer to the action (e.g. "Attack", "Kick", "Block") instead of the physical buttons ("A", "F", "P") which are different depending on the user's key bindings.


ScriptAPI implementation for key input:
► Show Spoiler
4 x
Gurt

Post Reply