Camera Bob: Difference between revisions
| No edit summary | Mark Tella (talk | contribs)  m (→The Code) | ||
| (13 intermediate revisions by 11 users not shown) | |||
| Line 1: | Line 1: | ||
| This tutorial will go through the basics of creating a camera bobbing for when a player walks. The result is a pretty realistic simulation of a head bob that nearly matches HL2's default walking speed and walking sounds. This tutorial has only been tested with the HL2MP OB and the beta OB SDK template, but should work for most every other version of Valve's source code with a few adjustments. A special thanks goes out to [http://forums.steampowered.com/forums/member.php?u=562817 sharkkk] and [http://forums.steampowered.com/forums/member.php?u=380894 Winston] from the Steam Forums for figuring all of this stuff out. | {{LanguageBar}} | ||
| This tutorial will go through the basics of creating a camera bobbing for when a player walks. The result is a pretty realistic simulation of a head bob that nearly matches HL2's default walking speed and walking sounds. This tutorial has only been tested with the HL2MP OB and the beta OB SDK template, but should work for most every other version of Valve's source code with a few adjustments. A special thanks goes out to [https://web.archive.org/web/20170604230305/http://forums.steampowered.com/forums/member.php?u=562817 sharkkk (archived)] and [https://web.archive.org/web/20170605055312/http://forums.steampowered.com/forums/member.php?u=380894 Winston (archived)] from the Steam Forums for figuring all of this stuff out. | |||
| Sources: | Sources: | ||
| [http://forums.steampowered.com/forums/showthread.php?t=862508  | <br> | ||
| [http://forums.steampowered.com/forums/showthread.php?t=706707  | [https://web.archive.org/web/20170521085616/http://forums.steampowered.com/forums/showthread.php?t=862508#11 sharkkk's code (archived)] | ||
| <br> | |||
| [https://web.archive.org/web/20170521100424/http://forums.steampowered.com/forums/showthread.php?t=706707#3 Winston's code (archived)] | |||
| == The Code == | == The Code == | ||
| In '''gamemovement.cpp''', before the list of defines around lines 65 or so, add the following: | In '''gamemovement.cpp''', before the list of defines around lines 65 or so, add the following: | ||
| <source lang="cpp"> | <source lang="cpp"> | ||
| // Camera Bob | // Camera Bob | ||
| ConVar cl_viewbob_enabled	( "cl_viewbob_enabled", "1", 0, "Oscillation Toggle" | ConVar cl_viewbob_enabled	( "cl_viewbob_enabled", "1", 0, "Oscillation Toggle" ); // Enable or disable camera bobbing | ||
| ConVar cl_viewbob_timer		( "cl_viewbob_timer", "10", 0, "Speed of Oscillation"); | ConVar cl_viewbob_timer		( "cl_viewbob_timer", "10", 0, "Speed of Oscillation" ); // How often do "turns up and down" happen | ||
| ConVar cl_viewbob_scale		( "cl_viewbob_scale", "0.05", 0, "Magnitude of Oscillation"); | ConVar cl_viewbob_scale		( "cl_viewbob_scale", "0.05", 0, "Magnitude of Oscillation" ); // How far does the camera go up or down when walking | ||
| </source> | </source> | ||
| All we're doing here is declaring our  | All we're doing here is declaring our ConVars, bools and floats for our camera bobbing code below. | ||
| In the same file, find the function void  | In the same file, find the function void <code>CGameMovement::WalkMove( void )</code> and add the following to the very top of the function after <code>smove = mv->m_flSideMove</code>: | ||
| <source lang="cpp"> | <source lang="cpp"> | ||
| 	if ( cl_viewbob_enabled.GetBool() && !engine->IsPaused() ) // Disable bobbing when menuing (NOT in multiplayer) | |||
| 	{ | 	{ | ||
| 		float xoffset = sin( gpGlobals->curtime * cl_viewbob_timer.GetFloat() ) * player->GetAbsVelocity().Length() * cl_viewbob_scale.GetFloat() / 100; | 		float xoffset = sin( gpGlobals->curtime * cl_viewbob_timer.GetFloat() ) * player->GetAbsVelocity().Length() * cl_viewbob_scale.GetFloat() / 100; | ||
| 		float yoffset = sin( 2 * gpGlobals->curtime * cl_viewbob_timer.GetFloat() ) * player->GetAbsVelocity().Length() * cl_viewbob_scale.GetFloat() / 400; | 		float yoffset = sin( 2 * gpGlobals->curtime * cl_viewbob_timer.GetFloat() ) * player->GetAbsVelocity().Length() * cl_viewbob_scale.GetFloat() / 400; | ||
| 		player->ViewPunch( QAngle( xoffset, yoffset, 0)); | 		player->ViewPunch( QAngle( xoffset, yoffset, 0 ) ); | ||
| 	} | 	} | ||
| </source> | </source> | ||
| What this does is it uses the player's velocity and the  | What this does is it uses the player's velocity and the ConVars to oscillate the players view in a figure of 8 using a [[ViewPunch]]. | ||
| [[Category:Programming]] | [[Category:Programming]] | ||
| [[Category:Tutorials]] | [[Category:Tutorials]] | ||
Latest revision as of 01:12, 6 April 2025
This tutorial will go through the basics of creating a camera bobbing for when a player walks. The result is a pretty realistic simulation of a head bob that nearly matches HL2's default walking speed and walking sounds. This tutorial has only been tested with the HL2MP OB and the beta OB SDK template, but should work for most every other version of Valve's source code with a few adjustments. A special thanks goes out to sharkkk (archived) and Winston (archived) from the Steam Forums for figuring all of this stuff out.
Sources:
sharkkk's code (archived)
Winston's code (archived)
The Code
In gamemovement.cpp, before the list of defines around lines 65 or so, add the following:
// Camera Bob
ConVar cl_viewbob_enabled	( "cl_viewbob_enabled", "1", 0, "Oscillation Toggle" ); // Enable or disable camera bobbing
ConVar cl_viewbob_timer		( "cl_viewbob_timer", "10", 0, "Speed of Oscillation" ); // How often do "turns up and down" happen
ConVar cl_viewbob_scale		( "cl_viewbob_scale", "0.05", 0, "Magnitude of Oscillation" ); // How far does the camera go up or down when walking
All we're doing here is declaring our ConVars, bools and floats for our camera bobbing code below.
In the same file, find the function void CGameMovement::WalkMove( void ) and add the following to the very top of the function after smove = mv->m_flSideMove:
	if ( cl_viewbob_enabled.GetBool() && !engine->IsPaused() ) // Disable bobbing when menuing (NOT in multiplayer)
	{
		float xoffset = sin( gpGlobals->curtime * cl_viewbob_timer.GetFloat() ) * player->GetAbsVelocity().Length() * cl_viewbob_scale.GetFloat() / 100;
		float yoffset = sin( 2 * gpGlobals->curtime * cl_viewbob_timer.GetFloat() ) * player->GetAbsVelocity().Length() * cl_viewbob_scale.GetFloat() / 400;
		player->ViewPunch( QAngle( xoffset, yoffset, 0 ) );
	}
What this does is it uses the player's velocity and the ConVars to oscillate the players view in a figure of 8 using a ViewPunch.

























