mirror of
https://github.com/dolphin-emu/dolphin.git
synced 2025-01-26 12:35:27 +00:00
Add wiimote tas input.
This commit is contained in:
parent
0d768bd55e
commit
c41b31d3ff
@ -110,7 +110,7 @@ bool CSIDevice_DanceMat::GetData(u32& _Hi, u32& _Low)
|
||||
memset(&PadStatus, 0, sizeof(PadStatus));
|
||||
|
||||
Pad::GetStatus(ISIDevice::m_iDeviceNumber, &PadStatus);
|
||||
Movie::CallInputManip(&PadStatus, ISIDevice::m_iDeviceNumber);
|
||||
Movie::CallGCInputManip(&PadStatus, ISIDevice::m_iDeviceNumber);
|
||||
|
||||
u32 netValues[2];
|
||||
if (NetPlay_GetInput(ISIDevice::m_iDeviceNumber, PadStatus, netValues))
|
||||
|
@ -110,7 +110,7 @@ bool CSIDevice_GCController::GetData(u32& _Hi, u32& _Low)
|
||||
memset(&PadStatus, 0, sizeof(PadStatus));
|
||||
|
||||
Pad::GetStatus(ISIDevice::m_iDeviceNumber, &PadStatus);
|
||||
Movie::CallInputManip(&PadStatus, ISIDevice::m_iDeviceNumber);
|
||||
Movie::CallGCInputManip(&PadStatus, ISIDevice::m_iDeviceNumber);
|
||||
|
||||
u32 netValues[2];
|
||||
if (NetPlay_GetInput(ISIDevice::m_iDeviceNumber, PadStatus, netValues))
|
||||
|
@ -101,7 +101,7 @@ bool CSIDevice_GCSteeringWheel::GetData(u32& _Hi, u32& _Low)
|
||||
memset(&PadStatus, 0, sizeof(PadStatus));
|
||||
|
||||
Pad::GetStatus(ISIDevice::m_iDeviceNumber, &PadStatus);
|
||||
Movie::CallInputManip(&PadStatus, ISIDevice::m_iDeviceNumber);
|
||||
Movie::CallGCInputManip(&PadStatus, ISIDevice::m_iDeviceNumber);
|
||||
|
||||
u32 netValues[2];
|
||||
if (NetPlay_GetInput(ISIDevice::m_iDeviceNumber, PadStatus, netValues))
|
||||
|
@ -517,18 +517,18 @@ void Wiimote::GetIRData(u8* const data, bool use_accel)
|
||||
{
|
||||
if (x[i*2] < 1024 && y[i*2] < 768)
|
||||
{
|
||||
irdata[i].x1 = u8(x[i*2]);
|
||||
irdata[i].x1 = static_cast<u8>(x[i*2]);
|
||||
irdata[i].x1hi = x[i*2] >> 8;
|
||||
|
||||
irdata[i].y1 = u8(y[i*2]);
|
||||
irdata[i].y1 = static_cast<u8>(y[i*2]);
|
||||
irdata[i].y1hi = y[i*2] >> 8;
|
||||
}
|
||||
if (x[i*2+1] < 1024 && y[i*2+1] < 768)
|
||||
{
|
||||
irdata[i].x2 = u8(x[i*2+1]);
|
||||
irdata[i].x2 = static_cast<u8>(x[i*2+1]);
|
||||
irdata[i].x2hi = x[i*2+1] >> 8;
|
||||
|
||||
irdata[i].y2 = u8(y[i*2+1]);
|
||||
irdata[i].y2 = static_cast<u8>(y[i*2+1]);
|
||||
irdata[i].y2hi = y[i*2+1] >> 8;
|
||||
}
|
||||
}
|
||||
@ -542,10 +542,10 @@ void Wiimote::GetIRData(u8* const data, bool use_accel)
|
||||
for (unsigned int i = 0; i < 4; ++i)
|
||||
if (x[i] < 1024 && y[i] < 768)
|
||||
{
|
||||
irdata[i].x = u8(x[i]);
|
||||
irdata[i].x = static_cast<u8>(x[i]);
|
||||
irdata[i].xhi = x[i] >> 8;
|
||||
|
||||
irdata[i].y = u8(y[i]);
|
||||
irdata[i].y = static_cast<u8>(y[i]);
|
||||
irdata[i].yhi = y[i] >> 8;
|
||||
|
||||
irdata[i].size = 10;
|
||||
@ -729,6 +729,8 @@ void Wiimote::Update()
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Movie::CallWiiInputManip(data, rptf, m_index);
|
||||
}
|
||||
if (NetPlay::IsNetPlayRunning())
|
||||
{
|
||||
|
@ -81,7 +81,8 @@ static std::string tmpStateFilename = File::GetUserPath(D_STATESAVES_IDX) + "dtm
|
||||
|
||||
static std::string s_InputDisplay[8];
|
||||
|
||||
static ManipFunction mfunc = nullptr;
|
||||
static GCManipFunction gcmfunc = nullptr;
|
||||
static WiiManipFunction wiimfunc = nullptr;
|
||||
|
||||
static void EnsureTmpInputSize(size_t bound)
|
||||
{
|
||||
@ -631,8 +632,8 @@ static void SetWiiInputDisplayString(int remoteID, u8* const data, const Wiimote
|
||||
if (irData)
|
||||
{
|
||||
u16 x = irData[0] | ((irData[2] >> 4 & 0x3) << 8);
|
||||
u16 y = irData[1] | ((irData[2] >> 2 & 0x3) << 8);
|
||||
std::string ir = StringFromFormat(" IR:%d,%d", x, y);
|
||||
u16 y = irData[1] | ((irData[2] >> 6 & 0x3) << 8);
|
||||
std::string ir = StringFromFormat(" IR:%d,%d", x,y);
|
||||
s_InputDisplay[controllerID].append(ir);
|
||||
}
|
||||
|
||||
@ -1245,15 +1246,24 @@ void SaveRecording(const std::string& filename)
|
||||
Core::DisplayMessage(StringFromFormat("Failed to save %s", filename.c_str()), 2000);
|
||||
}
|
||||
|
||||
void SetInputManip(ManipFunction func)
|
||||
void SetGCInputManip(GCManipFunction func)
|
||||
{
|
||||
mfunc = func;
|
||||
gcmfunc = func;
|
||||
}
|
||||
void SetWiiInputManip(WiiManipFunction func)
|
||||
{
|
||||
wiimfunc = func;
|
||||
}
|
||||
|
||||
void CallInputManip(GCPadStatus* PadStatus, int controllerID)
|
||||
void CallGCInputManip(GCPadStatus* PadStatus, int controllerID)
|
||||
{
|
||||
if (mfunc)
|
||||
(*mfunc)(PadStatus, controllerID);
|
||||
if (gcmfunc)
|
||||
(*gcmfunc)(PadStatus, controllerID);
|
||||
}
|
||||
void CallWiiInputManip(u8* data, WiimoteEmu::ReportFeatures rptf, int controllerID)
|
||||
{
|
||||
if (wiimfunc)
|
||||
(*wiimfunc)(data, rptf, controllerID);
|
||||
}
|
||||
|
||||
void SetGraphicsConfig()
|
||||
|
@ -176,8 +176,11 @@ void CheckWiimoteStatus(int wiimote, u8* data, const struct WiimoteEmu::ReportFe
|
||||
std::string GetInputDisplay();
|
||||
|
||||
// Done this way to avoid mixing of core and gui code
|
||||
typedef void(*ManipFunction)(GCPadStatus*, int);
|
||||
typedef void(*GCManipFunction)(GCPadStatus*, int);
|
||||
typedef void(*WiiManipFunction)(u8*, WiimoteEmu::ReportFeatures, int);
|
||||
|
||||
void SetInputManip(ManipFunction);
|
||||
void CallInputManip(GCPadStatus* PadStatus, int controllerID);
|
||||
void SetGCInputManip(GCManipFunction);
|
||||
void SetWiiInputManip(WiiManipFunction);
|
||||
void CallGCInputManip(GCPadStatus* PadStatus, int controllerID);
|
||||
void CallWiiInputManip(u8* core, WiimoteEmu::ReportFeatures rptf, int controllerID);
|
||||
}
|
||||
|
@ -398,12 +398,11 @@ CFrame::CFrame(wxFrame* parent,
|
||||
m_LogWindow->Hide();
|
||||
m_LogWindow->Disable();
|
||||
|
||||
g_TASInputDlg[0] = new TASInputDlg(this);
|
||||
g_TASInputDlg[1] = new TASInputDlg(this);
|
||||
g_TASInputDlg[2] = new TASInputDlg(this);
|
||||
g_TASInputDlg[3] = new TASInputDlg(this);
|
||||
for (int i = 0; i < 8; ++i)
|
||||
g_TASInputDlg[i] = new TASInputDlg(this);
|
||||
|
||||
Movie::SetInputManip(TASManipFunction);
|
||||
Movie::SetGCInputManip(GCTASManipFunction);
|
||||
Movie::SetWiiInputManip(WiiTASManipFunction);
|
||||
|
||||
State::SetOnAfterLoadCallback(OnAfterLoadCallback);
|
||||
Core::SetOnStoppedCallback(OnStoppedCallback);
|
||||
@ -974,15 +973,21 @@ void OnStoppedCallback()
|
||||
}
|
||||
}
|
||||
|
||||
void TASManipFunction(GCPadStatus* PadStatus, int controllerID)
|
||||
void GCTASManipFunction(GCPadStatus* PadStatus, int controllerID)
|
||||
{
|
||||
if (main_frame)
|
||||
main_frame->g_TASInputDlg[controllerID]->GetValues(PadStatus, controllerID);
|
||||
main_frame->g_TASInputDlg[controllerID]->GetValues(PadStatus);
|
||||
}
|
||||
|
||||
void WiiTASManipFunction(u8* data, WiimoteEmu::ReportFeatures rptf, int controllerID)
|
||||
{
|
||||
if (main_frame)
|
||||
main_frame->g_TASInputDlg[controllerID + 4]->GetValues(data, rptf);
|
||||
}
|
||||
|
||||
bool TASInputHasFocus()
|
||||
{
|
||||
for (int i = 0; i < 4; i++)
|
||||
for (int i = 0; i < 8; ++i)
|
||||
{
|
||||
if (main_frame->g_TASInputDlg[i]->TASHasFocus())
|
||||
return true;
|
||||
|
@ -23,6 +23,7 @@
|
||||
|
||||
#include "Common/CommonTypes.h"
|
||||
#include "Common/Event.h"
|
||||
#include "Core/HW/WiimoteEmu/WiimoteEmu.h"
|
||||
#include "DolphinWX/Globals.h"
|
||||
#include "InputCommon/GCPadStatus.h"
|
||||
|
||||
@ -98,7 +99,7 @@ public:
|
||||
CCodeWindow* g_pCodeWindow;
|
||||
NetPlaySetupDiag* g_NetPlaySetupDiag;
|
||||
wxCheatsWindow* g_CheatsWindow;
|
||||
TASInputDlg* g_TASInputDlg[4];
|
||||
TASInputDlg* g_TASInputDlg[8];
|
||||
|
||||
void InitBitmaps();
|
||||
void DoPause();
|
||||
@ -346,6 +347,7 @@ void OnAfterLoadCallback();
|
||||
void OnStoppedCallback();
|
||||
|
||||
// For TASInputDlg
|
||||
void TASManipFunction(GCPadStatus* PadStatus, int controllerID);
|
||||
void GCTASManipFunction(GCPadStatus* PadStatus, int controllerID);
|
||||
void WiiTASManipFunction(u8* data, WiimoteEmu::ReportFeatures rptf, int controllerID);
|
||||
bool TASInputHasFocus();
|
||||
extern int g_saveSlot;
|
||||
|
@ -699,11 +699,18 @@ void CFrame::OnTASInput(wxCommandEvent& event)
|
||||
|
||||
for (int i = 0; i < 4; ++i)
|
||||
{
|
||||
if (SConfig::GetInstance().m_SIDevice[i] == SIDEVICE_GC_CONTROLLER || SConfig::GetInstance().m_SIDevice[i] == SIDEVICE_GC_TARUKONGA)
|
||||
if (SConfig::GetInstance().m_SIDevice[i] != SIDEVICE_NONE && SConfig::GetInstance().m_SIDevice[i] != SIDEVICE_GC_GBA)
|
||||
{
|
||||
g_TASInputDlg[i]->CreateGCLayout();
|
||||
g_TASInputDlg[i]->Show(true);
|
||||
g_TASInputDlg[i]->SetTitle("TAS Input - Controller " + number[i]);
|
||||
}
|
||||
if (g_wiimote_sources[i] == WIIMOTE_SRC_EMU && !(Core::IsRunning() && !SConfig::GetInstance().m_LocalCoreStartupParameter.bWii))
|
||||
{
|
||||
g_TASInputDlg[i+4]->CreateWiiLayout();
|
||||
g_TASInputDlg[i+4]->Show(true);
|
||||
g_TASInputDlg[i+4]->SetTitle("TAS Input - Wiimote " + number[i]);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
File diff suppressed because it is too large
Load Diff
@ -9,12 +9,14 @@
|
||||
#include <wx/dialog.h>
|
||||
#include <wx/event.h>
|
||||
#include <wx/gdicmn.h>
|
||||
#include <wx/sizer.h>
|
||||
#include <wx/string.h>
|
||||
#include <wx/toplevel.h>
|
||||
#include <wx/translation.h>
|
||||
#include <wx/windowid.h>
|
||||
|
||||
#include "Common/CommonTypes.h"
|
||||
#include "Core/HW/WiimoteEmu/WiimoteEmu.h"
|
||||
#include "InputCommon/GCPadStatus.h"
|
||||
|
||||
class wxCheckBox;
|
||||
@ -27,72 +29,89 @@ class TASInputDlg : public wxDialog
|
||||
{
|
||||
public:
|
||||
TASInputDlg(wxWindow* parent,
|
||||
wxWindowID id = 1,
|
||||
const wxString& title = _("TAS Input"),
|
||||
const wxPoint& pos = wxDefaultPosition,
|
||||
const wxSize& size = wxDefaultSize,
|
||||
long style = wxDEFAULT_DIALOG_STYLE | wxSTAY_ON_TOP);
|
||||
wxWindowID id = 1,
|
||||
const wxString& title = _("TAS Input"),
|
||||
const wxPoint& pos = wxDefaultPosition,
|
||||
const wxSize& size = wxDefaultSize,
|
||||
long style = wxDEFAULT_DIALOG_STYLE | wxSTAY_ON_TOP);
|
||||
|
||||
void OnCloseWindow(wxCloseEvent& event);
|
||||
void UpdateFromSliders(wxCommandEvent& event);
|
||||
void UpdateFromText(wxCommandEvent& event);
|
||||
void OnMouseDownL(wxMouseEvent& event);
|
||||
void OnMouseUpR(wxMouseEvent& event);
|
||||
void OnRightClickSlider(wxMouseEvent& event);
|
||||
void ResetValues();
|
||||
void GetValues(GCPadStatus* PadStatus, int controllerID);
|
||||
void GetValues(GCPadStatus* PadStatus);
|
||||
void GetValues(u8* data, WiimoteEmu::ReportFeatures rptf);
|
||||
void SetTurbo(wxMouseEvent& event);
|
||||
void SetTurboFalse(wxMouseEvent& event);
|
||||
void SetTurboState(wxCheckBox* CheckBox, bool* TurboOn);
|
||||
void ButtonTurbo();
|
||||
void GetKeyBoardInput(GCPadStatus* PadStatus);
|
||||
void GetKeyBoardInput(u8* data, WiimoteEmu::ReportFeatures rptf);
|
||||
bool TextBoxHasFocus();
|
||||
void SetLandRTriggers();
|
||||
bool TASHasFocus();
|
||||
|
||||
void CreateGCLayout();
|
||||
void CreateWiiLayout();
|
||||
wxBitmap CreateStickBitmap(int x, int y);
|
||||
void SetWiiButtons(wm_core* butt);
|
||||
void GetIRData(u8* const data, u8 mode, bool use_accel);
|
||||
|
||||
private:
|
||||
u8 mainX, mainY, cX, cY, lTrig, rTrig;
|
||||
const int ID_C_STICK = 1001;
|
||||
const int ID_MAIN_STICK = 1002;
|
||||
int eleID = 1003;
|
||||
|
||||
enum
|
||||
struct Control
|
||||
{
|
||||
ID_MAIN_X_SLIDER = 1000,
|
||||
ID_MAIN_X_TEXT,
|
||||
ID_MAIN_Y_SLIDER,
|
||||
ID_MAIN_Y_TEXT,
|
||||
ID_C_X_SLIDER,
|
||||
ID_C_X_TEXT,
|
||||
ID_C_Y_SLIDER,
|
||||
ID_C_Y_TEXT,
|
||||
ID_L_SLIDER,
|
||||
ID_L_TEXT,
|
||||
ID_R_SLIDER,
|
||||
ID_R_TEXT,
|
||||
ID_CLOSE,
|
||||
ID_UP,
|
||||
ID_DOWN,
|
||||
ID_LEFT,
|
||||
ID_RIGHT,
|
||||
ID_A,
|
||||
ID_B,
|
||||
ID_X,
|
||||
ID_Y,
|
||||
ID_Z,
|
||||
ID_L,
|
||||
ID_R,
|
||||
ID_START,
|
||||
ID_MAIN_STICK,
|
||||
ID_C_STICK,
|
||||
wxTextCtrl* Text;
|
||||
wxSlider* Slider;
|
||||
int value = -1;
|
||||
int Text_ID;
|
||||
int Slider_ID;
|
||||
u32 range;
|
||||
u32 defaultValue = 128;
|
||||
bool SetByKeyboard = false;
|
||||
};
|
||||
|
||||
wxSlider *wx_mainX_s, *wx_mainY_s, *wx_cX_s, *wx_cY_s, *wx_l_s, *wx_r_s;
|
||||
wxCheckBox *wx_up_button, *wx_down_button, *wx_left_button, *wx_right_button, *wx_a_button, *wx_b_button, *wx_x_button, *wx_y_button, *wx_l_button, *wx_r_button, *wx_z_button, *wx_start_button;
|
||||
wxTextCtrl *wx_mainX_t, *wx_mainY_t, *wx_cX_t, *wx_cY_t, *wx_l_t, *wx_r_t;
|
||||
wxMemoryDC dc_main, dc_c;
|
||||
wxStaticBitmap *static_bitmap_main, *static_bitmap_c;
|
||||
wxBitmap bitmap;
|
||||
bool A_turbo,B_turbo, X_turbo, Y_turbo, Z_turbo, L_turbo, R_turbo, START_turbo,DL_turbo,DR_turbo,DD_turbo,DU_turbo;
|
||||
bool A_cont,B_cont, X_cont, Y_cont, Z_cont, L_cont, L_button_cont, R_cont, R_button_cont, START_cont,DL_cont,DR_cont,DD_cont,DU_cont,mstickx,msticky,cstickx,csticky;
|
||||
int xaxis,yaxis,c_xaxis,c_yaxis,update,update_axis;
|
||||
struct Button
|
||||
{
|
||||
wxCheckBox* Checkbox;
|
||||
bool SetByKeyboard = false;
|
||||
bool TurboOn = false;
|
||||
int ID;
|
||||
};
|
||||
|
||||
struct Stick
|
||||
{
|
||||
wxStaticBitmap* bitmap;
|
||||
Control xCont;
|
||||
Control yCont;
|
||||
};
|
||||
|
||||
void SetStickValue(bool* ActivatedByKeyboard, int* AmountPressed, wxTextCtrl* Textbox, int CurrentValue, int center = 128);
|
||||
void SetButtonValue(Button* button, bool CurrentState);
|
||||
void SetSliderValue(Control* control, int CurrentValue, int defaultValue = 128);
|
||||
Stick CreateStick(int id_stick);
|
||||
wxStaticBoxSizer* CreateStickLayout(Stick* tempStick, std::string title);
|
||||
Button CreateButton(const std::string& name);
|
||||
Control CreateControl(long style, int width, int height, u32 range = 255);
|
||||
|
||||
Control lCont, rCont, xCont, yCont, zCont;
|
||||
Button A, B, X, Y, Z, L, R, C, START, PLUS, MINUS, ONE, TWO, HOME, dpad_up, dpad_down, dpad_left, dpad_right;
|
||||
Stick MainStick, CStick;
|
||||
|
||||
Button* Buttons[14];
|
||||
Control* Controls[10];
|
||||
static const int GCPadButtonsBitmask[12];
|
||||
static const int WiiButtonsBitmask[13];
|
||||
|
||||
bool hasLayout = false;
|
||||
bool isWii = false;
|
||||
|
||||
wxGridSizer* const buttons_dpad = new wxGridSizer(3);
|
||||
|
||||
DECLARE_EVENT_TABLE();
|
||||
};
|
||||
|
Loading…
x
Reference in New Issue
Block a user