Difference between revisions of "UT3OSC"
m (→Timeline) |
m (→Exec Methods) |
||
Line 82: | Line 82: | ||
setLockHomingTargets | setLockHomingTargets | ||
+ | setSpeedSeekingShockBall | ||
setSpeedSeekingRocket | setSpeedSeekingRocket | ||
setSpeedShockBall | setSpeedShockBall |
Revision as of 01:30, 20 August 2010
UT3OSC is an implementation of the Unreal3 engine built using the Unreal Development Kit(UDK) with an integrated OscPack Windows dll linked to custom UnrealScript classes. First implementation will be used for the 2010 September 7,8 performances of Tele-Harmonium and Perkussionista in Milano, Italy at the 2010 MiTo (Milano-Torino) Festival.
By linking custom UnrealScript classes to Ross Bencina's excellent OscPack Open Sound Control c++ implementation, actions and motions taken by virtual actors in the Unreal3 game engine are encapsulated as OSC messages over UDP and used to control dynamic music and sound synthesis systems in a manner similar to q3osc.
Currently, OSC output from game engine includes:
- User XYZ coordinate data
- fired projectile coordinate data
- Static mesh objects XYZ coordinate data
- Static mesh bump event
- Static mesh takedamage event
Custom engine features include:
- bouncing projectiles (customized OSCProj_ShockBall and OSCProj_LinkPlasma)
- global projectile destructor exec command
Contents
Overview
UT3OSC is the fourth project in a lineage of integrating virtual worlds and environments with interactive audio and music servers with a common goal of creating shared and distributed musical performance spaces. Like our custom Sirikata implementation for the 2009 MiTo festival, q3osc and Maps & Legends before, UT3OSC combines a game-based virtual world implementation (in this case the Unreal Development Kit or UDK) with customized classes to stream game-data to interactive sound-servers using Open Sound Control messages over UDP. In this manner, gestures, motions and actions from actors in virtual space can be transformed in real-time into control messages for complex audio and musical software systems.
While the UDK offers only free access to the engine's UnrealScript programming layer (leaving the core C++ engine accessible only through significant financial investment) UnrealScript has a provision for binding Windows Win32 .dll's to UnrealScript classes, enabling code such as a C++ implementation of Open Sound Control (in this case, Ross Bencina's OSCPack) to provide bi-directional communication between game engine and sound-server. By then creating mirrored data structures both in UnrealScript classes and in the Windows .dll, data can be passed back and forth between the UDK and any OSC-enabled control system or software, including ChucK, Supercollider, Pure Data (PD) and Max/MSP.
For UT3OSC, a custom Windows oscpack_1_0_2.dll was compiled with specific extern methods and mirrored data structures to communicate with the game engine, both to stream specific game data out as OSC over UDP (including Pawn XYZ coordinate positioning, XYZ coordinate tracking for in-game projectiles, state and XYZ coordinate info for Static Mesh and Interp actor classes) and to send control data from iPad controllers and from the audio-engine itself back into the game to control Global GameInfo parameters such as world Gravity and GameRate, as well as specific positioning information for projecties and static actors.
Custom Classes and Files
UDK\UDK-2010-07\Binaries\Win32\UserCode
oscpack_1_0_2.dll
UDK\UDK-2010-07\UDKGame\Config
DefaultGame.ini DefaultOSC.ini DefaultUT3OSC.ini DefaultEngine.ini DefaultInput.ini
NOTE: Default .ini files generate UDK*.ini files when the engine runs. As such, make sure to delete UDK*.ini files after an svn update.
UDK\UDK-2010-07\Development\Src\UT3OSC\Classes
ActorFactoryOSCInterpActor.uc ActorFactoryOSCKActor.uc ActorFactoryOSCKActorFromStatic.uc ActorFactoryOSCStaticMeshActor.uc DefaultGame_QT3OSC.ini OSCInterpActor.uc OSCKActor.uc OSCKActorFromStatic.uc OSCParams.uc OSCPawn.uc OSCPlayerController.uc OSCPlayerControllerDLL.uc OSCProj_LinkPlasma.uc OSCProj_ShockBall.uc OSCStaticMeshActor.uc OSCWeap_LinkGun.uc OSCWeap_ShockRifle.uc OSCWorldInfo.uc ut3osc.uc
Exec Methods
Exec methods can be run from the UDK command-line in-game. The command-line can be accessed by pressing "~" for the full drop-down terminal window or by pressing "TAB" for the single-line window-bottom command-line. These are the custom UT3OSC exec methods that have been implemented to this point:
destroyAllProjectiles destroyAllShockBalls (optional bool) destroyShockball (#, optional bool)
OSCStartOutput OSCStopOutput OSCStartInput OSCSendDeltas setOSC [string, int] setOSCHostname [string] setOSCPort [int] getOSC getOSCHostname getOSCPort
setLockHomingTargets
setSpeedSeekingShockBall setSpeedSeekingRocket setSpeedShockBall
setGroundSpeed [float] getGroundSpeed initOSCFingerTouches [bool]
*setSpeedSeekingRocket [float] *setRadiusSeekingRocket *setRangeSeekingRocket *=doesn't work
Adding key-bindings to UDKGame\Config\DefaultInput.ini:
;----------------------------------------------------------------------------------------- ; UT3OSC Bindings ;----------------------------------------------------------------------------------------- .Bindings=(Name="one",Command="OSCStartOutput",Control=False,Shift=False,Alt=True) .Bindings=(Name="two",Command="OSCStopOutput",Control=False,Shift=False,Alt=True) .Bindings=(Name="three",Command="OSCStartInput",Control=False,Shift=False,Alt=True) .Bindings=(Name="four",Command="OSCSendDeltas",Control=False,Shift=False,Alt=True) .Bindings=(Name="nine",Command="DestroyAllShockballs True",Control=True,Shift=False,Alt=True) .Bindings=(Name="nine",Command="DestroyAllShockballs",Control=False,Shift=False,Alt=True) .Bindings=(Name="zero",Command="DestroyAllProjectiles",Control=False,Shift=False,Alt=True)
OSC Output and Input
Player output:
/player "bob" 85.474144 -48.000000 -479.850006 [True]
<tag> <player-name> <X float > <Y float > <Z float> <crouch bool>
Projectile output:
/projectile "OSCProj_LinkPlasma_0" "plasma" 141203.968750 13437.806641 -1752.857056
<tag> <projectile-name_instanceCount string> <projectile-type string> <X float> <Y float> <Z float> * TO ADD: explode bool current projectile-names: OSCProj_LinkPlasma, OSCProj_SeekingRocket, OSCProj_ShockBall current projectile-types: "plasma", "homingrocket" "shockball" * TO CHANGE: "homingrocket" to "seekingrocket"
/gameGravity <value float> /gameSpeed <value float>
iPad finger targeting for ShockBall homing OSC Input
/fingers <X1 float> <Y1 float> <Z1 float> <on1 float> ... <X5...
Getting Started
- Install July version of the UDK from: July 2010 UDK Beta (777 MB .exe)
- Follow the Subversion installation instructions below to install files to the correct locations.
There are only 4 locations where files need to be instlled:
- UDK-2010-07\Development\Src\UT3OSC: these are the custom OSC UnrealScript classes
- UDK-2010-07/Binaries/Win32/UserCode: the oscpack windows dll
- UDK-2010-07/UDKGame/Config: the custom default config files
- UDK-2010-07/UDKGame/Content/Maps: custom maps go here
Open UnrealFrontend to compile UT3OSC
- ?game=UT3OSC.UT3OSC should be pasted into the "Extra Options" field
- check the "show log" check box to see debug messages in the console
Launch Map
- DETAILS COMING SOON
SETUP OSC CLIENT FOR MONITORING
- DETAILS COMING SOON
Subversion Setup
Copy UT3OSC data into the Src dir:
cd D:/UDK/UDK-2010-07/Development/Src svn checkout svn+ssh://rob@ccrma-gate.stanford.edu/user/r/rob/data/mvw/svn/udkosc/UDK/UDK-2010-07/Development/Src/UT3OSC ./UT3OSC/
Checkout oscpack dll:
cd D:/UDK/UDK-2010-07/Binaries/Win32/UserCode svn checkout svn+ssh://rob@ccrma-gate.stanford.edu/user/r/rob/data/mvw/svn/udkosc/UDK/UDK-2010-07/Binaries/Win32/UserCode .
Checkout ini files:
cd D:/UDK/UDK-2010-07/UDKGame/Config svn checkout svn+ssh://rob@ccrma-gate.stanford.edu/user/r/rob/data/mvw/svn/udkosc/UDK/UDK-2010-07/UDKGame/Config .
Checkout test Maps:
cd D:/UDK/UDK-2010-07/UDKGame/Content/Maps svn checkout svn+ssh://rob@ccrma-gate.stanford.edu/user/r/rob/data/mvw/svn/udkosc/UDK/UDK-2010-07/UDKGame/Content/Maps .
Checkout oscpack_1_0_2.dll Source + VS2010 Project [optional]
svn checkout svn+ssh://rob@ccrma-gate.stanford.edu/user/r/rob/data/mvw/svn/udkosc/oscpack/ . NOTE: also includes .zip of source project
Timeline
8/18/2010
Cleanup on UDK-side of multi-touch control; now shockballs don't explode on collision with other shockballs and when initOSCFingerTouches is TRUE, will seek out the next available finger touch location currently being received.
Created Max/MSP test patch for control testing.
8/17/2010
Added initial OSC Input to control seeking of ShockBalls to be used as controlled by 5 iPad finger touches.
/fingers X Y Z on/off (all floats, for fingers 1-5)
8/16/2010
Smoothed out homing functionality for SeekingRockets; now make nice smooth arcs.
8/15/2010
Added basic homing functionality for SeekingRockets to track ShockBalls. Added helper functions:
setLockHomingTargets setRadiusSeekingRocket setRangeSeekingRocket setSpeedSeekingRocket setSpeedShockBall
with LockHomingTargets, we can set if seeking projectiles will automatically search for the closest target (expensive) or stay locked to the initial target the first seek.
8/14/2010
Committed Full svn
post svn:
- added setGroundSpeed (float), and getGroundSpeed() exec functions to OSCPawn to set player speed.
8/13/2010
Added exec functions for setting OSC params from within game terminal: setOSC(ip, port) setOSCHostname(ip) and setOSCPort(port) which all save values to UDKOSC.ini after edit.
Added getOSCHostname, getOSCPort and getOSC methods to display current OSC settings to in-game user.
Initial homing rocket code started with limited results; rockets home in on ShockBalls but after tracking them successfully, don't update their direction to follow again.
8/12/2010
Successful network (LAN, local) testing with 3 connected clients Added OSCTrigger class to send message on Trigger event
8/11/2010
Added crouch tracking in OSCPawn output, and OSCStartInput, OSCStartOutput, OSCStopOutput, and OSCSendDeltas exec functions.
Working on extending "Use" function:
http://forums.epicgames.com/showthread.php?t=717602&highlight=PerformedUseAction
found in PlayerController.uc
/** * Entry point function for player interactions with the world, * re-directs to ServerUse. */ exec function Use() { if( Role < Role_Authority ) { PerformedUseAction(); } ServerUse(); }
/** * Player pressed UseKey */ unreliable server function ServerUse() { PerformedUseAction(); }
8/10/2010
added initOSCReceiver function to OSCPawn to initiate OSC input polling from the dll.
updated Max/MSP gui OSC sender applet for testing global gameGravity and gameSpeed params over OSC
8/09/2010
Mapped incoming OSC test floats to GameSpeed and Gravity successfully.
Can access WorldInfo and current Game vars and methods stored in ut3osc.uc:
UT3OSC(WorldInfo.Game).fingerTouchArray[0].X=val;
8/08/2010
Code re-written to access OSC params in OSCParams.uc class. Now Hostname and Port can be set through the DefaultOSC.ini
Updated code checked into SVN
8/03/2010
Successful test of OSC messages being sent into UDK via OSCPack dll listener, operating on its own thread.
Pawn motion:
http://www.etc.cmu.edu/projects/coyote210/Docs/undox/Engine.Pawn.html
MoveTo and MoveToward methods
void MoveTo(vector NewDestination, optional float) // Latent Movement. Note that MoveTo sets the actor's Destination, and MoveToward sets the actor's MoveTarget. Actor will rotate towards destination void MoveToward(Actor NewTarget, optional float)
UDKProjectile
/** Currently tracked target - if set, projectile will seek it */ var actor SeekTarget;
Projectile
Can target be changed just by setting Velocity (Speed * Direction vector)? /* Init() initialize velocity and rotation of projectile */ function Init( Vector Direction ) { SetRotation(Rotator(Direction)); Velocity = Speed * Direction; }
Actor (projectiles inherit from Actor)
// The actor's position and rotation. /** Actor's location; use Move or SetLocation to change. */ var(Movement) const vector Location; /** The actor's rotation; use SetRotation to change. */ var(Movement) const rotator Rotation;
Added "MoveAllProjectiles X Y Z" as exec function: instantly moves all projectiles to a specific location.
Working on
exec function setAllProjectileSpeed(int speed) { local UTProjectile pUT; ForEach AllActors(class'UTProjectile', pUT) { pUT.Speed = speed; } }
8/01/2010
Checked in modifications to July UDK to svn at ccrma. Note only modified files/custom files were checked in, including the source for the oscpack windows dll, and these should be checked out into a 2010-07 install of the UDK.
7/31/2010
OSCInterpActor class
- outputs position data on move, bump and damage as well - Kismet script tested successfully to spit out position data while object moves
7/27/2010
- Moved to July UDK
Current Feature List
- OSC dll in place - Tracking XYZ data in customized player controller sending OSC data - Bouncing Projectiles - Tracking projectile XYZ data sending OSC data - customized Actor class for OSC on bump and touch events (not tested yet)
6/13/2010
First Words: ?game=UT3OSC.UT3OSC needs to be passed in "Extra Options" in Unreal FrontEnd
OSC message is being sent from Terminal on typing "Test1"
- first impressions are that it's a bit slow... lag/latency maybe UnrealScript?
[COMMANDLET 'UDK.exe make -full' STARTED IN ] June 13, 12:23 AM Init: Version: 6522 Init: Epic Internal: 0 Init: Compiled (32-bit): Apr 9 2010 12:14:06 Init: Command line: -full -DEFENGINEINI=..\..\UDKGame\Config\DefaultEngineUDK.ini Init: Base directory: C:\UDK\UDK-2010-04\Binaries\Win32\ Init: Character set: Unicode Log: Executing Class UnrealEd.MakeCommandlet --------------------Core - Release-------------------- Analyzing... Scripts successfully compiled - saving package 'C:\UDK\UDK-2010-04\Binaries\Win32\..\..\UDKGame\Script\Core.u' --------------------Engine - Release-------------------- Analyzing... Scripts successfully compiled - saving package 'C:\UDK\UDK-2010-04\Binaries\Win32\..\..\UDKGame\Script\Engine.u' --------------------GameFramework - Release-------------------- Analyzing... Scripts successfully compiled - saving package 'C:\UDK\UDK-2010-04\Binaries\Win32\..\..\UDKGame\Script\GameFramework.u' --------------------UnrealEd - Release-------------------- Analyzing... Scripts successfully compiled - saving package 'C:\UDK\UDK-2010-04\Binaries\Win32\..\..\UDKGame\Script\UnrealEd.u' --------------------IpDrv - Release-------------------- Analyzing... Scripts successfully compiled - saving package 'C:\UDK\UDK-2010-04\Binaries\Win32\..\..\UDKGame\Script\IpDrv.u' --------------------OnlineSubsystemPC - Release-------------------- Analyzing... Scripts successfully compiled - saving package 'C:\UDK\UDK-2010-04\Binaries\Win32\..\..\UDKGame\Script\OnlineSubsystemPC.u' --------------------UDKBase - Release-------------------- Analyzing... Scripts successfully compiled - saving package 'C:\UDK\UDK-2010-04\Binaries\Win32\..\..\UDKGame\Script\UDKBase.u' --------------------UTEditor - Release-------------------- Analyzing... Scripts successfully compiled - saving package 'C:\UDK\UDK-2010-04\Binaries\Win32\..\..\UDKGame\Script\UTEditor.u' --------------------UTGame - Release-------------------- Analyzing... Scripts successfully compiled - saving package 'C:\UDK\UDK-2010-04\Binaries\Win32\..\..\UDKGame\Script\UTGame.u' --------------------UTGameContent - Release-------------------- Analyzing... Scripts successfully compiled - saving package 'C:\UDK\UDK-2010-04\Binaries\Win32\..\..\UDKGame\Script\UTGameContent.u' --------------------UnrealOsc - Release-------------------- Analyzing... Scripts successfully compiled - saving package 'C:\UDK\UDK-2010-04\Binaries\Win32\..\..\UDKGame\Script\UnrealOsc.u' Success - 0 error(s), 0 warning(s) Execution of commandlet took: 22.67 seconds [COMMANDLET 'UDK.exe make -full' SUCCEEDED] June 13, 12:23 AM
6/1/2010
basic testing of Windows Oscpack dll writes message successfully over OSC from test app
__declspec(dllexport) double returnDouble(double a); __declspec(dllexport) void sendOSCmessageTest();
random notes
Shortcuts
Link to Disable Windows key:
http://support.microsoft.com/?id=216893
Hide HUD and Weapon: togglescreenshotmode
http://udn.epicgames.com/Three/CharactersTechnicalGuide.html#Inventory and Weapons: WeaponFired [weapon] [bViaReplication] [hitLocation] http://www.moddb.com/games/unreal-tournament-3/tutorials/unreal-learning-1-my-first-unreal-tournament-3-mutator
default gravity (game specific) - set in defaultgame.ini Default value: -520.0
ProjectileList http://wiki.beyondunreal.com/UE3:WorldInfo_internal_variables_(UDK)
Moving to July UDK
Add UT3OSC references to UDKGame\Config\DefaultGame.ini
[Engine.GameInfo] DefaultGame=UT3OSC.UT3OSC DefaultServerGame=UT3OSC.UT3OSC PlayerControllerClassName=UT3OSC.OSCPlayerControllerDll DefaultGameType="UT3OSC.UT3OSC";
Add ModEditPackages line to section in UDKGame\Config\DefaultEngineUDK.ini
[UnrealEd.EditorEngine] +EditPackages=UTGame +EditPackages=UTGameContent +EditPackages=CastleGame ModEditPackages=UT3OSC
Exposed OSC Methods
Adding Hostname and Port param to structs to allow for multiple/dynamic OSC targets
sendOSCPlayerState(PlayerStateStruct)
- OSCPawn::Tick
- Hostname (string) - Port (int) - PlayerName (string) - Location X (float) - Location Y (float) - Location Z (float) - Crouch (bool)
sendOSCpointClick(PointClickStruct)
- Hostname (string) - Port (int) - TraceHit (string) - TraceHit_class (string) - TraceHit_class_outerName (string) - Location X (float) - Location Y (float) - Location Z (float) - HitInfo_material (string) - HitInfo_physmaterial (string) - HitInfo_hitcomponent (string)
DLL Binding
"A single UnrealScript class can bind to only a single DLL. The DLL to bind to is specified with the DLLBind directive, and the DLL name to bind to is specified in parentheses. Do not include a path or .DLL extension. DLLs can only be loaded from the Binaries\Win32\UserCode folder." - http://udn.epicgames.com/Three/DLLBind.html
Also TCP/IP Link:
http://forums.epicgames.com/showthread.php?t=740321
Network Latency overview from Valve
http://developer.valvesoftware.com/wiki/Source_Multiplayer_Networking
My Posts
http://forums.epicgames.com/showthread.php?p=27580921#post27580921
http://forums.epicgames.com/showthread.php?p=27580950#post27580950
Scripting
http://okita.com/alex/?page_id=474
http://forums.epicgames.com/showthread.php?t=736141
http://forums.epicgames.com/forumdisplay.php?f=367&order=desc&page=19
UDK dev environment
http://udn.epicgames.com/Three/ExecFunctions.html#Debugging
http://forecourse.com/unreal-tutorials/
http://forecourse.com/unreal-tutorials/#UnrealScript%21
http://wiki.pixelminegames.com/index.php?title=Tools:nFringe
http://forums.epicgames.com/showthread.php?t=722792
http://forums.beyondunreal.com/showthread.php?p=2405761
Overview:
http://www.theballthegame.com/tutorialudk.htm
http://www.hourences.com/book/tutorialsindex.htm
Adding Classes to World Editor:
http://forums.epicgames.com/showthread.php?t=715530
Windows Multithreading c++:
http://www.cppgameprogramming.com/cgi/nav.cgi?page=multithreading
http://www.devarticles.com/c/a/Cplusplus/Multithreading-in-C/
Weapon Modding:
http://forums.epicgames.com/showthread.php?t=716665
http://udn.epicgames.com/Three/WeaponsTechnicalGuide.html
http://forums.epicgames.com/showthread.php?t=708422
Unreal Script calling Windows dll:
http://udn.epicgames.com/Three/DLLBind.html
OSC dlls:
http://www.frieder-weiss.de/OSC/OSC-DLL.htm
http://www.bespokesoftware.org/wordpress/?page_id=69
http://www.3dvia.com/forums/topic/opensoundcontrol-osc-bb-s-released-under-gpl/page/3
Windows OSC utilities:
http://www.frieder-weiss.de/OSC/
Creating Windows C++ dlls:
http://msdn.microsoft.com/en-us/library/1ez7dh12.aspx
http://www.tutorialspoint.com/dll/dll_writing.htm
UDK Tutorials (video):
http://www.3dbuzz.com/vbforum/sv_videonav.php?fid=292838127fecccd8b151c72003546386
http://utmapping.wikidot.com/how-to-build-a-simple-cube-map
Basic Level Building Tutorials:
Windows VS2010 stuff:
http://social.msdn.microsoft.com/Forums/en-US/vcgeneral/thread/ea11890e-247b-4640-82a9-d6f657c36afa
http://social.msdn.microsoft.com/forums/en-US/vclanguage/thread/d8c0ba83-a619-443f-b194-20a1fbbf7bd7
http://msdn.microsoft.com/en-us/library/28d6s79h(VS.80).aspx
Linker Settings for VS2010 (necessary to compile):
http://social.msdn.microsoft.com/Forums/en-US/vcgeneral/thread/ea11890e-247b-4640-82a9-d6f657c36afa
http://www.gamedev.net/community/forums/topic.asp?topic_id=185053
(right-click project > Properties > Linker > Input > add to "Additional Dependencies" Ws2_32.lib;WINMM.lib; )
Homing Missles:
http://board.flashkit.com/board/archive/index.php/t-175556.html
Packaging:
http://forums.epicgames.com/showthread.php?t=734728&highlight=PACKAGE+GAME&page=2
Overall Process:
http://developer.download.nvidia.com/udk/Whizzle_Creation_Document_1_2.pdf
Keyboard input overview:
class reference:
http://forums.epicgames.com/showthread.php?t=739124&highlight=actor+tag+instance
general location:
vectors:
http://chimeric.beyondunreal.com/tutorials/vectors.php
http://chortle.ccsu.edu/VectorLessons/vectorIndex.html#01
http://wiki.ioquake3.org/Vectors
http://wiki.beyondunreal.com/Legacy:UnrealScript_Vector_Maths