Alangara_PRC8/_module/nss/ke_randomwalk.nss
Jaysyn904 86feb9ca6f Initial commit
Initial commit.
2024-06-05 21:21:06 -04:00

94 lines
3.8 KiB
Plaintext

// On Heartbeat: Natural Random Walk script
//
// Every 6 seconds, on the heartbeat of a creature, this script has a
// 30% chance of running. If it activates, the creature will randomly
// walk to a location nearby (if the location is valid). You can easily
// change the chance to succeed by simply increasing or decreasing the
// value in the first "if" statement. By default it is at 3, meaning
// that it has a 30% chance of running what is below the "if". If you
// change it to 6, it would have a 60% chance of excuting the script.
//
// This is meant to take the place of ActionRandomWalk(); in many
// circumstances, such as when you want a creature or NPC to behave
// more naturally.
//
// With this in the heartbeat slot, 7 out of 10 times, any creature will
// wait an extra 6 seconds before walking again. Using statistics, ~50%
// of the time the creature will wait 18 seconds, and ~50% of the time,
// a creature will move on the first OR second heartbeat.
//
// Written by: Tyson McCann
// 07.16.03
//
void main()
{
int nValue = Random(10);
// Change the 3 below to a number from 1-10 to change the chance of
// firing. 3 = 30%, 6 = 60%, 1 = 10%, etc. Essentially if you want them to
// walk (or run) more often, set it to a higher number.
if (nValue < 3)
{
vector vCurrent = GetPosition(OBJECT_SELF);
float fOldX = vCurrent.x;
float fOldY = vCurrent.y;
float fOldZ = vCurrent.z;
// Change the max distance you want the creature to walk in meters below.
// Default = 7. There are 10 meters per square tile in NWN.
int nX = Random(7);
int nY = Random(7);
// nSign determines whether we will be subtracting or adding to X or Y.
int nSignX = Random(2);
int nSignY = Random(2);
float fNewX;
float fNewY;
float fNewZ = fOldZ; // since we're not changing Z
switch(nSignX)
{
case 0: // Add the random value to the X coordinate
fNewX = fOldX + IntToFloat(nX);
break;
case 1: // Subtract the random value from the X coordinate
fNewX = fOldX - IntToFloat(nX);
break;
}
switch(nSignY)
{
case 0: // Add the random value to the Y coordinate
fNewY = fOldY + IntToFloat(nY);
break;
case 1: // Subtract the random value from the Y coordinate
fNewY = fOldY - IntToFloat(nY);
break;
}
// now setting up all the required parameters for the new location
object oArea = GetArea(OBJECT_SELF);
vector vNew = Vector(fNewX, fNewY, fNewZ);
float fFacing = GetFacing(OBJECT_SELF);
location lNewSpot = Location(oArea, vNew, fFacing);
// and finally... if you prefer them to run, change FALSE to TRUE.
AssignCommand(OBJECT_SELF, ActionMoveToLocation(lNewSpot, FALSE));
// Now for some extra fun. If you want your creature to have a CHANCE
// of running to a location instead of walking, even if minutely,
// uncomment this section and RE-COMMENT the single line above.
// The default chance to run (and remember they won't be moving every 6
// seconds) is set to 7%. 7 times out of 100, when this script is
// activated they will run to the new random location, giving their
// movement an even greater sense of randomness. Whatever number you
// put in the "if" statement below, that will be their chance to run.
/*
int nRun = Random(100);
if (nRun < 7)
AssignCommand(OBJECT_SELF, ActionMoveToLocation(lNewSpot, TRUE));
else
AssignCommand(OBJECT_SELF, ActionMoveToLocation(lNewSpot, FALSE));
*/
}
}