mirror of
https://github.com/nillerusr/source-engine.git
synced 2025-01-12 16:18:03 +00:00
game/client: fix messagemode, add acceleration for touch, GameUI: add touch options
This commit is contained in:
parent
0feeab91dd
commit
ab5c1c0b3a
@ -52,6 +52,7 @@
|
|||||||
#include "replay/vgui/replaymessagepanel.h"
|
#include "replay/vgui/replaymessagepanel.h"
|
||||||
#include "econ/econ_controls.h"
|
#include "econ/econ_controls.h"
|
||||||
#include "econ/confirm_dialog.h"
|
#include "econ/confirm_dialog.h"
|
||||||
|
|
||||||
extern IClientReplayContext *g_pClientReplayContext;
|
extern IClientReplayContext *g_pClientReplayContext;
|
||||||
extern ConVar replay_rendersetting_renderglow;
|
extern ConVar replay_rendersetting_renderglow;
|
||||||
#endif
|
#endif
|
||||||
@ -144,6 +145,18 @@ CON_COMMAND( hud_reloadscheme, "Reloads hud layout and animation scripts." )
|
|||||||
mode->ReloadScheme();
|
mode->ReloadScheme();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
CON_COMMAND( messagemode, "Opens chat dialog" )
|
||||||
|
{
|
||||||
|
ClientModeShared *mode = ( ClientModeShared * )GetClientModeNormal();
|
||||||
|
mode->StartMessageMode( MM_SAY );
|
||||||
|
}
|
||||||
|
|
||||||
|
CON_COMMAND( messagemode2, "Opens chat dialog" )
|
||||||
|
{
|
||||||
|
ClientModeShared *mode = ( ClientModeShared * )GetClientModeNormal();
|
||||||
|
mode->StartMessageMode( MM_SAY_TEAM );
|
||||||
|
}
|
||||||
|
|
||||||
#ifdef _DEBUG
|
#ifdef _DEBUG
|
||||||
CON_COMMAND_F( crash, "Crash the client. Optional parameter -- type of crash:\n 0: read from NULL\n 1: write to NULL\n 2: DmCrashDump() (xbox360 only)", FCVAR_CHEAT )
|
CON_COMMAND_F( crash, "Crash the client. Optional parameter -- type of crash:\n 0: read from NULL\n 1: write to NULL\n 2: DmCrashDump() (xbox360 only)", FCVAR_CHEAT )
|
||||||
{
|
{
|
||||||
@ -632,28 +645,6 @@ int ClientModeShared::KeyInput( int down, ButtonCode_t keynum, const char *pszCu
|
|||||||
if ( engine->Con_IsVisible() )
|
if ( engine->Con_IsVisible() )
|
||||||
return 1;
|
return 1;
|
||||||
|
|
||||||
// Should we start typing a message?
|
|
||||||
if ( pszCurrentBinding &&
|
|
||||||
( Q_strcmp( pszCurrentBinding, "messagemode" ) == 0 ||
|
|
||||||
Q_strcmp( pszCurrentBinding, "say" ) == 0 ) )
|
|
||||||
{
|
|
||||||
if ( down )
|
|
||||||
{
|
|
||||||
StartMessageMode( MM_SAY );
|
|
||||||
}
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
else if ( pszCurrentBinding &&
|
|
||||||
( Q_strcmp( pszCurrentBinding, "messagemode2" ) == 0 ||
|
|
||||||
Q_strcmp( pszCurrentBinding, "say_team" ) == 0 ) )
|
|
||||||
{
|
|
||||||
if ( down )
|
|
||||||
{
|
|
||||||
StartMessageMode( MM_SAY_TEAM );
|
|
||||||
}
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
// If we're voting...
|
// If we're voting...
|
||||||
#ifdef VOTING_ENABLED
|
#ifdef VOTING_ENABLED
|
||||||
CHudVote *pHudVote = GET_HUDELEMENT( CHudVote );
|
CHudVote *pHudVote = GET_HUDELEMENT( CHudVote );
|
||||||
|
@ -947,7 +947,8 @@ void CInput::ControllerMove( float frametime, CUserCmd *cmd )
|
|||||||
}
|
}
|
||||||
|
|
||||||
JoyStickMove( frametime, cmd);
|
JoyStickMove( frametime, cmd);
|
||||||
gTouch.Move( frametime, cmd );
|
|
||||||
|
TouchMove( cmd );
|
||||||
|
|
||||||
// NVNT if we have a haptic device..
|
// NVNT if we have a haptic device..
|
||||||
if(haptics && haptics->HasDevice())
|
if(haptics && haptics->HasDevice())
|
||||||
@ -1194,9 +1195,9 @@ void CInput::CreateMove ( int sequence_number, float input_sample_frametime, boo
|
|||||||
|
|
||||||
// Using joystick?
|
// Using joystick?
|
||||||
#ifdef SIXENSE
|
#ifdef SIXENSE
|
||||||
if ( in_joystick.GetInt() || g_pSixenseInput->IsEnabled() )
|
if ( in_joystick.GetInt() || g_pSixenseInput->IsEnabled() || touch_enable.GetInt() )
|
||||||
#else
|
#else
|
||||||
if ( in_joystick.GetInt() )
|
if ( in_joystick.GetInt() || touch_enable.GetInt() )
|
||||||
#endif
|
#endif
|
||||||
{
|
{
|
||||||
if ( cmd->forwardmove > 0 )
|
if ( cmd->forwardmove > 0 )
|
||||||
|
113
game/client/in_touch.cpp
Normal file
113
game/client/in_touch.cpp
Normal file
@ -0,0 +1,113 @@
|
|||||||
|
//========= Copyright Valve Corporation, All rights reserved. ============//
|
||||||
|
//
|
||||||
|
// Purpose: Mouse input routines
|
||||||
|
//
|
||||||
|
// $Workfile: $
|
||||||
|
// $Date: $
|
||||||
|
// $NoKeywords: $
|
||||||
|
//===========================================================================//
|
||||||
|
#if defined( WIN32 ) && !defined( _X360 )
|
||||||
|
#define _WIN32_WINNT 0x0502
|
||||||
|
#include <windows.h>
|
||||||
|
#endif
|
||||||
|
#include "cbase.h"
|
||||||
|
#include "hud.h"
|
||||||
|
#include "cdll_int.h"
|
||||||
|
#include "kbutton.h"
|
||||||
|
#include "basehandle.h"
|
||||||
|
#include "usercmd.h"
|
||||||
|
#include "input.h"
|
||||||
|
#include "iviewrender.h"
|
||||||
|
#include "iclientmode.h"
|
||||||
|
#include "tier0/icommandline.h"
|
||||||
|
#include "vgui/ISurface.h"
|
||||||
|
#include "vgui_controls/Controls.h"
|
||||||
|
#include "vgui/Cursor.h"
|
||||||
|
#include "cdll_client_int.h"
|
||||||
|
#include "cdll_util.h"
|
||||||
|
#include "tier1/convar_serverbounded.h"
|
||||||
|
#include "cam_thirdperson.h"
|
||||||
|
#include "inputsystem/iinputsystem.h"
|
||||||
|
#include "touch.h"
|
||||||
|
|
||||||
|
// up / down
|
||||||
|
#define PITCH 0
|
||||||
|
// left / right
|
||||||
|
#define YAW 1
|
||||||
|
|
||||||
|
extern ConVar cl_sidespeed;
|
||||||
|
extern ConVar cl_forwardspeed;
|
||||||
|
extern ConVar sensitivity;
|
||||||
|
extern ConVar lookstrafe;
|
||||||
|
extern ConVar thirdperson_platformer;
|
||||||
|
extern ConVar touch_pitch;
|
||||||
|
extern ConVar touch_yaw;
|
||||||
|
extern ConVar default_fov;
|
||||||
|
|
||||||
|
#ifdef PORTAL
|
||||||
|
extern bool g_bUpsideDown;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
ConVar touch_enable_accel( "touch_enable_accel", "0", FCVAR_ARCHIVE );
|
||||||
|
ConVar touch_accel( "touch_accel", "1.f", FCVAR_ARCHIVE );
|
||||||
|
ConVar touch_reverse( "touch_reverse", "0", FCVAR_ARCHIVE );
|
||||||
|
ConVar touch_sensitivity( "touch_sensitivity", "3.0", FCVAR_ARCHIVE, "touch look sensitivity" );
|
||||||
|
|
||||||
|
void CInput::TouchScale( float &dx, float &dy )
|
||||||
|
{
|
||||||
|
dx *= touch_yaw.GetFloat();
|
||||||
|
dy *= touch_pitch.GetFloat();
|
||||||
|
|
||||||
|
float sensitivity = touch_sensitivity.GetFloat() * gHUD.GetFOVSensitivityAdjust() * ( touch_reverse.GetBool() ? -1.f : 1.f );
|
||||||
|
|
||||||
|
if( touch_enable_accel.GetBool() )
|
||||||
|
{
|
||||||
|
float raw_touch_movement_distance_squared = dx * dx + dy * dy;
|
||||||
|
float fExp = MAX(0.0f, (touch_accel.GetFloat() - 1.0f) / 2.0f);
|
||||||
|
float accelerated_sensitivity = powf( raw_touch_movement_distance_squared, fExp ) * sensitivity;
|
||||||
|
|
||||||
|
dx *= accelerated_sensitivity;
|
||||||
|
dy *= accelerated_sensitivity;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
dx *= sensitivity;
|
||||||
|
dy *= sensitivity;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void CInput::ApplyTouch( QAngle &viewangles, CUserCmd *cmd, float dx, float dy )
|
||||||
|
{
|
||||||
|
viewangles[YAW] -= dx;
|
||||||
|
viewangles[PITCH] += dy;
|
||||||
|
cmd->mousedx = dx;
|
||||||
|
cmd->mousedy = dy;
|
||||||
|
}
|
||||||
|
|
||||||
|
void CInput::TouchMove( CUserCmd *cmd )
|
||||||
|
{
|
||||||
|
QAngle viewangles;
|
||||||
|
float dx,dy,side,forward,pitch,yaw;
|
||||||
|
|
||||||
|
engine->GetViewAngles( viewangles );
|
||||||
|
|
||||||
|
view->StopPitchDrift();
|
||||||
|
|
||||||
|
gTouch.GetTouchAccumulators( &side, &forward, &yaw, &pitch );
|
||||||
|
|
||||||
|
cmd->sidemove -= cl_sidespeed.GetFloat() * side;
|
||||||
|
cmd->forwardmove += cl_forwardspeed.GetFloat() * forward;
|
||||||
|
|
||||||
|
gTouch.GetTouchDelta( yaw, pitch, &dx, &dy );
|
||||||
|
|
||||||
|
TouchScale( dx, dy );
|
||||||
|
|
||||||
|
// Let the client mode at the mouse input before it's used
|
||||||
|
g_pClientMode->OverrideMouseInput( &dx, &dy );
|
||||||
|
|
||||||
|
// Add mouse X/Y movement to cmd
|
||||||
|
ApplyTouch( viewangles, cmd, dx, dy );
|
||||||
|
|
||||||
|
// Store out the new viewangles.
|
||||||
|
engine->SetViewAngles( viewangles );
|
||||||
|
}
|
@ -135,7 +135,10 @@ private:
|
|||||||
void GetMouseDelta( float inmousex, float inmousey, float *pOutMouseX, float *pOutMouseY );
|
void GetMouseDelta( float inmousex, float inmousey, float *pOutMouseX, float *pOutMouseY );
|
||||||
void ScaleMouse( float *x, float *y );
|
void ScaleMouse( float *x, float *y );
|
||||||
void ApplyMouse( QAngle& viewangles, CUserCmd *cmd, float mouse_x, float mouse_y );
|
void ApplyMouse( QAngle& viewangles, CUserCmd *cmd, float mouse_x, float mouse_y );
|
||||||
void MouseMove ( CUserCmd *cmd );
|
void MouseMove( CUserCmd *cmd );
|
||||||
|
void TouchMove( CUserCmd *cmd );
|
||||||
|
void TouchScale( float &dx, float &dy );
|
||||||
|
void ApplyTouch( QAngle &viewangles, CUserCmd *cmd, float dx, float dy );
|
||||||
|
|
||||||
// Joystick movement input helpers
|
// Joystick movement input helpers
|
||||||
void ControllerMove ( float frametime, CUserCmd *cmd );
|
void ControllerMove ( float frametime, CUserCmd *cmd );
|
||||||
|
@ -28,6 +28,8 @@ extern ConVar sensitivity;
|
|||||||
#define TOUCH_DEFAULT_CFG "touch_default.cfg"
|
#define TOUCH_DEFAULT_CFG "touch_default.cfg"
|
||||||
|
|
||||||
ConVar touch_enable( "touch_enable", TOUCH_DEFAULT, FCVAR_ARCHIVE );
|
ConVar touch_enable( "touch_enable", TOUCH_DEFAULT, FCVAR_ARCHIVE );
|
||||||
|
ConVar touch_draw( "touch_draw", "1", FCVAR_ARCHIVE );
|
||||||
|
ConVar touch_filter( "touch_filter", "0", FCVAR_ARCHIVE );
|
||||||
ConVar touch_forwardzone( "touch_forwardzone", "0.06", FCVAR_ARCHIVE, "forward touch zone" );
|
ConVar touch_forwardzone( "touch_forwardzone", "0.06", FCVAR_ARCHIVE, "forward touch zone" );
|
||||||
ConVar touch_sidezone( "touch_sidezone", "0.06", FCVAR_ARCHIVE, "side touch zone" );
|
ConVar touch_sidezone( "touch_sidezone", "0.06", FCVAR_ARCHIVE, "side touch zone" );
|
||||||
ConVar touch_pitch( "touch_pitch", "90", FCVAR_ARCHIVE, "touch pitch sensitivity" );
|
ConVar touch_pitch( "touch_pitch", "90", FCVAR_ARCHIVE, "touch pitch sensitivity" );
|
||||||
@ -258,6 +260,36 @@ CON_COMMAND( touch_toggleselection, "toggle visibility on selected button in edi
|
|||||||
|
|
||||||
}*/
|
}*/
|
||||||
|
|
||||||
|
void CTouchControls::GetTouchAccumulators( float *side, float *forward, float *yaw, float *pitch )
|
||||||
|
{
|
||||||
|
*forward = this->forward;
|
||||||
|
*side = this->side;
|
||||||
|
*pitch = this->pitch;
|
||||||
|
*yaw = this->yaw;
|
||||||
|
this->yaw = 0.f;
|
||||||
|
this->pitch = 0.f;
|
||||||
|
}
|
||||||
|
|
||||||
|
void CTouchControls::GetTouchDelta( float yaw, float pitch, float *dx, float *dy )
|
||||||
|
{
|
||||||
|
// Apply filtering?
|
||||||
|
if( touch_filter.GetBool() )
|
||||||
|
{
|
||||||
|
// Average over last two samples
|
||||||
|
*dx = ( yaw + m_flPreviousYaw ) * 0.5f;
|
||||||
|
*dy = ( pitch + m_flPreviousPitch ) * 0.5f;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
*dx = yaw;
|
||||||
|
*dy = pitch;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Latch previous
|
||||||
|
m_flPreviousYaw = yaw;
|
||||||
|
m_flPreviousPitch = pitch;
|
||||||
|
}
|
||||||
|
|
||||||
void CTouchControls::ResetToDefaults()
|
void CTouchControls::ResetToDefaults()
|
||||||
{
|
{
|
||||||
rgba_t color(255, 255, 255, 155);
|
rgba_t color(255, 255, 255, 155);
|
||||||
@ -291,7 +323,7 @@ void CTouchControls::ResetToDefaults()
|
|||||||
else
|
else
|
||||||
{
|
{
|
||||||
Q_snprintf(buf, sizeof buf, "exec %s", TOUCH_DEFAULT_CFG);
|
Q_snprintf(buf, sizeof buf, "exec %s", TOUCH_DEFAULT_CFG);
|
||||||
engine->ClientCmd_Unrestricted(buf);
|
engine->ExecuteClientCmd(buf);
|
||||||
}
|
}
|
||||||
|
|
||||||
WriteConfig();
|
WriteConfig();
|
||||||
@ -307,7 +339,8 @@ void CTouchControls::Init()
|
|||||||
config_loaded = false;
|
config_loaded = false;
|
||||||
btns.EnsureCapacity( 64 );
|
btns.EnsureCapacity( 64 );
|
||||||
look_finger = move_finger = resize_finger = -1;
|
look_finger = move_finger = resize_finger = -1;
|
||||||
forward = side = 0;
|
forward = side = 0.f;
|
||||||
|
pitch = yaw = 0.f;
|
||||||
scolor = rgba_t( -1, -1, -1, -1 );
|
scolor = rgba_t( -1, -1, -1, -1 );
|
||||||
state = state_none;
|
state = state_none;
|
||||||
swidth = 1;
|
swidth = 1;
|
||||||
@ -317,6 +350,7 @@ void CTouchControls::Init()
|
|||||||
precision = false;
|
precision = false;
|
||||||
mouse_events = 0;
|
mouse_events = 0;
|
||||||
move_start_x = move_start_y = 0.0f;
|
move_start_x = move_start_y = 0.0f;
|
||||||
|
m_flPreviousYaw = m_flPreviousPitch = 0.f;
|
||||||
|
|
||||||
showtexture = hidetexture = resettexture = closetexture = joytexture = 0;
|
showtexture = hidetexture = resettexture = closetexture = joytexture = 0;
|
||||||
configchanged = false;
|
configchanged = false;
|
||||||
@ -344,12 +378,15 @@ void CTouchControls::Init()
|
|||||||
AddButton( "menu", "vgui/touch/menu", "gameui_activate", 0.000000, 0.00000, 0.080000, 0.142222, color );
|
AddButton( "menu", "vgui/touch/menu", "gameui_activate", 0.000000, 0.00000, 0.080000, 0.142222, color );
|
||||||
|
|
||||||
char buf[256];
|
char buf[256];
|
||||||
Q_snprintf(buf, sizeof buf, "exec %s\n", touch_config_file.GetString());
|
|
||||||
engine->ClientCmd_Unrestricted(buf);
|
|
||||||
|
|
||||||
Q_snprintf(buf, sizeof buf, "cfg/%s", touch_config_file.GetString());
|
Q_snprintf(buf, sizeof buf, "cfg/%s", touch_config_file.GetString());
|
||||||
if( !filesystem->FileExists(buf) )
|
if( filesystem->FileExists(buf, "MOD") )
|
||||||
WriteConfig();
|
{
|
||||||
|
Q_snprintf(buf, sizeof buf, "exec %s\n", touch_config_file.GetString());
|
||||||
|
engine->ClientCmd_Unrestricted(buf);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
ResetToDefaults();
|
||||||
|
|
||||||
initialized = true;
|
initialized = true;
|
||||||
}
|
}
|
||||||
@ -405,32 +442,10 @@ void CTouchControls::IN_CheckCoords( float *x1, float *y1, float *x2, float *y2
|
|||||||
|
|
||||||
void CTouchControls::Move( float /*frametime*/, CUserCmd *cmd )
|
void CTouchControls::Move( float /*frametime*/, CUserCmd *cmd )
|
||||||
{
|
{
|
||||||
cmd->sidemove -= cl_sidespeed.GetFloat() * side;
|
|
||||||
cmd->forwardmove += cl_forwardspeed.GetFloat() * forward;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void CTouchControls::IN_Look()
|
void CTouchControls::IN_Look()
|
||||||
{
|
{
|
||||||
C_BasePlayer *pl = C_BasePlayer::GetLocalPlayer();
|
|
||||||
|
|
||||||
float diff = 1.0f;
|
|
||||||
if( pl )
|
|
||||||
{
|
|
||||||
float def_fov = default_fov.GetFloat();
|
|
||||||
float fov = pl->GetFOV();
|
|
||||||
diff = fov/def_fov;
|
|
||||||
}
|
|
||||||
|
|
||||||
if( !pitch && !yaw )
|
|
||||||
return;
|
|
||||||
|
|
||||||
|
|
||||||
QAngle ang;
|
|
||||||
engine->GetViewAngles( ang );
|
|
||||||
ang.x += pitch*diff;
|
|
||||||
ang.y += yaw*diff;
|
|
||||||
engine->SetViewAngles( ang );
|
|
||||||
pitch = yaw = 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void CTouchControls::Frame()
|
void CTouchControls::Frame()
|
||||||
@ -438,9 +453,7 @@ void CTouchControls::Frame()
|
|||||||
if (!initialized)
|
if (!initialized)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
IN_Look();
|
if( touch_enable.GetBool() && touch_draw.GetBool() && !enginevgui->IsGameUIVisible() ) Paint();
|
||||||
|
|
||||||
if( touch_enable.GetBool() && !enginevgui->IsGameUIVisible() ) Paint();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void CTouchControls::Paint( )
|
void CTouchControls::Paint( )
|
||||||
@ -448,7 +461,6 @@ void CTouchControls::Paint( )
|
|||||||
if (!initialized)
|
if (!initialized)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
|
||||||
if( state == state_edit )
|
if( state == state_edit )
|
||||||
{
|
{
|
||||||
vgui::surface()->DrawSetColor(255, 0, 0, 200);
|
vgui::surface()->DrawSetColor(255, 0, 0, 200);
|
||||||
@ -694,8 +706,8 @@ void CTouchControls::FingerMotion(touch_event_t *ev) // finger in my ass
|
|||||||
}
|
}
|
||||||
else if( btn->type == touch_look )
|
else if( btn->type == touch_look )
|
||||||
{
|
{
|
||||||
yaw -= touch_yaw.GetFloat() * ev->dx * sensitivity.GetFloat();
|
yaw += ev->dx;
|
||||||
pitch += touch_pitch.GetFloat() * ev->dy * sensitivity.GetFloat();
|
pitch += ev->dy;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -178,20 +178,21 @@ public:
|
|||||||
void IN_CheckCoords( float *x1, float *y1, float *x2, float *y2 );
|
void IN_CheckCoords( float *x1, float *y1, float *x2, float *y2 );
|
||||||
void InitGrid();
|
void InitGrid();
|
||||||
|
|
||||||
|
|
||||||
void Move( float frametime, CUserCmd *cmd );
|
void Move( float frametime, CUserCmd *cmd );
|
||||||
void IN_Look( );
|
void IN_Look( );
|
||||||
|
|
||||||
void ProcessEvent( touch_event_t *ev );
|
void ProcessEvent( touch_event_t *ev );
|
||||||
void FingerPress( touch_event_t *ev );
|
void FingerPress( touch_event_t *ev );
|
||||||
void FingerMotion( touch_event_t *ev );
|
void FingerMotion( touch_event_t *ev );
|
||||||
|
void GetTouchAccumulators( float *forward, float *side, float *yaw, float *pitch );
|
||||||
|
void GetTouchDelta( float yaw, float pitch, float *dx, float *dy );
|
||||||
void EditEvent( touch_event_t *ev );
|
void EditEvent( touch_event_t *ev );
|
||||||
|
|
||||||
void EnableTouchEdit(bool enable);
|
void EnableTouchEdit(bool enable);
|
||||||
|
|
||||||
CTouchPanel *touchPanel;
|
CTouchPanel *touchPanel;
|
||||||
float screen_h, screen_w;
|
float screen_h, screen_w;
|
||||||
|
float forward, side, movecount;
|
||||||
|
float yaw, pitch;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
bool initialized = false;
|
bool initialized = false;
|
||||||
@ -199,11 +200,10 @@ private:
|
|||||||
CUtlLinkedList<CTouchButton*> btns;
|
CUtlLinkedList<CTouchButton*> btns;
|
||||||
|
|
||||||
int look_finger, move_finger, wheel_finger;
|
int look_finger, move_finger, wheel_finger;
|
||||||
float forward, side, movecount;
|
|
||||||
float yaw, pitch;
|
|
||||||
CTouchButton *move_button;
|
CTouchButton *move_button;
|
||||||
|
|
||||||
float move_start_x, move_start_y;
|
float move_start_x, move_start_y;
|
||||||
|
float m_flPreviousYaw, m_flPreviousPitch;
|
||||||
|
|
||||||
// editing
|
// editing
|
||||||
CTouchButton *edit;
|
CTouchButton *edit;
|
||||||
|
@ -15,6 +15,7 @@ games = {
|
|||||||
'hl2': ['client_base.vpc', 'client_hl2.vpc'],
|
'hl2': ['client_base.vpc', 'client_hl2.vpc'],
|
||||||
'hl2mp': ['client_base.vpc', 'client_hl2mp.vpc'],
|
'hl2mp': ['client_base.vpc', 'client_hl2mp.vpc'],
|
||||||
'hl1': ['client_base.vpc', 'client_hl1.vpc'],
|
'hl1': ['client_base.vpc', 'client_hl1.vpc'],
|
||||||
|
'episodic': ['client_base.vpc', 'client_episodic.vpc'],
|
||||||
'portal': ['client_base.vpc', 'client_portal.vpc'],
|
'portal': ['client_base.vpc', 'client_portal.vpc'],
|
||||||
'hl1mp': ['client_base.vpc', 'client_hl1.vpc'],
|
'hl1mp': ['client_base.vpc', 'client_hl1.vpc'],
|
||||||
'cstrike': ['client_base.vpc', 'client_cstrike.vpc'],
|
'cstrike': ['client_base.vpc', 'client_cstrike.vpc'],
|
||||||
@ -25,6 +26,8 @@ def configure(conf):
|
|||||||
game = conf.options.GAMES
|
game = conf.options.GAMES
|
||||||
conf.env.GAMES = game
|
conf.env.GAMES = game
|
||||||
|
|
||||||
|
conf.env.append_unique('DEFINES', ['DISABLE_STEAM=1'])
|
||||||
|
|
||||||
if game not in games.keys():
|
if game not in games.keys():
|
||||||
conf.fatal("Couldn't find game: ", game)
|
conf.fatal("Couldn't find game: ", game)
|
||||||
|
|
||||||
@ -66,7 +69,7 @@ def build(bld):
|
|||||||
if bld.env.DEST_OS != 'android':
|
if bld.env.DEST_OS != 'android':
|
||||||
install_path += '/'+bld.env.GAMES+'/bin'
|
install_path += '/'+bld.env.GAMES+'/bin'
|
||||||
|
|
||||||
source = [ 'touch.cpp' ]
|
source = [ 'touch.cpp', 'in_touch.cpp' ]
|
||||||
|
|
||||||
source += game["sources"]
|
source += game["sources"]
|
||||||
includes += game["includes"]
|
includes += game["includes"]
|
||||||
|
@ -22,6 +22,7 @@
|
|||||||
#include "KeyValues.h"
|
#include "KeyValues.h"
|
||||||
#include "OptionsSubKeyboard.h"
|
#include "OptionsSubKeyboard.h"
|
||||||
#include "OptionsSubMouse.h"
|
#include "OptionsSubMouse.h"
|
||||||
|
#include "OptionsSubTouch.h"
|
||||||
#include "OptionsSubAudio.h"
|
#include "OptionsSubAudio.h"
|
||||||
#include "OptionsSubVideo.h"
|
#include "OptionsSubVideo.h"
|
||||||
#include "OptionsSubVoice.h"
|
#include "OptionsSubVoice.h"
|
||||||
@ -86,6 +87,10 @@ COptionsDialog::COptionsDialog(vgui::Panel *parent) : PropertyDialog(parent, "Op
|
|||||||
AddPage(new COptionsSubKeyboard(this), "#GameUI_Keyboard");
|
AddPage(new COptionsSubKeyboard(this), "#GameUI_Keyboard");
|
||||||
AddPage(new COptionsSubMouse(this), "#GameUI_Mouse");
|
AddPage(new COptionsSubMouse(this), "#GameUI_Mouse");
|
||||||
|
|
||||||
|
#ifdef ANDROID
|
||||||
|
AddPage(new COptionsSubTouch(this), "Touch");
|
||||||
|
#endif
|
||||||
|
|
||||||
m_pOptionsSubAudio = new COptionsSubAudio(this);
|
m_pOptionsSubAudio = new COptionsSubAudio(this);
|
||||||
AddPage(m_pOptionsSubAudio, "#GameUI_Audio");
|
AddPage(m_pOptionsSubAudio, "#GameUI_Audio");
|
||||||
m_pOptionsSubVideo = new COptionsSubVideo(this);
|
m_pOptionsSubVideo = new COptionsSubVideo(this);
|
||||||
|
220
gameui/OptionsSubTouch.cpp
Normal file
220
gameui/OptionsSubTouch.cpp
Normal file
@ -0,0 +1,220 @@
|
|||||||
|
//========= Copyright Valve Corporation, All rights reserved. ============//
|
||||||
|
//
|
||||||
|
// Purpose:
|
||||||
|
//
|
||||||
|
// $NoKeywords: $
|
||||||
|
//
|
||||||
|
//=============================================================================//
|
||||||
|
#include "OptionsSubTouch.h"
|
||||||
|
//#include "CommandCheckButton.h"
|
||||||
|
#include "KeyToggleCheckButton.h"
|
||||||
|
#include "CvarNegateCheckButton.h"
|
||||||
|
#include "CvarToggleCheckButton.h"
|
||||||
|
#include "cvarslider.h"
|
||||||
|
|
||||||
|
#include "EngineInterface.h"
|
||||||
|
|
||||||
|
#include <KeyValues.h>
|
||||||
|
#include <vgui/IScheme.h>
|
||||||
|
#include "tier1/convar.h"
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <vgui_controls/TextEntry.h>
|
||||||
|
// memdbgon must be the last include file in a .cpp file!!!
|
||||||
|
#include <tier0/memdbgon.h>
|
||||||
|
|
||||||
|
using namespace vgui;
|
||||||
|
|
||||||
|
COptionsSubTouch::COptionsSubTouch(vgui::Panel *parent) : PropertyPage(parent, NULL)
|
||||||
|
{
|
||||||
|
m_pTouchEnableCheckBox = new CCvarToggleCheckButton(this,
|
||||||
|
"EnableTouch",
|
||||||
|
"Enable touch",
|
||||||
|
"touch_enable");
|
||||||
|
|
||||||
|
m_pTouchDrawCheckBox = new CCvarToggleCheckButton(this,
|
||||||
|
"DrawTouch",
|
||||||
|
"Draw touch",
|
||||||
|
"touch_draw");
|
||||||
|
|
||||||
|
m_pReverseTouchCheckBox = new CCvarToggleCheckButton(
|
||||||
|
this,
|
||||||
|
"ReverseTouch",
|
||||||
|
"Reverse touch",
|
||||||
|
"touch_reverse" );
|
||||||
|
|
||||||
|
m_pTouchFilterCheckBox = new CCvarToggleCheckButton(
|
||||||
|
this,
|
||||||
|
"TouchFilter",
|
||||||
|
"Touch filter",
|
||||||
|
"touch_filter" );
|
||||||
|
|
||||||
|
m_pTouchAccelerationCheckBox = new CCvarToggleCheckButton(
|
||||||
|
this,
|
||||||
|
"TouchAccelerationCheckbox",
|
||||||
|
"Touch acceleration",
|
||||||
|
"touch_enable_accel" );
|
||||||
|
|
||||||
|
m_pTouchSensitivitySlider = new CCvarSlider( this, "Slider", "Touch sensitivity",
|
||||||
|
0.1f, 6.0f, "touch_sensitivity", true );
|
||||||
|
|
||||||
|
m_pTouchSensitivityLabel = new TextEntry(this, "SensitivityLabel");
|
||||||
|
m_pTouchSensitivityLabel->AddActionSignalTarget(this);
|
||||||
|
|
||||||
|
m_pTouchAccelExponentSlider = new CCvarSlider( this, "TouchAccelerationSlider", "Touch acceleration",
|
||||||
|
1.0f, 1.5f, "touch_accel", true );
|
||||||
|
|
||||||
|
m_pTouchAccelExponentLabel = new TextEntry(this, "TouchAccelerationLabel");
|
||||||
|
m_pTouchAccelExponentLabel->AddActionSignalTarget(this);
|
||||||
|
|
||||||
|
m_pTouchYawSensitivitySlider = new CCvarSlider( this, "TouchYawSlider", "#GameUI_JoystickYawSensitivity",
|
||||||
|
50.f, 300.f, "touch_yaw", true );
|
||||||
|
m_pTouchYawSensitivityPreLabel = new Label(this, "TouchYawSensitivityPreLabel", "#GameUI_JoystickLookSpeedYaw" );
|
||||||
|
m_pTouchYawSensitivityLabel = new TextEntry(this, "TouchYawSensitivityLabel");
|
||||||
|
m_pTouchYawSensitivityLabel->AddActionSignalTarget(this);
|
||||||
|
|
||||||
|
m_pTouchPitchSensitivitySlider = new CCvarSlider( this, "TouchPitchSlider", "#GameUI_JoystickPitchSensitivity",
|
||||||
|
50.f, 300.f, "touch_pitch", true );
|
||||||
|
m_pTouchPitchSensitivityPreLabel = new Label(this, "TouchPitchSensitivityPreLabel", "#GameUI_JoystickLookSpeedPitch" );
|
||||||
|
m_pTouchPitchSensitivityLabel = new TextEntry(this, "TouchPitchSensitivityLabel");
|
||||||
|
m_pTouchPitchSensitivityLabel->AddActionSignalTarget(this);
|
||||||
|
|
||||||
|
LoadControlSettings("Resource\\OptionsSubTouch.res");
|
||||||
|
|
||||||
|
UpdateLabel(m_pTouchSensitivitySlider, m_pTouchSensitivityLabel);
|
||||||
|
UpdateLabel(m_pTouchAccelExponentSlider, m_pTouchAccelExponentLabel);
|
||||||
|
UpdateLabel(m_pTouchYawSensitivitySlider, m_pTouchYawSensitivityLabel);
|
||||||
|
UpdateLabel(m_pTouchPitchSensitivitySlider, m_pTouchPitchSensitivityLabel);
|
||||||
|
}
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// Purpose:
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
COptionsSubTouch::~COptionsSubTouch()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// Purpose:
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
void COptionsSubTouch::OnResetData()
|
||||||
|
{
|
||||||
|
m_pReverseTouchCheckBox->Reset();
|
||||||
|
m_pTouchFilterCheckBox->Reset();
|
||||||
|
m_pTouchSensitivitySlider->Reset();
|
||||||
|
m_pTouchAccelExponentSlider->Reset();
|
||||||
|
m_pTouchYawSensitivitySlider->Reset();
|
||||||
|
m_pTouchPitchSensitivitySlider->Reset();
|
||||||
|
m_pTouchAccelerationCheckBox->Reset();
|
||||||
|
}
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// Purpose:
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
void COptionsSubTouch::OnApplyChanges()
|
||||||
|
{
|
||||||
|
m_pReverseTouchCheckBox->ApplyChanges();
|
||||||
|
m_pTouchFilterCheckBox->ApplyChanges();
|
||||||
|
m_pTouchSensitivitySlider->ApplyChanges();
|
||||||
|
m_pTouchAccelExponentSlider->ApplyChanges();
|
||||||
|
m_pTouchYawSensitivitySlider->ApplyChanges();
|
||||||
|
m_pTouchPitchSensitivitySlider->ApplyChanges();
|
||||||
|
m_pTouchEnableCheckBox->ApplyChanges();
|
||||||
|
m_pTouchDrawCheckBox->ApplyChanges();
|
||||||
|
m_pTouchAccelerationCheckBox->ApplyChanges();
|
||||||
|
}
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// Purpose: sets background color & border
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
void COptionsSubTouch::ApplySchemeSettings(IScheme *pScheme)
|
||||||
|
{
|
||||||
|
BaseClass::ApplySchemeSettings(pScheme);
|
||||||
|
}
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// Purpose:
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
void COptionsSubTouch::OnControlModified(Panel *panel)
|
||||||
|
{
|
||||||
|
PostActionSignal(new KeyValues("ApplyButtonEnable"));
|
||||||
|
|
||||||
|
// the HasBeenModified() check is so that if the value is outside of the range of the
|
||||||
|
// slider, it won't use the slider to determine the display value but leave the
|
||||||
|
// real value that we determined in the constructor
|
||||||
|
if (panel == m_pTouchSensitivitySlider && m_pTouchSensitivitySlider->HasBeenModified())
|
||||||
|
UpdateLabel( m_pTouchSensitivitySlider, m_pTouchSensitivityLabel );
|
||||||
|
else if (panel == m_pTouchAccelExponentSlider && m_pTouchAccelExponentSlider->HasBeenModified())
|
||||||
|
UpdateLabel( m_pTouchAccelExponentSlider, m_pTouchAccelExponentLabel );
|
||||||
|
else if (panel == m_pTouchYawSensitivitySlider && m_pTouchYawSensitivitySlider->HasBeenModified())
|
||||||
|
UpdateLabel( m_pTouchYawSensitivitySlider, m_pTouchYawSensitivityLabel );
|
||||||
|
else if (panel == m_pTouchPitchSensitivitySlider && m_pTouchPitchSensitivitySlider->HasBeenModified())
|
||||||
|
UpdateLabel( m_pTouchPitchSensitivitySlider, m_pTouchPitchSensitivityLabel );
|
||||||
|
else if (panel == m_pTouchAccelerationCheckBox)
|
||||||
|
{
|
||||||
|
m_pTouchAccelExponentSlider->SetEnabled(m_pTouchAccelerationCheckBox->IsSelected());
|
||||||
|
m_pTouchAccelExponentLabel->SetEnabled(m_pTouchAccelerationCheckBox->IsSelected());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// Purpose:
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
void COptionsSubTouch::OnTextChanged(Panel *panel)
|
||||||
|
{
|
||||||
|
if ( panel == m_pTouchSensitivityLabel )
|
||||||
|
{
|
||||||
|
char buf[64];
|
||||||
|
m_pTouchSensitivityLabel->GetText(buf, 64);
|
||||||
|
|
||||||
|
float fValue;
|
||||||
|
int numParsed = sscanf(buf, "%f", &fValue);
|
||||||
|
if ( ( numParsed == 1 ) && ( fValue >= 0.0f ) )
|
||||||
|
{
|
||||||
|
m_pTouchSensitivitySlider->SetSliderValue(fValue);
|
||||||
|
PostActionSignal(new KeyValues("ApplyButtonEnable"));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if ( panel == m_pTouchAccelExponentLabel )
|
||||||
|
{
|
||||||
|
char buf[64];
|
||||||
|
m_pTouchAccelExponentLabel->GetText(buf, 64);
|
||||||
|
|
||||||
|
float fValue = (float) atof(buf);
|
||||||
|
if (fValue >= 1.0)
|
||||||
|
{
|
||||||
|
m_pTouchAccelExponentSlider->SetSliderValue(fValue);
|
||||||
|
PostActionSignal(new KeyValues("ApplyButtonEnable"));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if( panel == m_pTouchPitchSensitivityLabel )
|
||||||
|
{
|
||||||
|
char buf[64];
|
||||||
|
m_pTouchPitchSensitivityLabel->GetText(buf, 64);
|
||||||
|
|
||||||
|
float fValue = (float) atof(buf);
|
||||||
|
if (fValue >= 1.0)
|
||||||
|
{
|
||||||
|
m_pTouchPitchSensitivitySlider->SetSliderValue(fValue);
|
||||||
|
PostActionSignal(new KeyValues("ApplyButtonEnable"));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if( panel == m_pTouchYawSensitivityLabel )
|
||||||
|
{
|
||||||
|
char buf[64];
|
||||||
|
m_pTouchYawSensitivityLabel->GetText(buf, 64);
|
||||||
|
|
||||||
|
float fValue = (float) atof(buf);
|
||||||
|
if (fValue >= 1.0)
|
||||||
|
{
|
||||||
|
m_pTouchYawSensitivitySlider->SetSliderValue(fValue);
|
||||||
|
PostActionSignal(new KeyValues("ApplyButtonEnable"));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void COptionsSubTouch::UpdateLabel(CCvarSlider *slider, vgui::TextEntry *label)
|
||||||
|
{
|
||||||
|
char buf[64];
|
||||||
|
Q_snprintf(buf, sizeof( buf ), " %.2f", slider->GetSliderValue());
|
||||||
|
label->SetText(buf);
|
||||||
|
}
|
81
gameui/OptionsSubTouch.h
Normal file
81
gameui/OptionsSubTouch.h
Normal file
@ -0,0 +1,81 @@
|
|||||||
|
//========= Copyright Valve Corporation, All rights reserved. ============//
|
||||||
|
//
|
||||||
|
// Purpose:
|
||||||
|
//
|
||||||
|
// $NoKeywords: $
|
||||||
|
//=============================================================================//
|
||||||
|
|
||||||
|
#ifndef OPTIONS_SUB_TOUCH_H
|
||||||
|
#define OPTIONS_SUB_TOUCH_H
|
||||||
|
#ifdef _WIN32
|
||||||
|
#pragma once
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include <vgui_controls/PropertyPage.h>
|
||||||
|
|
||||||
|
class CCvarNegateCheckButton;
|
||||||
|
class CKeyToggleCheckButton;
|
||||||
|
class CCvarToggleCheckButton;
|
||||||
|
class CCvarSlider;
|
||||||
|
|
||||||
|
namespace vgui
|
||||||
|
{
|
||||||
|
class Label;
|
||||||
|
class Panel;
|
||||||
|
}
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// Purpose: Touch Details, Part of OptionsDialog
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
class COptionsSubTouch : public vgui::PropertyPage
|
||||||
|
{
|
||||||
|
DECLARE_CLASS_SIMPLE( COptionsSubTouch, vgui::PropertyPage );
|
||||||
|
|
||||||
|
public:
|
||||||
|
COptionsSubTouch(vgui::Panel *parent);
|
||||||
|
~COptionsSubTouch();
|
||||||
|
|
||||||
|
virtual void OnResetData();
|
||||||
|
virtual void OnApplyChanges();
|
||||||
|
|
||||||
|
protected:
|
||||||
|
virtual void ApplySchemeSettings(vgui::IScheme *pScheme);
|
||||||
|
|
||||||
|
MESSAGE_FUNC_PTR( OnControlModified, "ControlModified", panel );
|
||||||
|
MESSAGE_FUNC_PTR( OnTextChanged, "TextChanged", panel );
|
||||||
|
MESSAGE_FUNC_PTR( OnCheckButtonChecked, "CheckButtonChecked", panel )
|
||||||
|
{
|
||||||
|
OnControlModified( panel );
|
||||||
|
}
|
||||||
|
|
||||||
|
void UpdateLabel(CCvarSlider *slider, vgui::TextEntry *label);
|
||||||
|
private:
|
||||||
|
CCvarToggleCheckButton *m_pReverseTouchCheckBox;
|
||||||
|
CCvarToggleCheckButton *m_pTouchFilterCheckBox;
|
||||||
|
CCvarToggleCheckButton *m_pTouchRawCheckBox;
|
||||||
|
CCvarToggleCheckButton *m_pTouchAccelerationCheckBox;
|
||||||
|
|
||||||
|
CCvarToggleCheckButton *m_pTouchCheckBox;
|
||||||
|
CCvarToggleCheckButton *m_pTouchSouthpawCheckBox;
|
||||||
|
CCvarToggleCheckButton *m_pQuickInfoCheckBox;
|
||||||
|
CCvarToggleCheckButton *m_pTouchEnableCheckBox;
|
||||||
|
CCvarToggleCheckButton *m_pTouchDrawCheckBox;
|
||||||
|
|
||||||
|
CCvarSlider *m_pTouchSensitivitySlider;
|
||||||
|
vgui::TextEntry *m_pTouchSensitivityLabel;
|
||||||
|
|
||||||
|
CCvarSlider *m_pTouchAccelExponentSlider;
|
||||||
|
vgui::TextEntry *m_pTouchAccelExponentLabel;
|
||||||
|
|
||||||
|
CCvarSlider *m_pTouchYawSensitivitySlider;
|
||||||
|
vgui::Label *m_pTouchYawSensitivityPreLabel;
|
||||||
|
CCvarSlider *m_pTouchPitchSensitivitySlider;
|
||||||
|
vgui::Label *m_pTouchPitchSensitivityPreLabel;
|
||||||
|
vgui::TextEntry *m_pTouchYawSensitivityLabel;
|
||||||
|
vgui::TextEntry *m_pTouchPitchSensitivityLabel;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#endif // OPTIONS_SUB_TOUCH_H
|
@ -91,6 +91,7 @@ def build(bld):
|
|||||||
#'OptionsSubHaptics.cpp', [$WIN32] [$WIN32]
|
#'OptionsSubHaptics.cpp', [$WIN32] [$WIN32]
|
||||||
'OptionsSubKeyboard.cpp',
|
'OptionsSubKeyboard.cpp',
|
||||||
'OptionsSubMouse.cpp',
|
'OptionsSubMouse.cpp',
|
||||||
|
'OptionsSubTouch.cpp',
|
||||||
'OptionsSubMultiplayer.cpp',
|
'OptionsSubMultiplayer.cpp',
|
||||||
'OptionsSubPortal.cpp',
|
'OptionsSubPortal.cpp',
|
||||||
'OptionsSubVideo.cpp',
|
'OptionsSubVideo.cpp',
|
||||||
|
@ -113,7 +113,6 @@ void SetLauncherArgs()
|
|||||||
LogPrintf(binPath);
|
LogPrintf(binPath);
|
||||||
D(binPath);
|
D(binPath);
|
||||||
|
|
||||||
D("-console");
|
|
||||||
D("-nouserclip");
|
D("-nouserclip");
|
||||||
|
|
||||||
parseArgs(java_args);
|
parseArgs(java_args);
|
||||||
|
Loading…
Reference in New Issue
Block a user