Commit message (Collapse) | Author | Age | Files | Lines | |
---|---|---|---|---|---|
* | instead of setting avatar rotation twice in SP.HandleAgentUpdate(), ↵ | Justin Clark-Casey (justincc) | 2011-08-11 | 1 | -16/+14 |
| | | | | eliminate the second setting in AddNewMovement() | ||||
* | get rid of intermediate local store of body rotation in ScenePresence, this ↵ | Justin Clark-Casey (justincc) | 2011-08-11 | 1 | -5/+4 |
| | | | | is not used. | ||||
* | Get NPCs to revert to the correct 'resting' animation (e.g. stand or hover) ↵ | Justin Clark-Casey (justincc) | 2011-08-11 | 2 | -2/+14 |
| | | | | | | after finishing their movement. This also fixes judder after an avatar has finished "go here"/autopilot movement in a viewer. This meant reseting the SP.AgentControlFlags since the Animator uses these to determine the correct default animation. | ||||
* | If SP.MoveToTarget has been called with a force walk, begin by landing the ↵ | Justin Clark-Casey (justincc) | 2011-08-11 | 1 | -1/+3 |
| | | | | | | avatar. There is a bug here - once an avatar has landed it glides to its new position instead of performing a walk animation | ||||
* | Add a OS_NPC_LAND_AT_TARGET option to osMoveToTarget() | Justin Clark-Casey (justincc) | 2011-08-10 | 1 | -1/+4 |
| | | | | | | | Default for this function is now not to automatically land. This allows better control by scripts when an avatar is going to be landing on a prim rather than the ground. Stopping the avatar involves faking a collision, to avoid the pid controller making it overshoot. A better approach would be to gradually slow the avatar as we near the target | ||||
* | early code to allow scripts to force npcs not to fly when moving to target | Justin Clark-Casey (justincc) | 2011-08-10 | 3 | -4/+13 |
| | | | | | this is to allow walking on prims. it will be up to the script writer to be sure that there is a continuous path. currently implemented in osNpcMoveToTarget(), but none of this is final. | ||||
* | Stop trying to deregister caps or close child agents when an NPC is removed | Justin Clark-Casey (justincc) | 2011-08-10 | 3 | -22/+11 |
| | |||||
* | implement osNpcStopMoveTo() to cancel any current move target | Justin Clark-Casey (justincc) | 2011-08-10 | 1 | -4/+15 |
| | |||||
* | When an NPC is created, stop telling neighbouring regions to expect a child ↵ | Justin Clark-Casey (justincc) | 2011-08-09 | 1 | -4/+8 |
| | | | | agent | ||||
* | Implement first draft functions for saving and loading NPC appearance from ↵ | Justin Clark-Casey (justincc) | 2011-08-09 | 2 | -1/+26 |
| | | | | | | | | | | storage. This works by serializing and deserializing NPC AvatarAppearance to a notecard in the prim inventory and making the required baked textures permanent. By using notecards, we avoid lots of awkward, technical and user-unfriendly issues concerning retaining asset references and creating a new asset type. Notecards also allow different appearances to be swapped and manipulated easily. This also allows stored NPC appearances to work transparently with OARs/IARs since the UUID scan will pick up and store the necessary references from the notecard text. This works in my basic test but is not at all ready for user use or bug reporting yet. | ||||
* | get rid of bogus log message | Justin Clark-Casey (justincc) | 2011-08-06 | 1 | -7/+0 |
| | |||||
* | remove some obsolete tests that are now done elsewhere | Justin Clark-Casey (justincc) | 2011-08-06 | 1 | -53/+53 |
| | |||||
* | Add a test to check that ScenePresence and circuit go away when a root agent ↵ | Justin Clark-Casey (justincc) | 2011-08-06 | 1 | -10/+17 |
| | | | | is closed down | ||||
* | refactor: Change SceneHelpers.AddClient() to AddScenePresence(). | Justin Clark-Casey (justincc) | 2011-08-06 | 6 | -37/+47 |
| | | | | This seems to make more sense as we can get SP.ControllingClient | ||||
* | rip out sog generation methods in ScenePresenceAgentTests and use ↵ | Justin Clark-Casey (justincc) | 2011-08-06 | 2 | -38/+8 |
| | | | | | | | SceneHelpers instead Not that it matters, since these tests are pretty bogus anyway. Also, renames some test classes for consistency. | ||||
* | Do proper locking of m_localScenes list in SceneManager | Justin Clark-Casey (justincc) | 2011-08-06 | 1 | -93/+140 |
| | |||||
* | rename TestHelper => TestHelpers for consistency | Justin Clark-Casey (justincc) | 2011-08-06 | 16 | -41/+41 |
| | |||||
* | rename test SceneSetupHelpers -> SceneHelpers for consistency | Justin Clark-Casey (justincc) | 2011-08-06 | 15 | -65/+65 |
| | |||||
* | extend phantom flag regression test to toggle back off | Justin Clark-Casey (justincc) | 2011-08-06 | 2 | -0/+7 |
| | |||||
* | refactor: Fold most SOP.ScriptSet* methods back into script code. Simplify. | Justin Clark-Casey (justincc) | 2011-08-06 | 2 | -27/+2 |
| | |||||
* | Add regression test for setting phantom status on a scene object. This is ↵ | Justin Clark-Casey (justincc) | 2011-08-05 | 3 | -13/+78 |
| | | | | not yet complete. | ||||
* | remove the largely unused copy/pasted HandleAgentRequestSit() method | Justin Clark-Casey (justincc) | 2011-08-05 | 1 | -40/+11 |
| | |||||
* | if an NPC target is set to a ground location, then automatically land them ↵ | Justin Clark-Casey (justincc) | 2011-08-04 | 1 | -5/+4 |
| | | | | | | when they get there. This doesn't help where the target is a prim surface. In these situations, it might be better to provide manual overrides so the script can control whethre an avatar flys there/lands, etc. | ||||
* | if an NPC move to target is above the terrain then make it fly to destination | Justin Clark-Casey (justincc) | 2011-08-04 | 1 | -7/+19 |
| | |||||
* | if a move to target is set underground, constrain it to the terrain height | Justin Clark-Casey (justincc) | 2011-08-04 | 1 | -1/+3 |
| | |||||
* | move bAllowUpdateMoveToPosition switch outside of HandleMoveToTargetUpdate() | Justin Clark-Casey (justincc) | 2011-08-04 | 1 | -8/+5 |
| | |||||
* | only call move target code in SP.HandleAgentUpdate() if we're actually in ↵ | Justin Clark-Casey (justincc) | 2011-08-04 | 1 | -9/+12 |
| | | | | the process of moving to a position | ||||
* | move reset code out of HandleMoveToTargetUpdate() so that we only call it ↵ | Justin Clark-Casey (justincc) | 2011-08-04 | 1 | -16/+12 |
| | | | | where needed instead of passing in a flag | ||||
* | Make SIGNIFICANT_MOVEMENT SP constant a top-level property so that other ↵ | Justin Clark-Casey (justincc) | 2011-08-04 | 1 | -5/+7 |
| | | | | classes can use it. | ||||
* | When the NPC reaches within the SIGNIFICANT_CLIENT_MOVEMENT distance of the ↵ | Justin Clark-Casey (justincc) | 2011-08-04 | 1 | -1/+2 |
| | | | | | | | target, move it directly to the target. This makes the movement exact. Regression test changed to check avatar reaches exact target. Also has the nice side effect of making NPC animations continue to work after the first movement (which wasn't working). However, avatar still pauses in mid-stride | ||||
* | extend npc move test to check a second movement | Justin Clark-Casey (justincc) | 2011-08-04 | 1 | -1/+1 |
| | |||||
* | eliminate pre-existing unused SP.StopMovement() | Justin Clark-Casey (justincc) | 2011-08-04 | 1 | -8/+1 |
| | |||||
* | Rename HandleMoveToPositionUpdate() to HandleMoveToTargetUpdate() for ↵ | Justin Clark-Casey (justincc) | 2011-08-04 | 1 | -6/+6 |
| | | | | consistency. Improve method doc. | ||||
* | eliminate a reset position flag by using functionally equivalent ↵ | Justin Clark-Casey (justincc) | 2011-08-04 | 1 | -3/+4 |
| | | | | DCFlagKeyPressed | ||||
* | Stop calling the SP.ResetMoveToTarget() code if a target is not actually set | Justin Clark-Casey (justincc) | 2011-08-03 | 1 | -6/+16 |
| | |||||
* | remove move to duck walk compensation - no longer required. | Justin Clark-Casey (justincc) | 2011-08-03 | 1 | -12/+12 |
| | | | | extends npc move to regression test to check stop after sufficient sim updates | ||||
* | rename NPC.Autopilot to NPC.MoveToTarget internally. Add method doc to ↵ | Justin Clark-Casey (justincc) | 2011-08-03 | 1 | -1/+31 |
| | | | | INPCModule | ||||
* | refactor: rename the move to position methods to move to target to be ↵ | Justin Clark-Casey (justincc) | 2011-08-03 | 2 | -36/+12 |
| | | | | consistent with terminology used by scene object part and elsewhere | ||||
* | get rid of vestigal move to parameters | Justin Clark-Casey (justincc) | 2011-08-03 | 2 | -3/+6 |
| | |||||
* | Do a partial fix/implementation of OSSL osNpcMoveTo() | Justin Clark-Casey (justincc) | 2011-08-03 | 2 | -19/+29 |
| | | | | | | Avatar moves and stops. However, will stop in mid stride. And if the move to position is in the air, avatar will continue to make vain and quite hilarious attempts to take off (but never doing so). Clearly more work is needed. | ||||
* | Improve z axis move to/autopilot so the avatar does alternative ↵ | Justin Clark-Casey (justincc) | 2011-08-03 | 2 | -12/+30 |
| | | | | | | crouch/huzzah when walking along the ground Moving a flying avatar to a ground point doesn't yet land the avatar. This may or may not be the best thing | ||||
* | Implement move to/autopilot for z axis movement as well. | Justin Clark-Casey (justincc) | 2011-08-03 | 2 | -17/+40 |
| | | | | This is jerky (an artifact of the way it's being done, I think), but it's better than on implementation. | ||||
* | get autopilot/go here to work immediately. | Justin Clark-Casey (justincc) | 2011-08-03 | 1 | -3/+7 |
| | | | | This works with viewer 1.23.5 and so in theory should work with libopenmetaverse. | ||||
* | refactor: Move update_movement_flag and the final check inside the ↵ | Justin Clark-Casey (justincc) | 2011-08-03 | 1 | -5/+5 |
| | | | | m_allowMovement if in HandleAgentUpdate() since it's logically only ever used there | ||||
* | refactor: move out code from HandleAgentUpdate() which processes updates to ↵ | Justin Clark-Casey (justincc) | 2011-08-03 | 1 | -98/+116 |
| | | | | | | move to a set position Also comment out the really spammy log message I accidentally left in on the last commit. | ||||
* | Partially fix autopilot/go here | Justin Clark-Casey (justincc) | 2011-08-02 | 3 | -72/+53 |
| | | | | | | | This now works again except that it requires a click or avatar mvmt to get going This is because the ScenePresence.HandleAgentUpdate() method doesn't trigger until the client does something significant, at which point autopilot takes over. Even clicking is enough to trigger. This will be improved presently. | ||||
* | Get rid of AvatarAppearance.Owner to simplify the code. | Justin Clark-Casey (justincc) | 2011-08-02 | 2 | -4/+4 |
| | | | | This is not used for anything - appearances are always properties of objects with ids (ScenePresence, AgentCircuitData) and just has the potential to get out of sync when the appearance is cloned. | ||||
* | Get osNpcCreate appearance working with avatars that are currently in the scene. | Justin Clark-Casey (justincc) | 2011-08-01 | 1 | -2/+7 |
| | | | | | | Had to stop using AvatarService for now since it doesn't store baked texture IDs (which is why this was failing). Also failing because cloning appearance was also cloning the AvatarApperance.Owner field, which we weren't then changing. Extended TestCreate() to check this. | ||||
* | Comment out SOP logging message I accidentally left in | Justin Clark-Casey (justincc) | 2011-07-31 | 1 | -1/+1 |
| | |||||
* | refactor: split out ninja joint part of SOP.DoPhysicsPropertyUpdate() so ↵ | Justin Clark-Casey (justincc) | 2011-07-31 | 1 | -71/+86 |
| | | | | that we don't have to look at it if it's not relevant |