public interface Player
Modifier and Type | Method and Description |
---|---|
void |
addGuiElement(GuiElement guiElement)
Attaches a GUI element to the player's hud.
|
void |
addGuiElement(GuiElement guiElement,
java.lang.String parent)
Attaches a GUI element to the player's screen.
|
void |
addWorldElement(WorldElement worldElement)
Adds the provided
WorldElement to the player's world. |
void |
ban(java.lang.String reason)
Bans the player permanently from the server.
|
void |
ban(java.lang.String reason,
int duration)
Bans the player from the server for a given amount of time.
|
void |
connectToDiscord(java.lang.String url)
Connects the client to a Discord server, or more precisely, it opens the
url to the Discord server in the web browser.
|
void |
connectToTeamSpeak(java.lang.String ip,
int port,
java.lang.String channel)
Connects the client to a TeamSpeak server, but only as long as TeamSpeak is
installed on the client computer, and only if the client accepts to connect.
|
void |
createScreenshot(float sizeFactor,
Callback<java.awt.image.BufferedImage> callback)
Creates a screenshot of the player screen and convert it into a BufferedImage.
|
void |
deleteAttribute(java.lang.String key)
Removes a player attribute.
|
void |
disableAreaSelectionTool()
Disables the "area selection tool" for this player.
|
void |
disableClientsideKeys(int... keys)
Disables certain keys for the client.
|
void |
disableGameMusic()
Disables the ingame music.
|
void |
enableAreaSelectionTool()
Enables the "area selection tool" for this player.
|
void |
enableClientsideKeys()
Re-enables all keys which have been disabled by calling
disableClientsideKeys(int...) . |
void |
enableClientsideKeys(int... keys)
Re-enables certain keys which have been disabled by calling
disableClientsideKeys(int...) . |
void |
enableGameMusic()
Enables the ingame music.
|
void |
executeConsoleCommand(java.lang.String command)
Executes a console command for this player.
|
java.util.List<WorldElement> |
getAllWorldElements() |
void |
getAreaSelectionData(Callback<Area> callback)
Gets the currently selected area.
|
int |
getArmor()
Gets the current armor level of the player.
|
java.lang.Object |
getAttribute(java.lang.String key)
Gets the value to which the specified key is mapped,
or null if no attribute is stored for that key.
|
Vector3i |
getBlockPosition()
Gets a Vector3i containing the current block position (x, y and z)
of the player within the current chunk.
|
java.lang.String |
getCardinalDirection()
Returns the cardinal direction of the player.
|
Vector3i |
getChunkPosition()
Gets a Vector3i containing the x, y and z coordinates of
the current chunk the player is in.
|
Clothes |
getClothes()
Gets a
Clothes object which contains the clothes the character
is currently wearing. |
java.util.List<Area> |
getCurrentAreas()
Gets a list of all Areas the player is currently in.
|
int |
getCurrentPlayTime()
Gets the amount of time the player is connected to the server.
|
int |
getDbID()
Gets the database ID of the player.
|
Item |
getEquippedItem()
Gets the currently equipped item (i.e. the item the player
currently holds in his hands), or null if no item is equipped.
|
float |
getHeading()
Returns the heading/facing, i.e. the player rotation around the y axis (vertical axis)
in radians.
|
int |
getHealth()
Gets the current health of the player.
|
int |
getHunger()
Gets the current hunger level of the player. 100 means the player is not
hungry, 0 means the player is starving (i.e. the player looses health).
|
int |
getID()
Gets the current ID of this player.
|
int |
getIdleTime()
Gets the player idle time in seconds.
|
Inventory |
getInventory()
Gets the inventory of the player.
|
java.lang.String |
getIP()
Gets the ip of the player (only relevant in multiplayer).
|
java.lang.String |
getLanguage()
Gets the current ingame language of the player.
|
long |
getLastTimeOnline()
Gets a timestamp (i.e. the number of milliseconds since 00:00:00 UTC on
January 1, 1970) when the player was online on this server most recently.
|
int |
getMaxArmor()
Gets the maximum armor level the player can have.
|
int |
getMaxHealth()
Gets the maximum health the player can have.
|
Npc |
getMount()
Gets the mount the player is currently riding on.
|
java.lang.String |
getName()
Gets the name of the player.
|
void |
getOption(java.lang.String setting,
Callback<java.lang.String> callback)
Gets a setting from the client (a setting from his config.properties file).
|
java.lang.String |
getPermissionGroup()
Gets the current permission group name of the player.
|
java.lang.Object |
getPermissionValue(java.lang.String key)
Gets a particular permission value (usually boolean, int, String) from the
current player permission.
|
int |
getPing()
Gets the current ping of the player, in other words, the amount of time
(in milliseconds) that passes until a player packet arrives at the server.
|
Vector3f |
getPosition()
Gets a Vector3f containing the current global x, y and z
coordinate of the player.
|
int[] |
getRegisteredKeys()
Gets all keys that are registered.
|
Vector3f |
getRespawnPosition()
Gets the estimated respawn position (i.e. the position the player will respawn
once he died [or once he gets respawned forcefully]).
|
Quaternion |
getRotation()
Gets the current player rotation.
|
int |
getScreenResolutionX()
Gets the current screen width (horizontal resolution) the player set for his game.
|
int |
getScreenResolutionY()
Gets the current screen height (vertical resolution) the player set for his game.
|
void |
getScreenToWorldPosition(float x,
float y,
boolean relativeposition,
Callback<Vector3f> callback)
Performs a raycast from the screen xy position.
|
Skin |
getSkin()
Gets a
Skin object which represents the appearance of the character,
i.e. gender, haircut, skin color, hair color etc. |
int |
getStamina()
Gets the player stamina. 0 means the player is fully exhausted (so the player
cannot sprint anymore), 100 is the max value.
|
java.lang.String |
getSystemLanguage()
Gets the current system language of the player.
|
int |
getTemperature()
Gets the current player temperature (in celsius).
|
int |
getThirst()
Gets the current thirst level of the player. 100 means the player is not
thirsty, 0 means the player is dying of dehydration
(i.e. the player looses health).
|
int |
getTotalPlayTime()
Gets the total amount of time the player has spent on this server (or more
precisely, the amount of time the player has spent on this world).
|
long |
getUID()
Gets the globally unique ID of the player.
|
Vector3f |
getViewDirection()
Gets the current view direction of the player.
|
int |
getWetness() |
boolean |
hasAttribute(java.lang.String key)
Gets whether or not the provided attribute exists.
|
boolean |
hasBrokenBones()
Gets whether the player has broken bones or not.
|
void |
hideInventory() |
void |
hideJournal()
Hides the journal.
|
void |
hideMap()
Hides the ingame map.
|
void |
hideStorage()
Hides the chest/storage content.
|
boolean |
isAdmin()
Gets wheter or not the player is an admin
(according to the server.properties file).
|
boolean |
isBleeding()
Gets whether the player is bleeding or not.
|
boolean |
isConnected()
Gets whether or not the player is (still) connected.
|
boolean |
isCreativeModeEnabled()
Gets whether or not creative mode is currently enabled.
|
boolean |
isCrouching()
Gets whether or not the player is currently crouching.
|
boolean |
isDead()
Gets whether or not the player is dead.
|
boolean |
isFishing()
Gets whether or not the player is currently fishing.
|
boolean |
isFlying()
Gets whether or not the player is currently flying (i.e. flymode enabled).
|
boolean |
isInCave()
Gets whether or not the player is inside a cave.
|
boolean |
isIndoor()
Gets whether or not the player is inside a building.
|
boolean |
isInLava()
Gets whether or not the player is currently in lava.
|
boolean |
isInVehicle()
Gets whether or not the player is currently inside a vehicle (either as driver
or passenger).
|
boolean |
isInvisible()
Gets whether or not the player is invisible (i.e. if a plugin has set the
player invisible).
|
boolean |
isInWater()
Gets whether or not the player is currently in water.
|
boolean |
isKeyRegistered(int key)
Checks if a particular key is already registered.
|
boolean |
isLaying()
Gets whether or not the player is currently laying in a bed, tent or shelter.
|
boolean |
isListeningForKeyInput()
Determines if the client does forward his key input to the server or not.
|
boolean |
isListeningForObjectInteractions()
Deprecated.
Method is no longer used. Now interactions of players with
objects (like furniture) are always forwarded to the server (and they are
also cancellable), so this method returns always true
|
boolean |
isPlayingPiano()
Gets whether or not the player is currently playing a piano.
|
boolean |
isSitting()
Gets whether or not the player is currently sitting on a chair.
|
boolean |
isSleeping()
Gets whether or not this player is currently sleeping.
|
boolean |
isSpawned()
Gets whether or not the player is already spawned, i.e. if he's no longer
in the loading screen.
|
boolean |
isSprinting() |
boolean |
isSteamVersion()
Gets whether or not the player uses the Steam version of the game.
|
boolean |
isUnderWater()
Gets whether or not the player is currently under water.
|
boolean |
isWalking() |
void |
kick(java.lang.String reason)
Kicks the player from the server.
|
void |
kill()
Kills the player instantly.
|
void |
moveTo(float x,
float y,
float z,
float speed)
Moves the player (smoothly) to the target position.
|
void |
moveTo(Vector3f position,
float speed)
Moves the player (smoothly) to the target position.
|
int |
playGameSound(java.lang.String name)
Plays an ingame sound effect at the position of the player which can only be
heard by this player.
|
int |
playGameSound(java.lang.String name,
Vector3f position)
Plays an ingame sound effect at the given world position which can only be
heard by this player.
|
int |
playGameSound(java.lang.String name,
Vector3f position,
java.lang.String parameter,
float parameterValue)
Plays an ingame sound effect at the given world position.
|
int |
playSound(SoundInformation sound)
Plays a custom 2D sound (i.e. it can be heard everywhere, but only by this player).
|
int |
playSound(SoundInformation sound,
boolean loop,
float volume,
float pitch,
float minDistance,
float maxDistance,
Vector3f position)
Plays a custom 3D sound at the given position.
|
int |
playSound(SoundInformation sound,
Vector3f position)
Plays a custom 3D sound at the given position.
|
void |
raycast(int collisionType,
Callback<RayCastResult> callback)
Performs a raycast from the player view position to the player view direction,
i.e. from the cam position to the center of the screen (crosshair).
|
void |
raycast(Vector3f direction,
int collisionType,
Callback<RayCastResult> callback)
Performs a raycast from the player view position to the provided direction.
|
void |
raycastFromScreenPosition(float x,
float y,
boolean relativeposition,
int collisionType,
Callback<RayCastResult> callback)
Performs a raycast from the screen xy position.
|
void |
raycastFromWorldPosition(Vector3f position,
Vector3f direction,
int collisionType,
Callback<RayCastResult> callback)
Performs a raycast from a world position.
|
void |
registerKeys(int... keys)
Defines the key inputs the client should forward to the server.
|
void |
removeAllGuiElements()
Removes all GUI elements that are attached to the player's hud.
|
void |
removeAllWorldElements()
Removes all
WorldElements from the player's world. |
void |
removeGuiElement(GuiElement guiElement)
Removes a GUI element from the player's hud.
|
void |
removeWorldElement(WorldElement worldElement)
Removes a
WorldElement from the player's world. |
void |
requestMapTileRaw(int x,
int y,
java.lang.String controlHash,
Callback<byte[]> callback)
Requests a raw map tile from a client.
|
void |
respawn()
Respawns the player.
|
void |
respawn(Vector3f position,
Quaternion rotation)
Respawns the player at the given position.
|
void |
sendTextMessage(java.lang.String message)
Sends a text message to the player's chat.
|
void |
sendYellMessage(java.lang.String message)
Displays a message with big letters in the middle of the screen of the player
for a few seconds (depending on the length of the message).
|
void |
setAdmin(boolean set)
Gives admin rights to the player.
|
void |
setAreaSelectionData(Area area)
Sets an area for the "area selection tool" for this player, i.e. the selection
tool will adapt to the position and size of the provided area.
|
void |
setAttribute(java.lang.String key,
java.lang.Object value)
Stores an attribute for the player.
|
void |
setBleeding(boolean set)
Sets the bleeding state of the player.
|
void |
setBrokenBones(boolean set)
Sets the broken bone state of the player.
|
void |
setChunkAndBlockPosition(int cx,
int cy,
int cz,
int bx,
int by,
int bz)
Sets the chunk and block position of the player (resulting
in the total global position).
|
void |
setChunkAndBlockPosition(Vector3i chunkPosition,
Vector3i blockPosition)
Sets the chunk and block position of the player (resulting
in the total global position).
|
void |
setCreativeModeEnabled(boolean set)
Enables or disables creative mode for this player.
|
void |
setEquippedItem(int quickslot)
Changes the equipped item (i.e. the item the player currently holds in his hands).
|
void |
setFlying(boolean set)
Sets the flymode for the player.
|
void |
setGravity(float gravity) |
void |
setGuiElementVisible(GuiElement element,
boolean visible)
Changes the visibility of the GUI element only for this player.
|
void |
setHealth(int health)
Sets the health of the player.
|
void |
setHunger(int hunger)
Sets the hunger level of the player. 100 means the player is not hungry,
0 means the player is starving (i.e. the player looses health).
|
void |
setInvisible(boolean set)
Sets the player invisible.
|
void |
setJumpSpeed(float jumpheight)
Sets the jump height for the player.
|
void |
setListenForKeyInput(boolean set)
Sets if the client should forward his key input to the server or not.
|
void |
setListenForObjectInteractions(boolean set)
Deprecated.
Method is no longer used. Now interactions of players with
objects (like furniture) are always forwarded to the server (and they are
also cancellable).
Calling this method has no effect. |
void |
setMouseCursorCoordinates(float x,
float y,
boolean relative)
Moves the mouse cursor of the client to the specified xy coordinates.
|
void |
setMouseCursorVisible(boolean set)
Toggles the visibility of the mouse cursor.
|
void |
setName(java.lang.String name)
Changes the name of the player.
|
void |
setOption(java.lang.String setting,
java.lang.Object value)
Sets the graphics/audio/game settings for the client.
|
void |
setPermissionGroup(java.lang.String groupName)
Sets the permission group of the player.
|
void |
setPermissionValue(java.lang.String key,
java.lang.Object value)
Overrides a permission value.
|
void |
setPosition(float x,
float y,
float z)
Sets the global position of the player.
|
void |
setPosition(Vector3f position)
Sets the global position of the player.
|
void |
setRotation(float pitch,
float yaw,
float roll)
Sets the player rotation from euler angles.
|
void |
setRotation(Quaternion quaternion)
Sets the player rotation.
|
void |
setRunSpeed(float speed)
Sets the running speed for the player, i.e. the default movement speed.
|
void |
setSoundPitch(int soundID,
float pitch)
Changes the pitch of a sound instance.
|
void |
setSoundPosition(int soundID,
Vector3f position)
Changes the position of a sound.
|
void |
setSoundTimelinePosition(int soundID,
float position,
boolean relative)
Changes the track position / timeline position of the sound.
|
void |
setSoundVolume(int soundID,
float volume)
Changes the volume of a sound instance.
|
void |
setSprintSpeed(float speed)
Sets the sprinting speed for the player, i.e. fast movement.
|
void |
setTemperature(int temperature)
Sets the player temperature (in celsius).
|
void |
setThirst(int thirst)
Sets the thirst level of the player. 100 means the player is not thirsty,
0 means the player is dying of dehydration (i.e. the player looses health).
|
void |
setViewDirection(float directionx,
float directiony,
float directionz)
Sets the view direction of the player.
|
void |
setViewDirection(Vector3f direction)
Sets the view direction of the player.
|
void |
setWalkSpeed(float speed)
Sets the walking speed for the player.
|
void |
setWetness(int wetness) |
void |
shake(float intensity,
float duration)
Shakes the player screen, like an earthquake.
|
void |
showContextMenu(java.lang.String[] entries,
Callback<java.lang.String> callback)
Shows a context menu with the given entries.
|
void |
showInventory() |
void |
showJournal()
Shows the journal.
|
void |
showMap(boolean ignoreMissingMapItem)
Brings up the ingame map.
|
void |
showMap(boolean ignoreMissingMapItem,
Vector3f coordinates,
boolean smoothScroll)
Brings up the ingame map.
|
void |
showStatusMessage(java.lang.String message,
int duration)
Shows a status text message (centered, bottom of the screen).
|
void |
showStorage(int storageID)
Shows the content of a chest/storage.
|
void |
stopInput(boolean stopMovement,
boolean stopActions)
Stops / aborts the current input actions.
|
void |
stopSound(int soundID)
Stops a sound effect.
|
void |
unregisterKeys(int... keys)
Unregisters a key (or multiple keys), so the client no longer forwards
the input to the server.
|
int getID()
long getUID()
int getDbID()
java.lang.String getName()
void setName(java.lang.String name)
name
- the new player name.long getLastTimeOnline()
int getCurrentPlayTime()
int getTotalPlayTime()
java.lang.String getPermissionGroup()
void setPermissionGroup(java.lang.String groupName)
groupName
- the group name. Set null to remove the player from any
permission group.java.lang.Object getPermissionValue(java.lang.String key)
key
- the name of the particular permission key.void setPermissionValue(java.lang.String key, java.lang.Object value)
key
- the permission key.value
- the value.boolean isAdmin()
void setAdmin(boolean set)
set
- set true to give admin rights to the player, or false to revoke
admin rights.Inventory getInventory()
Item getEquippedItem()
void setEquippedItem(int quickslot)
quickslot
- the quickslot focus (hotbar) which holds the desired item.void sendTextMessage(java.lang.String message)
[#RRGGBB]
, RR
is the hex red color, GG
the hex green color, BB
the hex blue color) in the string to
color a specific part of the text (or the whole text).message
- the message you want to send to the player.void sendYellMessage(java.lang.String message)
message
- the message you want to display on the player's screen.void showStatusMessage(java.lang.String message, int duration)
message
- the message you want to show.duration
- the duration (seconds) how long the message will be displayed.void setOption(java.lang.String setting, java.lang.Object value)
setting
- the name of the setting (see config.properties
file).value
- the new value. Set null
to reset this setting to default.void getOption(java.lang.String setting, Callback<java.lang.String> callback)
setting
- the setting you want to query, e.g. "input_interaction" or "graphic_fullscreen" etc.callback
- the Callback
object. It will be called once the data
has been retrieved from the player. The result will be passed as a string argument
(empty string if setting is not set, null if setting does not exist).void setAttribute(java.lang.String key, java.lang.Object value)
key
- the name of the attribute.value
- the value/object you want to store. Set null to remove the attribute.java.lang.Object getAttribute(java.lang.String key)
key
- the name of the attribute.boolean hasAttribute(java.lang.String key)
key
- the name of the attribute.void deleteAttribute(java.lang.String key)
key
- the name of the attribute you want to delete.Vector3f getPosition()
void setPosition(Vector3f position)
position
- A Vector3f (float) containing the global target position.void setPosition(float x, float y, float z)
x
- global x coordinate to set (horizontally).y
- global y coordinate to set (vertically).z
- global z coordinate to set (horizontally).void moveTo(Vector3f position, float speed)
position
- the target position.speed
- the speed (how long it should take to move the player to the
target position).void moveTo(float x, float y, float z, float speed)
x
- the target x coordinate.y
- the target y coordinate.z
- the target z coordinate.speed
- the speed (how long it should take to move the player to the
target position).Vector3i getChunkPosition()
Vector3i getBlockPosition()
void setChunkAndBlockPosition(Vector3i chunkPosition, Vector3i blockPosition)
chunkPosition
- chunk offset as a Vector3i (int).blockPosition
- block position within the chunk as a Vector3i (int).void setChunkAndBlockPosition(int cx, int cy, int cz, int bx, int by, int bz)
cx
- x chunk offset.cy
- y chunk offset.cz
- z chunk offset.bx
- x block position within the chunk.by
- y block position within the chunk.bz
- z block position within the chunk.Quaternion getRotation()
void setRotation(Quaternion quaternion)
quaternion
- the quaternion which describes the desired rotation.void setRotation(float pitch, float yaw, float roll)
pitch
- the rotation around the x axis (left axis).yaw
- the rotation around the y axis (vertical/up axis), "heading".roll
- the rotation around the z axis (forward axis)Vector3f getViewDirection()
void setViewDirection(Vector3f direction)
direction
- the new view direction as a Vector3f (float). Make sure to
use a unit vector.void setViewDirection(float directionx, float directiony, float directionz)
directionx
- y component of the new view direction vector.directiony
- y component of the new view direction vector.directionz
- z component of the new view direction vector.float getHeading()
java.lang.String getCardinalDirection()
java.util.List<Area> getCurrentAreas()
Area
,
PlayerEnterAreaEvent
,
PlayerLeaveAreaEvent
void shake(float intensity, float duration)
intensity
- the intensity (default: 1.0f)duration
- the duration, in seconds.boolean isSpawned()
boolean isFishing()
boolean isInVehicle()
boolean isSprinting()
boolean isWalking()
boolean isCrouching()
boolean isLaying()
boolean isSitting()
boolean isPlayingPiano()
boolean isInWater()
boolean isUnderWater()
boolean isInLava()
boolean isIndoor()
boolean isInCave()
boolean isSleeping()
void setCreativeModeEnabled(boolean set)
set
- set true to enable creative mode, false to disable it.boolean isCreativeModeEnabled()
int getHealth()
int getMaxHealth()
void setHealth(int health)
health
- the new player health.int getArmor()
int getMaxArmor()
int getHunger()
void setHunger(int hunger)
hunger
- the new hunger level (0-100).int getThirst()
void setThirst(int thirst)
thirst
- the new thirst level.boolean hasBrokenBones()
void setBrokenBones(boolean set)
set
- set true to break the bones of the player, or false to
heal the broken bones.boolean isBleeding()
void setBleeding(boolean set)
set
- set true if the player should be bleeding, or false to stop
bleeding.int getStamina()
int getWetness()
void setWetness(int wetness)
boolean isFlying()
void setFlying(boolean set)
set
- true to enable flymode, false if not (be careful when the player
is currently in mid-air :D)boolean isDead()
void kill()
void respawn()
void respawn(Vector3f position, Quaternion rotation)
position
- the respawn position. You can get the default player spawnrotation
- the respawn rotation. Use "null" if you want to use the
default rotation.Vector3f getRespawnPosition()
int getTemperature()
void setTemperature(int temperature)
temperature
- the player temperature (in celsius). Value must be between
-100 and 100 (inclusive).boolean isInvisible()
void setInvisible(boolean set)
set
- true to set the player invisible, false to make him visible again.int getIdleTime()
Npc getMount()
Npc.getRider()
java.lang.String getLanguage()
java.lang.String getSystemLanguage()
boolean isSteamVersion()
void setWalkSpeed(float speed)
speed
- the new walking speed.void setRunSpeed(float speed)
speed
- the new running speed.void setSprintSpeed(float speed)
speed
- the new sprinting speed.void setJumpSpeed(float jumpheight)
jumpheight
- the new jump height.void setGravity(float gravity)
Skin getSkin()
Skin
object which represents the appearance of the character,
i.e. gender, haircut, skin color, hair color etc.Skin
object representing the visual appearance of the character.Clothes getClothes()
Clothes
object which contains the clothes the character
is currently wearing. The object is updated automatically when the player
changes his clothes.Clothes
object representing the clothes of the character.void showMap(boolean ignoreMissingMapItem)
ignoreMissingMapItem
- true if the map should show up independent of
whether or not a map item exists in the player equipment slots, false if it
should only show up if the player actually has a map item.showMap(boolean, net.risingworld.api.utils.Vector3f, boolean)
,
hideMap()
void showMap(boolean ignoreMissingMapItem, Vector3f coordinates, boolean smoothScroll)
ignoreMissingMapItem
- true if the map should show up independent of
whether or not a map item exists in the player equipment slots, false if it
should only show up if the player actually has a map item.coordinates
- the map will scroll to this position automatically. Set null
to scroll the map to the current player position.smoothScroll
- true to scroll the map smoothly to the target coordinates,
false to update the map position instantly.showMap(boolean)
,
hideMap()
void hideMap()
void showJournal()
void hideJournal()
void showInventory()
void hideInventory()
void showStorage(int storageID)
storageID
- the storage IDvoid hideStorage()
void showContextMenu(java.lang.String[] entries, Callback<java.lang.String> callback)
entries
- the entries of the context menu, as a string array.callback
- the callback which will be called once the player selects an entry.
The selected entry is provided as parameter (never null). If the player just closes
the context menu (i.e. if he doesn't select anything), an empty string will be provided.void stopInput(boolean stopMovement, boolean stopActions)
stopMovement
- true if you want to stop movement input (e.g. WASD). If causes
the character to stop (if he's currently moving).stopActions
- true if you want to stop interaction input, e.g. primary and
secondary mouse buttons and interaction key (F by default).void registerKeys(int... keys)
keys
- all key codes the game should listen for.KeyInput
void unregisterKeys(int... keys)
keys
- the key codes you want to unregisterKeyInput
boolean isKeyRegistered(int key)
key
- the key you want to check if it's registered.KeyInput
int[] getRegisteredKeys()
KeyInput
void setListenForKeyInput(boolean set)
set
- true to forward the key inputs, false if not.boolean isListeningForKeyInput()
void disableClientsideKeys(int... keys)
enableClientsideKeys()
.
Note: If a plugin registered a key (see registerKeys(int...)
,
these key inputs won't be processed client side, but they will still be
forwarded to the plugin.registerKeys(int...)
or setListenForKeyInput(boolean)
keys
- the keys you want to disable.KeyInput
void enableClientsideKeys()
disableClientsideKeys(int...)
.registerKeys(int...)
or setListenForKeyInput(boolean)
void enableClientsideKeys(int... keys)
disableClientsideKeys(int...)
. If you want to enable all keys
again, call enableClientsideKeys()
instead.registerKeys(int...)
or setListenForKeyInput(boolean)
keys
- the keys you want to enable again.KeyInput
void setMouseCursorVisible(boolean set)
set
- true to show the mouse cursor, false to hide it.void setMouseCursorCoordinates(float x, float y, boolean relative)
x
- the x target coordinatey
- the y target coordinaterelative
- if set to true, relative target coordinates (0.0-1.0) will be
used, otherwise the target coordinates will be treated as absolute coordinates.void executeConsoleCommand(java.lang.String command)
command
- the command you want to execute. It's exactly the same as if
the player typed this command into his console (he even get a response in the console).boolean isConnected()
int getPing()
java.lang.String getIP()
void kick(java.lang.String reason)
reason
- a string containing the reason why the player was kicked.void ban(java.lang.String reason)
reason
- a string containing the reason why the player was banned.void ban(java.lang.String reason, int duration)
reason
- a string containing the reason why the player was banned.duration
- the duration (in minutes) how long the player will be banned. Use
'-1' to ban the player permanently.void enableAreaSelectionTool()
disableAreaSelectionTool()
. If you want to retrieve the
selection result (i.e. the selected area), you can call
getAreaSelectionData(net.risingworld.api.callbacks.Callback)
and
provide a proper Callback
object.
getAreaSelectionData(net.risingworld.api.callbacks.Callback)
,
disableAreaSelectionTool()
void setAreaSelectionData(Area area)
enableAreaSelectionTool()
)area
- the area you want to adapt the selected area to. Provide null
to reset the selected area (this means the player has to set a new
start and end position).void getAreaSelectionData(Callback<Area> callback)
Area
if the "area selection tool" is currently enabled and if a start and end
position is selected. Otherwise, null is returned.Callback
.callback
- the Callback
object. It will be called once the
Area
object has been retrieved from the player. The particular
Area
will be passed as argument (or null if no area was selected).enableAreaSelectionTool()
,
disableAreaSelectionTool()
void disableAreaSelectionTool()
Area
by calling
getAreaSelectionData(net.risingworld.api.callbacks.Callback)
first,
otherwise the selected area will be discarded.void setListenForObjectInteractions(boolean set)
set
- N/Aboolean isListeningForObjectInteractions()
void getScreenToWorldPosition(float x, float y, boolean relativeposition, Callback<Vector3f> callback)
raycastFromScreenPosition(float, float, boolean, int, net.risingworld.api.callbacks.Callback)
,
with the exception that it returns a Vector3f
(the collision point) instead of
a RayCastResult
.Callback
.x
- the horizontal screen position (x).y
- the vertical screen position (y).relativeposition
- set to false to use absolute screen coordinates (i.e. pixel
coordinates), or true to use relative screen coordinates (range between 0.0 and 1.0)callback
- the Callback
object. It will be called once the
Vector3f
object has been retrieved from the player. The particular
Vector3f
will be passed as argument (or null if no collision was
found, for example when the player looks towards the sky etc).void raycast(int collisionType, Callback<RayCastResult> callback)
Callback
.collisionType
- the collision type (bitmask). This value specifies which collidables
should be taken into account when performing the raycast. See CollisionType
callback
- the Callback
object. It will be called once the
RayCastResult
object has been retrieved from the player. The particular
RayCastResult
will be passed as argument (or null if no collision was
found, for example when the player looks towards the sky etc).raycast(net.risingworld.api.utils.Vector3f, int, net.risingworld.api.callbacks.Callback)
,
raycastFromScreenPosition(float, float, boolean, int, net.risingworld.api.callbacks.Callback)
,
raycastFromWorldPosition(net.risingworld.api.utils.Vector3f, net.risingworld.api.utils.Vector3f, int, net.risingworld.api.callbacks.Callback)
void raycast(Vector3f direction, int collisionType, Callback<RayCastResult> callback)
Callback
.direction
- the direction of the ray. If you want to use the player view direction, you can
call raycast(int, net.risingworld.api.callbacks.Callback)
instead.collisionType
- the collision type (bitmask). This value specifies which collidables
should be taken into account when performing the raycast. See CollisionType
callback
- the Callback
object. It will be called once the
RayCastResult
object has been retrieved from the player. The particular
RayCastResult
will be passed as argument (or null if no collision was
found, for example when the player looks towards the sky etc).raycast(int, net.risingworld.api.callbacks.Callback)
,
raycastFromScreenPosition(float, float, boolean, int, net.risingworld.api.callbacks.Callback)
,
raycastFromWorldPosition(net.risingworld.api.utils.Vector3f, net.risingworld.api.utils.Vector3f, int, net.risingworld.api.callbacks.Callback)
void raycastFromScreenPosition(float x, float y, boolean relativeposition, int collisionType, Callback<RayCastResult> callback)
Callback
.x
- the horizontal screen position (x).y
- the vertical screen position (y).relativeposition
- set to false to use absolute screen coordinates (i.e. pixel
coordinates), or true to use relative screen coordinates (range between 0.0 and 1.0)collisionType
- the collision type (bitmask). This value specifies which collidables
should be taken into account when performing the raycast. See CollisionType
callback
- the Callback
object. It will be called once the
RayCastResult
object has been retrieved from the player. The particular
RayCastResult
will be passed as argument (or null if no collision was
found, for example when the player looks towards the sky etc).void raycastFromWorldPosition(Vector3f position, Vector3f direction, int collisionType, Callback<RayCastResult> callback)
Callback
.position
- the origin of the ray, i.e. where the world position you want to start the ray from.direction
- the direction of the ray.collisionType
- the collision type (bitmask). This value specifies which collidables
should be taken into account when performing the raycast. See CollisionType
callback
- the Callback
object. It will be called once the
RayCastResult
object has been retrieved from the player. The particular
RayCastResult
will be passed as argument (or null if no collision was
found, for example when the player looks towards the sky etc).void addGuiElement(GuiElement guiElement)
guiElement
- the GUI element you want to attach.void addGuiElement(GuiElement guiElement, java.lang.String parent)
guiElement
- the GUI element you want to attach.parent
- the parent GUI element, or more precisely, the element where
you want to attach this element to. Has no effect if this element is a child.
Example parent names: "Inventory", "Crafting", "HudLayer", "LoadingLayer",
"InGameMenu", "Crosshair", "Journal" etc.void removeGuiElement(GuiElement guiElement)
guiElement
- the GUI element you want to remove.void removeAllGuiElements()
void setGuiElementVisible(GuiElement element, boolean visible)
GuiElement.setVisible(boolean)
). However, changes to the GUI
element itself will restore the original visibility value of the GUI element.addGuiElement(net.risingworld.api.gui.GuiElement)
element
- the GUI element.visible
- true to show the GUI element, false to hide it.int getScreenResolutionX()
int getScreenResolutionY()
void addWorldElement(WorldElement worldElement)
WorldElement
to the player's world. Only the
player can see this object.worldElement
- The WorldElement
you want to add to the
player's world.void removeWorldElement(WorldElement worldElement)
WorldElement
from the player's world. If the specified
element does not exist in the player's world, nothing happens.worldElement
- the WorldElement
you want to remove.void removeAllWorldElements()
WorldElements
from the player's world.java.util.List<WorldElement> getAllWorldElements()
int playSound(SoundInformation sound)
sound
- the SoundInformation object which refers to the custom sound file.int playSound(SoundInformation sound, Vector3f position)
sound
- the SoundInformation object which refers to the custom sound file.position
- the world position of the sound. Provide null
if you want to
play this sound as a 2D sound instead (this means the sound has no actual position and
can be heard everywhere).int playSound(SoundInformation sound, boolean loop, float volume, float pitch, float minDistance, float maxDistance, Vector3f position)
sound
- the SoundInformation object which refers to the custom sound file.loop
- determines if this sound should play as a loop (i.e. it repeats indefinitely).
If true, the sound will only stop when calling stopSound(int)
.volume
- the sound volume (default: 1.0)pitch
- the sound pitch (default: 1.0)minDistance
- the distance that the sound emitter will cease to continue growing louder
at (the further you move to the center of the sound). Within the minimum distance, the sound
stays at the constant loudest possible volume (default: 1.0)maxDistance
- the distance the sound becomes silent. The sound volume is interpolated
between minDistance and maxDistance (default: 50.0). Sound uses a linear-square-rolloff
(minDistance == full volume, maxDistance == silence).position
- the world position of the sound. Provide null
if you want to
play a 2D sound instead (this means the sound has no actual position and
can be heard everywhere).int playGameSound(java.lang.String name)
gui_click // Clicking sound in GUI
message // Incoming private chat message
trade_success // Sound when trading was successful
item_switch //Switching the equipped item
warning_proximity //Warning sound when too close to a block
piano_1, piano_2, ... piano_61 //Piano sounds
name
- the name of the sound effect.playGameSound(java.lang.String, net.risingworld.api.utils.Vector3f)
int playGameSound(java.lang.String name, Vector3f position)
name
- the name of the sound effect.position
- the world position where the sound will be played.playGameSound(java.lang.String)
int playGameSound(java.lang.String name, Vector3f position, java.lang.String parameter, float parameterValue)
name
- the name of the sound effect.position
- the world position where the sound will be played.parameter
- an optional sound parameter that can be set. Set null if
you don't want to provide an parameter. Note that only certain sounds have parameters.parameterValue
- the parameter value (has no effect if parameter
is set to null).playGameSound(java.lang.String)
void stopSound(int soundID)
soundID
- the internal ID of the sound instance you want to stop.void setSoundPosition(int soundID, Vector3f position)
soundID
- the internal ID of the sound instance.position
- the new world position.void setSoundVolume(int soundID, float volume)
soundID
- the internal ID of the sound instance.volume
- the new sound volume (default: 1.0)void setSoundPitch(int soundID, float pitch)
soundID
- the internal ID of the sound instance.pitch
- the new sound pitch (default: 1.0)void setSoundTimelinePosition(int soundID, float position, boolean relative)
soundID
- the internal ID of the sound instance.position
- the new timeline position in seconds. If "relative" is true,
use a value between 0 and 1.relative
- false to use absolute values (seconds), true to use a value
relative to the total length of the sound (0-1).void enableGameMusic()
disableGameMusic()
has been called previously.void disableGameMusic()
enableGameMusic()
was called.
This does not affect the main theme (which can be heared only in main menu and during the loading screen).void connectToTeamSpeak(java.lang.String ip, int port, java.lang.String channel)
ip
- the target ip address of the TeamSpeak server.port
- the target port of the TeamSpeak server.channel
- the target channel the client should join on connect. To join
a subchannel, you have to use a slash (e.g. "channel/subchannel"
).void connectToDiscord(java.lang.String url)
url
- the url to the Discord server, for example "https://discord.gg/ay21koSP"
or "https://discordapp.com/invite/example" etc.void createScreenshot(float sizeFactor, Callback<java.awt.image.BufferedImage> callback)
sizeFactor
- the size factor of the image (1.0f is original width/height, 0.5f is half widht/height etc).callback
- this callback will be called once the screenshot has been
uploaded to the server. The screenshot is passed as BufferedImage obejct.
Uploading the screenshot may take a few seconds depending on the bandwidth, traffic and screenshot size.void requestMapTileRaw(int x, int y, java.lang.String controlHash, Callback<byte[]> callback)
Utils.ByteUtils#decompress(byte[])
).
The bytes represent an 8 bit RGBA image.[2|2] [1|2] [0|2] [-1|2] [-2|2]
[2|1] [1|1] [0|1] [-1|1] [-2|1]
[2|0] [1|0] [0|0] [-1|0] [-2|0]
[2|-1] [1|-1] [0|-1] [-1|-1] [-2|-1]
[2|-2] [1|-2] [0|-2] [-1|-2] [-2|-2]
Utils.ImageUtils#rawMapTileToBufferedImage(byte[])
after decompressing the array.x
- the x coordinate of the map tile (horizontal, from right to left).y
- the y coordinate of the map tile (vertical).controlHash
- optional md5 control hash. Compares the client side byte[] with
this hash and only transfers the bytes to the server if the hash does not match.
Provide null to disable this check.callback
- this callback will be called once the map tile data has been uploaded
to the server. The map tile data will be passed as raw byte array. If the map tile
does not exist (i.e. if this part of the map hasn't been explored by the player yet),
null is passed instead. Same happens if a controlHash
is set and
the client side hash matches the server side hash.