mirror of
https://github.com/dolphin-emu/dolphin.git
synced 2025-04-25 06:44:59 +00:00
InputCommon/ControllerEmu: Break out functionality of EmulatedController
to eliminate redundant unused members in Wii Remote extension objects.
This commit is contained in:
parent
225039f742
commit
ddb82a5e8c
26 changed files with 312 additions and 245 deletions
|
@ -4,6 +4,19 @@ package org.dolphinemu.dolphinemu.features.input.model.controlleremu
|
||||||
|
|
||||||
import androidx.annotation.Keep
|
import androidx.annotation.Keep
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Represents a C++ ControllerEmu::ControlGroupContainer.
|
||||||
|
*
|
||||||
|
* The lifetime of this class is managed by C++ code. Calling methods on it after it's destroyed
|
||||||
|
* in C++ is undefined behavior!
|
||||||
|
*/
|
||||||
|
@Keep
|
||||||
|
open class ControlGroupContainer constructor(private val pointer: Long) {
|
||||||
|
external fun getGroupCount(): Int
|
||||||
|
|
||||||
|
external fun getGroup(index: Int): ControlGroup
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Represents a C++ ControllerEmu::EmulatedController.
|
* Represents a C++ ControllerEmu::EmulatedController.
|
||||||
*
|
*
|
||||||
|
@ -11,15 +24,11 @@ import androidx.annotation.Keep
|
||||||
* in C++ is undefined behavior!
|
* in C++ is undefined behavior!
|
||||||
*/
|
*/
|
||||||
@Keep
|
@Keep
|
||||||
class EmulatedController private constructor(private val pointer: Long) {
|
class EmulatedController private constructor(private val pointer: Long) : ControlGroupContainer(pointer) {
|
||||||
external fun getDefaultDevice(): String
|
external fun getDefaultDevice(): String
|
||||||
|
|
||||||
external fun setDefaultDevice(device: String)
|
external fun setDefaultDevice(device: String)
|
||||||
|
|
||||||
external fun getGroupCount(): Int
|
|
||||||
|
|
||||||
external fun getGroup(index: Int): ControlGroup
|
|
||||||
|
|
||||||
external fun updateSingleControlReference(controlReference: ControlReference)
|
external fun updateSingleControlReference(controlReference: ControlReference)
|
||||||
|
|
||||||
external fun loadDefaultSettings()
|
external fun loadDefaultSettings()
|
||||||
|
@ -50,7 +59,7 @@ class EmulatedController private constructor(private val pointer: Long) {
|
||||||
external fun getWiimoteAttachment(
|
external fun getWiimoteAttachment(
|
||||||
controllerIndex: Int,
|
controllerIndex: Int,
|
||||||
attachmentIndex: Int
|
attachmentIndex: Int
|
||||||
): EmulatedController
|
): ControlGroupContainer
|
||||||
|
|
||||||
@JvmStatic
|
@JvmStatic
|
||||||
external fun getSelectedWiimoteAttachment(controllerIndex: Int): Int
|
external fun getSelectedWiimoteAttachment(controllerIndex: Int): Int
|
||||||
|
|
|
@ -22,6 +22,7 @@ import org.dolphinemu.dolphinemu.features.input.model.InputMappingBooleanSetting
|
||||||
import org.dolphinemu.dolphinemu.features.input.model.InputMappingDoubleSetting
|
import org.dolphinemu.dolphinemu.features.input.model.InputMappingDoubleSetting
|
||||||
import org.dolphinemu.dolphinemu.features.input.model.InputMappingIntSetting
|
import org.dolphinemu.dolphinemu.features.input.model.InputMappingIntSetting
|
||||||
import org.dolphinemu.dolphinemu.features.input.model.controlleremu.ControlGroup
|
import org.dolphinemu.dolphinemu.features.input.model.controlleremu.ControlGroup
|
||||||
|
import org.dolphinemu.dolphinemu.features.input.model.controlleremu.ControlGroupContainer
|
||||||
import org.dolphinemu.dolphinemu.features.input.model.controlleremu.EmulatedController
|
import org.dolphinemu.dolphinemu.features.input.model.controlleremu.EmulatedController
|
||||||
import org.dolphinemu.dolphinemu.features.input.model.controlleremu.NumericSetting
|
import org.dolphinemu.dolphinemu.features.input.model.controlleremu.NumericSetting
|
||||||
import org.dolphinemu.dolphinemu.features.input.model.view.InputDeviceSetting
|
import org.dolphinemu.dolphinemu.features.input.model.view.InputDeviceSetting
|
||||||
|
@ -2255,8 +2256,9 @@ class SettingsFragmentPresenter(
|
||||||
wiimoteNumber: Int,
|
wiimoteNumber: Int,
|
||||||
extensionType: Int
|
extensionType: Int
|
||||||
) {
|
) {
|
||||||
addControllerMappingSettings(
|
addContainerMappingSettings(
|
||||||
sl,
|
sl,
|
||||||
|
EmulatedController.getWiimote(wiimoteNumber),
|
||||||
EmulatedController.getWiimoteAttachment(wiimoteNumber, extensionType),
|
EmulatedController.getWiimoteAttachment(wiimoteNumber, extensionType),
|
||||||
null
|
null
|
||||||
)
|
)
|
||||||
|
@ -2404,15 +2406,32 @@ class SettingsFragmentPresenter(
|
||||||
* @param groupTypeFilter If this is non-null, only groups whose types match this are considered.
|
* @param groupTypeFilter If this is non-null, only groups whose types match this are considered.
|
||||||
*/
|
*/
|
||||||
private fun addControllerMappingSettings(
|
private fun addControllerMappingSettings(
|
||||||
|
sl: ArrayList<SettingsItem>,
|
||||||
|
controller: EmulatedController,
|
||||||
|
groupTypeFilter: Set<Int>?
|
||||||
|
) {
|
||||||
|
addContainerMappingSettings(sl, controller, controller, groupTypeFilter)
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Adds mapping settings and other control-specific settings.
|
||||||
|
*
|
||||||
|
* @param sl The list to place controller settings into.
|
||||||
|
* @param controller The encompassing controller.
|
||||||
|
* @param container The container of control groups to add settings for.
|
||||||
|
* @param groupTypeFilter If this is non-null, only groups whose types match this are considered.
|
||||||
|
*/
|
||||||
|
private fun addContainerMappingSettings(
|
||||||
sl: ArrayList<SettingsItem>,
|
sl: ArrayList<SettingsItem>,
|
||||||
controller: EmulatedController,
|
controller: EmulatedController,
|
||||||
|
container: ControlGroupContainer,
|
||||||
groupTypeFilter: Set<Int>?
|
groupTypeFilter: Set<Int>?
|
||||||
) {
|
) {
|
||||||
updateOldControllerSettingsWarningVisibility(controller)
|
updateOldControllerSettingsWarningVisibility(controller)
|
||||||
|
|
||||||
val groupCount = controller.getGroupCount()
|
val groupCount = container.getGroupCount()
|
||||||
for (i in 0 until groupCount) {
|
for (i in 0 until groupCount) {
|
||||||
val group = controller.getGroup(i)
|
val group = container.getGroup(i)
|
||||||
val groupType = group.getGroupType()
|
val groupType = group.getGroupType()
|
||||||
if (groupTypeFilter != null && !groupTypeFilter.contains(groupType)) continue
|
if (groupTypeFilter != null && !groupTypeFilter.contains(groupType)) continue
|
||||||
|
|
||||||
|
|
|
@ -97,6 +97,10 @@ static jclass s_control_reference_class;
|
||||||
static jfieldID s_control_reference_pointer;
|
static jfieldID s_control_reference_pointer;
|
||||||
static jmethodID s_control_reference_constructor;
|
static jmethodID s_control_reference_constructor;
|
||||||
|
|
||||||
|
static jclass s_control_group_container_class;
|
||||||
|
static jfieldID s_control_group_container_pointer;
|
||||||
|
static jmethodID s_control_group_container_constructor;
|
||||||
|
|
||||||
static jclass s_emulated_controller_class;
|
static jclass s_emulated_controller_class;
|
||||||
static jfieldID s_emulated_controller_pointer;
|
static jfieldID s_emulated_controller_pointer;
|
||||||
static jmethodID s_emulated_controller_constructor;
|
static jmethodID s_emulated_controller_constructor;
|
||||||
|
@ -446,6 +450,21 @@ jmethodID GetControlReferenceConstructor()
|
||||||
return s_control_reference_constructor;
|
return s_control_reference_constructor;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
jclass GetControlGroupContainerClass()
|
||||||
|
{
|
||||||
|
return s_control_group_container_class;
|
||||||
|
}
|
||||||
|
|
||||||
|
jfieldID GetControlGroupContainerPointer()
|
||||||
|
{
|
||||||
|
return s_control_group_container_pointer;
|
||||||
|
}
|
||||||
|
|
||||||
|
jmethodID GetControlGroupContainerConstructor()
|
||||||
|
{
|
||||||
|
return s_control_group_container_constructor;
|
||||||
|
}
|
||||||
|
|
||||||
jclass GetEmulatedControllerClass()
|
jclass GetEmulatedControllerClass()
|
||||||
{
|
{
|
||||||
return s_emulated_controller_class;
|
return s_emulated_controller_class;
|
||||||
|
@ -685,6 +704,16 @@ JNIEXPORT jint JNI_OnLoad(JavaVM* vm, void* reserved)
|
||||||
s_control_reference_constructor = env->GetMethodID(control_reference_class, "<init>", "(J)V");
|
s_control_reference_constructor = env->GetMethodID(control_reference_class, "<init>", "(J)V");
|
||||||
env->DeleteLocalRef(control_reference_class);
|
env->DeleteLocalRef(control_reference_class);
|
||||||
|
|
||||||
|
const jclass control_group_container_class = env->FindClass(
|
||||||
|
"org/dolphinemu/dolphinemu/features/input/model/controlleremu/ControlGroupContainer");
|
||||||
|
s_control_group_container_class =
|
||||||
|
reinterpret_cast<jclass>(env->NewGlobalRef(control_group_container_class));
|
||||||
|
s_control_group_container_pointer =
|
||||||
|
env->GetFieldID(control_group_container_class, "pointer", "J");
|
||||||
|
s_control_group_container_constructor =
|
||||||
|
env->GetMethodID(control_group_container_class, "<init>", "(J)V");
|
||||||
|
env->DeleteLocalRef(control_group_container_class);
|
||||||
|
|
||||||
const jclass emulated_controller_class = env->FindClass(
|
const jclass emulated_controller_class = env->FindClass(
|
||||||
"org/dolphinemu/dolphinemu/features/input/model/controlleremu/EmulatedController");
|
"org/dolphinemu/dolphinemu/features/input/model/controlleremu/EmulatedController");
|
||||||
s_emulated_controller_class =
|
s_emulated_controller_class =
|
||||||
|
@ -754,5 +783,6 @@ JNIEXPORT void JNI_OnUnload(JavaVM* vm, void* reserved)
|
||||||
env->DeleteGlobalRef(s_numeric_setting_class);
|
env->DeleteGlobalRef(s_numeric_setting_class);
|
||||||
env->DeleteGlobalRef(s_core_device_class);
|
env->DeleteGlobalRef(s_core_device_class);
|
||||||
env->DeleteGlobalRef(s_core_device_control_class);
|
env->DeleteGlobalRef(s_core_device_control_class);
|
||||||
|
env->DeleteGlobalRef(s_control_group_container_class);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -92,6 +92,10 @@ jclass GetControlReferenceClass();
|
||||||
jfieldID GetControlReferencePointer();
|
jfieldID GetControlReferencePointer();
|
||||||
jmethodID GetControlReferenceConstructor();
|
jmethodID GetControlReferenceConstructor();
|
||||||
|
|
||||||
|
jclass GetControlGroupContainerClass();
|
||||||
|
jfieldID GetControlGroupContainerPointer();
|
||||||
|
jmethodID GetControlGroupContainerConstructor();
|
||||||
|
|
||||||
jclass GetEmulatedControllerClass();
|
jclass GetEmulatedControllerClass();
|
||||||
jfieldID GetEmulatedControllerPointer();
|
jfieldID GetEmulatedControllerPointer();
|
||||||
jmethodID GetEmulatedControllerConstructor();
|
jmethodID GetEmulatedControllerConstructor();
|
||||||
|
|
|
@ -20,6 +20,23 @@
|
||||||
#include "jni/Input/ControlReference.h"
|
#include "jni/Input/ControlReference.h"
|
||||||
#include "jni/Input/NumericSetting.h"
|
#include "jni/Input/NumericSetting.h"
|
||||||
|
|
||||||
|
ControllerEmu::ControlGroupContainer* ControlGroupContainerFromJava(JNIEnv* env, jobject obj)
|
||||||
|
{
|
||||||
|
return reinterpret_cast<ControllerEmu::ControlGroupContainer*>(
|
||||||
|
env->GetLongField(obj, IDCache::GetEmulatedControllerPointer()));
|
||||||
|
}
|
||||||
|
|
||||||
|
static jobject ControlGroupContainerToJava(JNIEnv* env,
|
||||||
|
ControllerEmu::ControlGroupContainer* container)
|
||||||
|
{
|
||||||
|
if (!container)
|
||||||
|
return nullptr;
|
||||||
|
|
||||||
|
return env->NewObject(IDCache::GetControlGroupContainerClass(),
|
||||||
|
IDCache::GetControlGroupContainerConstructor(),
|
||||||
|
reinterpret_cast<jlong>(container));
|
||||||
|
}
|
||||||
|
|
||||||
ControllerEmu::EmulatedController* EmulatedControllerFromJava(JNIEnv* env, jobject obj)
|
ControllerEmu::EmulatedController* EmulatedControllerFromJava(JNIEnv* env, jobject obj)
|
||||||
{
|
{
|
||||||
return reinterpret_cast<ControllerEmu::EmulatedController*>(
|
return reinterpret_cast<ControllerEmu::EmulatedController*>(
|
||||||
|
@ -53,18 +70,18 @@ Java_org_dolphinemu_dolphinemu_features_input_model_controlleremu_EmulatedContro
|
||||||
}
|
}
|
||||||
|
|
||||||
JNIEXPORT jint JNICALL
|
JNIEXPORT jint JNICALL
|
||||||
Java_org_dolphinemu_dolphinemu_features_input_model_controlleremu_EmulatedController_getGroupCount(
|
Java_org_dolphinemu_dolphinemu_features_input_model_controlleremu_ControlGroupContainer_getGroupCount(
|
||||||
JNIEnv* env, jobject obj)
|
JNIEnv* env, jobject obj)
|
||||||
{
|
{
|
||||||
return static_cast<jint>(EmulatedControllerFromJava(env, obj)->groups.size());
|
return static_cast<jint>(ControlGroupContainerFromJava(env, obj)->groups.size());
|
||||||
}
|
}
|
||||||
|
|
||||||
JNIEXPORT jobject JNICALL
|
JNIEXPORT jobject JNICALL
|
||||||
Java_org_dolphinemu_dolphinemu_features_input_model_controlleremu_EmulatedController_getGroup(
|
Java_org_dolphinemu_dolphinemu_features_input_model_controlleremu_ControlGroupContainer_getGroup(
|
||||||
JNIEnv* env, jobject obj, jint controller_index)
|
JNIEnv* env, jobject obj, jint controller_index)
|
||||||
{
|
{
|
||||||
return ControlGroupToJava(env,
|
return ControlGroupToJava(
|
||||||
EmulatedControllerFromJava(env, obj)->groups[controller_index].get());
|
env, ControlGroupContainerFromJava(env, obj)->groups[controller_index].get());
|
||||||
}
|
}
|
||||||
|
|
||||||
JNIEXPORT void JNICALL
|
JNIEXPORT void JNICALL
|
||||||
|
@ -175,7 +192,7 @@ Java_org_dolphinemu_dolphinemu_features_input_model_controlleremu_EmulatedContro
|
||||||
{
|
{
|
||||||
auto* attachments = static_cast<ControllerEmu::Attachments*>(
|
auto* attachments = static_cast<ControllerEmu::Attachments*>(
|
||||||
Wiimote::GetWiimoteGroup(controller_index, WiimoteEmu::WiimoteGroup::Attachments));
|
Wiimote::GetWiimoteGroup(controller_index, WiimoteEmu::WiimoteGroup::Attachments));
|
||||||
return EmulatedControllerToJava(env, attachments->GetAttachmentList()[attachment_index].get());
|
return ControlGroupContainerToJava(env, attachments->GetAttachmentList()[attachment_index].get());
|
||||||
}
|
}
|
||||||
|
|
||||||
JNIEXPORT jint JNICALL
|
JNIEXPORT jint JNICALL
|
||||||
|
|
|
@ -10,8 +10,6 @@
|
||||||
|
|
||||||
#include "Core/HW/GCPad.h"
|
#include "Core/HW/GCPad.h"
|
||||||
|
|
||||||
#include "InputCommon/ControllerEmu/Control/Input.h"
|
|
||||||
#include "InputCommon/ControllerEmu/Control/Output.h"
|
|
||||||
#include "InputCommon/ControllerEmu/ControlGroup/AnalogStick.h"
|
#include "InputCommon/ControllerEmu/ControlGroup/AnalogStick.h"
|
||||||
#include "InputCommon/ControllerEmu/ControlGroup/Buttons.h"
|
#include "InputCommon/ControllerEmu/ControlGroup/Buttons.h"
|
||||||
#include "InputCommon/ControllerEmu/ControlGroup/ControlGroup.h"
|
#include "InputCommon/ControllerEmu/ControlGroup/ControlGroup.h"
|
||||||
|
@ -128,6 +126,8 @@ ControllerEmu::ControlGroup* GCPad::GetGroup(PadGroup group)
|
||||||
|
|
||||||
GCPadStatus GCPad::GetInput() const
|
GCPadStatus GCPad::GetInput() const
|
||||||
{
|
{
|
||||||
|
using ControllerEmu::MapFloat;
|
||||||
|
|
||||||
const auto lock = GetStateLock();
|
const auto lock = GetStateLock();
|
||||||
GCPadStatus pad = {};
|
GCPadStatus pad = {};
|
||||||
|
|
||||||
|
@ -182,12 +182,12 @@ void GCPad::LoadDefaults(const ControllerInterface& ciface)
|
||||||
// Rumble
|
// Rumble
|
||||||
m_rumble->SetControlExpression(0, "`Android/0/Device Sensors:Motor 0`");
|
m_rumble->SetControlExpression(0, "`Android/0/Device Sensors:Motor 0`");
|
||||||
#else
|
#else
|
||||||
// Buttons
|
// Buttons: A, B, X, Y, Z
|
||||||
m_buttons->SetControlExpression(0, "`X`"); // A
|
m_buttons->SetControlExpression(0, "`X`");
|
||||||
m_buttons->SetControlExpression(1, "`Z`"); // B
|
m_buttons->SetControlExpression(1, "`Z`");
|
||||||
m_buttons->SetControlExpression(2, "`C`"); // X
|
m_buttons->SetControlExpression(2, "`C`");
|
||||||
m_buttons->SetControlExpression(3, "`S`"); // Y
|
m_buttons->SetControlExpression(3, "`S`");
|
||||||
m_buttons->SetControlExpression(4, "`D`"); // Z
|
m_buttons->SetControlExpression(4, "`D`");
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
m_buttons->SetControlExpression(5, "`RETURN`"); // Start
|
m_buttons->SetControlExpression(5, "`RETURN`"); // Start
|
||||||
#else
|
#else
|
||||||
|
|
|
@ -4,17 +4,13 @@
|
||||||
#include "Core/HW/WiimoteEmu/Extension/Classic.h"
|
#include "Core/HW/WiimoteEmu/Extension/Classic.h"
|
||||||
|
|
||||||
#include <array>
|
#include <array>
|
||||||
#include <string_view>
|
|
||||||
|
|
||||||
#include "Common/Assert.h"
|
|
||||||
#include "Common/BitUtils.h"
|
|
||||||
#include "Common/Common.h"
|
#include "Common/Common.h"
|
||||||
#include "Common/CommonTypes.h"
|
#include "Common/CommonTypes.h"
|
||||||
|
|
||||||
#include "Core/HW/WiimoteEmu/Extension/DesiredExtensionState.h"
|
#include "Core/HW/WiimoteEmu/Extension/DesiredExtensionState.h"
|
||||||
#include "Core/HW/WiimoteEmu/WiimoteEmu.h"
|
#include "Core/HW/WiimoteEmu/WiimoteEmu.h"
|
||||||
|
|
||||||
#include "InputCommon/ControllerEmu/Control/Input.h"
|
|
||||||
#include "InputCommon/ControllerEmu/ControlGroup/AnalogStick.h"
|
#include "InputCommon/ControllerEmu/ControlGroup/AnalogStick.h"
|
||||||
#include "InputCommon/ControllerEmu/ControlGroup/Buttons.h"
|
#include "InputCommon/ControllerEmu/ControlGroup/Buttons.h"
|
||||||
#include "InputCommon/ControllerEmu/ControlGroup/ControlGroup.h"
|
#include "InputCommon/ControllerEmu/ControlGroup/ControlGroup.h"
|
||||||
|
@ -88,6 +84,8 @@ Classic::Classic() : Extension1stParty("Classic", _trans("Classic Controller"))
|
||||||
|
|
||||||
void Classic::BuildDesiredExtensionState(DesiredExtensionState* target_state)
|
void Classic::BuildDesiredExtensionState(DesiredExtensionState* target_state)
|
||||||
{
|
{
|
||||||
|
using ControllerEmu::MapFloat;
|
||||||
|
|
||||||
DataFormat classic_data = {};
|
DataFormat classic_data = {};
|
||||||
|
|
||||||
// left stick
|
// left stick
|
||||||
|
|
|
@ -6,14 +6,12 @@
|
||||||
#include <array>
|
#include <array>
|
||||||
|
|
||||||
#include "Common/Assert.h"
|
#include "Common/Assert.h"
|
||||||
#include "Common/BitUtils.h"
|
|
||||||
#include "Common/Common.h"
|
#include "Common/Common.h"
|
||||||
#include "Common/CommonTypes.h"
|
#include "Common/CommonTypes.h"
|
||||||
|
|
||||||
#include "Core/HW/WiimoteEmu/Extension/DesiredExtensionState.h"
|
#include "Core/HW/WiimoteEmu/Extension/DesiredExtensionState.h"
|
||||||
#include "Core/HW/WiimoteEmu/WiimoteEmu.h"
|
#include "Core/HW/WiimoteEmu/WiimoteEmu.h"
|
||||||
|
|
||||||
#include "InputCommon/ControllerEmu/Control/Input.h"
|
|
||||||
#include "InputCommon/ControllerEmu/ControlGroup/AnalogStick.h"
|
#include "InputCommon/ControllerEmu/ControlGroup/AnalogStick.h"
|
||||||
#include "InputCommon/ControllerEmu/ControlGroup/Triggers.h"
|
#include "InputCommon/ControllerEmu/ControlGroup/Triggers.h"
|
||||||
|
|
||||||
|
@ -37,6 +35,8 @@ DrawsomeTablet::DrawsomeTablet() : Extension3rdParty("Drawsome", _trans("Drawsom
|
||||||
|
|
||||||
void DrawsomeTablet::BuildDesiredExtensionState(DesiredExtensionState* target_state)
|
void DrawsomeTablet::BuildDesiredExtensionState(DesiredExtensionState* target_state)
|
||||||
{
|
{
|
||||||
|
using ControllerEmu::MapFloat;
|
||||||
|
|
||||||
DataFormat& tablet_data = target_state->data.emplace<DataFormat>();
|
DataFormat& tablet_data = target_state->data.emplace<DataFormat>();
|
||||||
|
|
||||||
// Stylus X/Y (calibrated values):
|
// Stylus X/Y (calibrated values):
|
||||||
|
|
|
@ -3,8 +3,6 @@
|
||||||
|
|
||||||
#include "Core/HW/WiimoteEmu/Extension/Drums.h"
|
#include "Core/HW/WiimoteEmu/Extension/Drums.h"
|
||||||
|
|
||||||
#include <type_traits>
|
|
||||||
|
|
||||||
#include "Common/Assert.h"
|
#include "Common/Assert.h"
|
||||||
#include "Common/BitUtils.h"
|
#include "Common/BitUtils.h"
|
||||||
#include "Common/Common.h"
|
#include "Common/Common.h"
|
||||||
|
@ -13,7 +11,6 @@
|
||||||
#include "Core/HW/WiimoteEmu/Extension/DesiredExtensionState.h"
|
#include "Core/HW/WiimoteEmu/Extension/DesiredExtensionState.h"
|
||||||
#include "Core/HW/WiimoteEmu/WiimoteEmu.h"
|
#include "Core/HW/WiimoteEmu/WiimoteEmu.h"
|
||||||
|
|
||||||
#include "InputCommon/ControllerEmu/Control/Input.h"
|
|
||||||
#include "InputCommon/ControllerEmu/ControlGroup/AnalogStick.h"
|
#include "InputCommon/ControllerEmu/ControlGroup/AnalogStick.h"
|
||||||
#include "InputCommon/ControllerEmu/ControlGroup/Buttons.h"
|
#include "InputCommon/ControllerEmu/ControlGroup/Buttons.h"
|
||||||
|
|
||||||
|
@ -83,6 +80,8 @@ Drums::Drums() : Extension1stParty("Drums", _trans("Drum Kit"))
|
||||||
|
|
||||||
void Drums::BuildDesiredExtensionState(DesiredExtensionState* target_state)
|
void Drums::BuildDesiredExtensionState(DesiredExtensionState* target_state)
|
||||||
{
|
{
|
||||||
|
using ControllerEmu::MapFloat;
|
||||||
|
|
||||||
DesiredState& state = target_state->data.emplace<DesiredState>();
|
DesiredState& state = target_state->data.emplace<DesiredState>();
|
||||||
|
|
||||||
{
|
{
|
||||||
|
|
|
@ -32,11 +32,6 @@ std::string Extension::GetDisplayName() const
|
||||||
return m_display_name;
|
return m_display_name;
|
||||||
}
|
}
|
||||||
|
|
||||||
InputConfig* Extension::GetConfig() const
|
|
||||||
{
|
|
||||||
return ::Wiimote::GetConfig();
|
|
||||||
}
|
|
||||||
|
|
||||||
None::None() : Extension("None")
|
None::None() : Extension("None")
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
|
@ -10,13 +10,13 @@
|
||||||
#include "Common/CommonTypes.h"
|
#include "Common/CommonTypes.h"
|
||||||
#include "Core/HW/WiimoteEmu/Encryption.h"
|
#include "Core/HW/WiimoteEmu/Encryption.h"
|
||||||
#include "Core/HW/WiimoteEmu/I2CBus.h"
|
#include "Core/HW/WiimoteEmu/I2CBus.h"
|
||||||
#include "InputCommon/ControllerEmu/ControllerEmu.h"
|
#include "InputCommon/ControllerEmu/ControlGroup/Attachments.h"
|
||||||
|
|
||||||
namespace WiimoteEmu
|
namespace WiimoteEmu
|
||||||
{
|
{
|
||||||
struct DesiredExtensionState;
|
struct DesiredExtensionState;
|
||||||
|
|
||||||
class Extension : public ControllerEmu::EmulatedController, public I2CSlave
|
class Extension : public ControllerEmu::AttachedController, public I2CSlave
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
explicit Extension(const char* name);
|
explicit Extension(const char* name);
|
||||||
|
@ -25,8 +25,6 @@ public:
|
||||||
std::string GetName() const override;
|
std::string GetName() const override;
|
||||||
std::string GetDisplayName() const override;
|
std::string GetDisplayName() const override;
|
||||||
|
|
||||||
InputConfig* GetConfig() const override;
|
|
||||||
|
|
||||||
// Used by the wiimote to detect extension changes.
|
// Used by the wiimote to detect extension changes.
|
||||||
// The normal extensions short this pin so it's always connected,
|
// The normal extensions short this pin so it's always connected,
|
||||||
// but M+ does some tricks with it during activation.
|
// but M+ does some tricks with it during activation.
|
||||||
|
|
|
@ -8,14 +8,12 @@
|
||||||
#include <map>
|
#include <map>
|
||||||
|
|
||||||
#include "Common/Assert.h"
|
#include "Common/Assert.h"
|
||||||
#include "Common/BitUtils.h"
|
|
||||||
#include "Common/Common.h"
|
#include "Common/Common.h"
|
||||||
#include "Common/CommonTypes.h"
|
#include "Common/CommonTypes.h"
|
||||||
|
|
||||||
#include "Core/HW/WiimoteEmu/Extension/DesiredExtensionState.h"
|
#include "Core/HW/WiimoteEmu/Extension/DesiredExtensionState.h"
|
||||||
#include "Core/HW/WiimoteEmu/WiimoteEmu.h"
|
#include "Core/HW/WiimoteEmu/WiimoteEmu.h"
|
||||||
|
|
||||||
#include "InputCommon/ControllerEmu/Control/Input.h"
|
|
||||||
#include "InputCommon/ControllerEmu/ControlGroup/AnalogStick.h"
|
#include "InputCommon/ControllerEmu/ControlGroup/AnalogStick.h"
|
||||||
#include "InputCommon/ControllerEmu/ControlGroup/Buttons.h"
|
#include "InputCommon/ControllerEmu/ControlGroup/Buttons.h"
|
||||||
#include "InputCommon/ControllerEmu/ControlGroup/ControlGroup.h"
|
#include "InputCommon/ControllerEmu/ControlGroup/ControlGroup.h"
|
||||||
|
@ -99,6 +97,8 @@ Guitar::Guitar() : Extension1stParty(_trans("Guitar"))
|
||||||
|
|
||||||
void Guitar::BuildDesiredExtensionState(DesiredExtensionState* target_state)
|
void Guitar::BuildDesiredExtensionState(DesiredExtensionState* target_state)
|
||||||
{
|
{
|
||||||
|
using ControllerEmu::MapFloat;
|
||||||
|
|
||||||
DataFormat guitar_data = {};
|
DataFormat guitar_data = {};
|
||||||
|
|
||||||
// stick
|
// stick
|
||||||
|
|
|
@ -3,21 +3,17 @@
|
||||||
|
|
||||||
#include "Core/HW/WiimoteEmu/Extension/Nunchuk.h"
|
#include "Core/HW/WiimoteEmu/Extension/Nunchuk.h"
|
||||||
|
|
||||||
#include <algorithm>
|
|
||||||
#include <array>
|
#include <array>
|
||||||
#include <cstring>
|
#include <cstring>
|
||||||
|
|
||||||
#include "Common/Assert.h"
|
#include "Common/Assert.h"
|
||||||
#include "Common/BitUtils.h"
|
|
||||||
#include "Common/Common.h"
|
#include "Common/Common.h"
|
||||||
#include "Common/CommonTypes.h"
|
#include "Common/CommonTypes.h"
|
||||||
#include "Common/MathUtil.h"
|
|
||||||
|
|
||||||
#include "Core/HW/Wiimote.h"
|
#include "Core/HW/Wiimote.h"
|
||||||
#include "Core/HW/WiimoteEmu/Extension/DesiredExtensionState.h"
|
#include "Core/HW/WiimoteEmu/Extension/DesiredExtensionState.h"
|
||||||
#include "Core/HW/WiimoteEmu/WiimoteEmu.h"
|
#include "Core/HW/WiimoteEmu/WiimoteEmu.h"
|
||||||
|
|
||||||
#include "InputCommon/ControllerEmu/Control/Input.h"
|
|
||||||
#include "InputCommon/ControllerEmu/ControlGroup/AnalogStick.h"
|
#include "InputCommon/ControllerEmu/ControlGroup/AnalogStick.h"
|
||||||
#include "InputCommon/ControllerEmu/ControlGroup/Buttons.h"
|
#include "InputCommon/ControllerEmu/ControlGroup/Buttons.h"
|
||||||
#include "InputCommon/ControllerEmu/ControlGroup/ControlGroup.h"
|
#include "InputCommon/ControllerEmu/ControlGroup/ControlGroup.h"
|
||||||
|
@ -64,6 +60,8 @@ Nunchuk::Nunchuk() : Extension1stParty(_trans("Nunchuk"))
|
||||||
|
|
||||||
void Nunchuk::BuildDesiredExtensionState(DesiredExtensionState* target_state)
|
void Nunchuk::BuildDesiredExtensionState(DesiredExtensionState* target_state)
|
||||||
{
|
{
|
||||||
|
using ControllerEmu::MapFloat;
|
||||||
|
|
||||||
DataFormat nc_data = {};
|
DataFormat nc_data = {};
|
||||||
|
|
||||||
// stick
|
// stick
|
||||||
|
@ -197,7 +195,7 @@ void Nunchuk::DoState(PointerWrap& p)
|
||||||
p.Do(m_shake_state);
|
p.Do(m_shake_state);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Nunchuk::LoadDefaults(const ControllerInterface& ciface)
|
void Nunchuk::LoadDefaults()
|
||||||
{
|
{
|
||||||
#ifndef ANDROID
|
#ifndef ANDROID
|
||||||
// Stick
|
// Stick
|
||||||
|
|
|
@ -158,7 +158,7 @@ public:
|
||||||
|
|
||||||
ControllerEmu::ControlGroup* GetGroup(NunchukGroup group);
|
ControllerEmu::ControlGroup* GetGroup(NunchukGroup group);
|
||||||
|
|
||||||
void LoadDefaults(const ControllerInterface& ciface) override;
|
void LoadDefaults() override;
|
||||||
|
|
||||||
static constexpr u8 BUTTON_C = 0x02;
|
static constexpr u8 BUTTON_C = 0x02;
|
||||||
static constexpr u8 BUTTON_Z = 0x01;
|
static constexpr u8 BUTTON_Z = 0x01;
|
||||||
|
|
|
@ -57,6 +57,8 @@ Shinkansen::Shinkansen() : Extension3rdParty("Shinkansen", _trans("Shinkansen Co
|
||||||
|
|
||||||
void Shinkansen::BuildDesiredExtensionState(DesiredExtensionState* target_state)
|
void Shinkansen::BuildDesiredExtensionState(DesiredExtensionState* target_state)
|
||||||
{
|
{
|
||||||
|
using ControllerEmu::MapFloat;
|
||||||
|
|
||||||
DesiredState& state = target_state->data.emplace<DesiredState>();
|
DesiredState& state = target_state->data.emplace<DesiredState>();
|
||||||
|
|
||||||
const auto analog = m_levers->GetState().data;
|
const auto analog = m_levers->GetState().data;
|
||||||
|
@ -104,7 +106,7 @@ void Shinkansen::Update(const DesiredExtensionState& target_state)
|
||||||
ext_data.buttons = desired_state.buttons ^ 0xFFFF;
|
ext_data.buttons = desired_state.buttons ^ 0xFFFF;
|
||||||
Common::BitCastPtr<DataFormat>(&m_reg.controller_data) = ext_data;
|
Common::BitCastPtr<DataFormat>(&m_reg.controller_data) = ext_data;
|
||||||
|
|
||||||
const auto lock = GetStateLock();
|
const auto lock = ControllerEmu::EmulatedController::GetStateLock();
|
||||||
m_led->controls[0]->control_ref->State(m_reg.identifier[1]);
|
m_led->controls[0]->control_ref->State(m_reg.identifier[1]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -7,19 +7,16 @@
|
||||||
#include <cstring>
|
#include <cstring>
|
||||||
|
|
||||||
#include "Common/Assert.h"
|
#include "Common/Assert.h"
|
||||||
#include "Common/BitUtils.h"
|
|
||||||
#include "Common/Common.h"
|
#include "Common/Common.h"
|
||||||
#include "Common/CommonTypes.h"
|
#include "Common/CommonTypes.h"
|
||||||
|
|
||||||
#include "Core/HW/WiimoteEmu/Extension/DesiredExtensionState.h"
|
#include "Core/HW/WiimoteEmu/Extension/DesiredExtensionState.h"
|
||||||
#include "Core/HW/WiimoteEmu/WiimoteEmu.h"
|
#include "Core/HW/WiimoteEmu/WiimoteEmu.h"
|
||||||
|
|
||||||
#include "InputCommon/ControllerEmu/Control/Input.h"
|
|
||||||
#include "InputCommon/ControllerEmu/ControlGroup/AnalogStick.h"
|
#include "InputCommon/ControllerEmu/ControlGroup/AnalogStick.h"
|
||||||
#include "InputCommon/ControllerEmu/ControlGroup/Buttons.h"
|
#include "InputCommon/ControllerEmu/ControlGroup/Buttons.h"
|
||||||
#include "InputCommon/ControllerEmu/ControlGroup/ControlGroup.h"
|
#include "InputCommon/ControllerEmu/ControlGroup/ControlGroup.h"
|
||||||
#include "InputCommon/ControllerEmu/ControlGroup/Slider.h"
|
#include "InputCommon/ControllerEmu/ControlGroup/Slider.h"
|
||||||
#include "InputCommon/ControllerEmu/ControlGroup/Triggers.h"
|
|
||||||
|
|
||||||
namespace WiimoteEmu
|
namespace WiimoteEmu
|
||||||
{
|
{
|
||||||
|
@ -84,6 +81,8 @@ Turntable::Turntable() : Extension1stParty("Turntable", _trans("DJ Turntable"))
|
||||||
|
|
||||||
void Turntable::BuildDesiredExtensionState(DesiredExtensionState* target_state)
|
void Turntable::BuildDesiredExtensionState(DesiredExtensionState* target_state)
|
||||||
{
|
{
|
||||||
|
using ControllerEmu::MapFloat;
|
||||||
|
|
||||||
DataFormat tt_data = {};
|
DataFormat tt_data = {};
|
||||||
|
|
||||||
// stick
|
// stick
|
||||||
|
|
|
@ -790,7 +790,7 @@ void Wiimote::LoadDefaults(const ControllerInterface& ciface)
|
||||||
// Enable Nunchuk:
|
// Enable Nunchuk:
|
||||||
constexpr ExtensionNumber DEFAULT_EXT = ExtensionNumber::NUNCHUK;
|
constexpr ExtensionNumber DEFAULT_EXT = ExtensionNumber::NUNCHUK;
|
||||||
m_attachments->SetSelectedAttachment(DEFAULT_EXT);
|
m_attachments->SetSelectedAttachment(DEFAULT_EXT);
|
||||||
m_attachments->GetAttachmentList()[DEFAULT_EXT]->LoadDefaults(ciface);
|
m_attachments->GetAttachmentList()[DEFAULT_EXT]->LoadDefaults();
|
||||||
}
|
}
|
||||||
|
|
||||||
Extension* Wiimote::GetNoneExtension() const
|
Extension* Wiimote::GetNoneExtension() const
|
||||||
|
|
|
@ -17,11 +17,8 @@
|
||||||
#include <QSpinBox>
|
#include <QSpinBox>
|
||||||
#include <QVBoxLayout>
|
#include <QVBoxLayout>
|
||||||
|
|
||||||
#include "Common/CommonTypes.h"
|
|
||||||
|
|
||||||
#include "DolphinQt/Host.h"
|
#include "DolphinQt/Host.h"
|
||||||
#include "DolphinQt/QtUtils/AspectRatioWidget.h"
|
#include "DolphinQt/QtUtils/AspectRatioWidget.h"
|
||||||
#include "DolphinQt/QtUtils/QueueOnObject.h"
|
|
||||||
#include "DolphinQt/Resources.h"
|
#include "DolphinQt/Resources.h"
|
||||||
#include "DolphinQt/TAS/StickWidget.h"
|
#include "DolphinQt/TAS/StickWidget.h"
|
||||||
#include "DolphinQt/TAS/TASCheckBox.h"
|
#include "DolphinQt/TAS/TASCheckBox.h"
|
||||||
|
@ -250,14 +247,12 @@ std::optional<ControlState> TASInputWindow::GetButton(TASCheckBox* checkbox,
|
||||||
std::optional<ControlState> TASInputWindow::GetSpinBox(TASSpinBox* spin, int zero, int min, int max,
|
std::optional<ControlState> TASInputWindow::GetSpinBox(TASSpinBox* spin, int zero, int min, int max,
|
||||||
ControlState controller_state)
|
ControlState controller_state)
|
||||||
{
|
{
|
||||||
const int controller_value =
|
const int controller_value = ControllerEmu::MapFloat<int>(controller_state, zero, 0, max);
|
||||||
ControllerEmu::EmulatedController::MapFloat<int>(controller_state, zero, 0, max);
|
|
||||||
|
|
||||||
if (m_use_controller->isChecked())
|
if (m_use_controller->isChecked())
|
||||||
spin->OnControllerValueChanged(controller_value);
|
spin->OnControllerValueChanged(controller_value);
|
||||||
|
|
||||||
return ControllerEmu::EmulatedController::MapToFloat<ControlState, int>(spin->GetValue(), zero,
|
return ControllerEmu::MapToFloat<ControlState, int>(spin->GetValue(), zero, min, max);
|
||||||
min, max);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
std::optional<ControlState> TASInputWindow::GetSpinBox(TASSpinBox* spin, int zero,
|
std::optional<ControlState> TASInputWindow::GetSpinBox(TASSpinBox* spin, int zero,
|
||||||
|
|
|
@ -5,11 +5,16 @@
|
||||||
|
|
||||||
namespace ControllerEmu
|
namespace ControllerEmu
|
||||||
{
|
{
|
||||||
|
|
||||||
|
void AttachedController::LoadDefaults()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
Attachments::Attachments(const std::string& name_) : ControlGroup(name_, GroupType::Attachments)
|
Attachments::Attachments(const std::string& name_) : ControlGroup(name_, GroupType::Attachments)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
void Attachments::AddAttachment(std::unique_ptr<EmulatedController> att)
|
void Attachments::AddAttachment(std::unique_ptr<AttachedController> att)
|
||||||
{
|
{
|
||||||
m_attachments.emplace_back(std::move(att));
|
m_attachments.emplace_back(std::move(att));
|
||||||
}
|
}
|
||||||
|
@ -40,9 +45,61 @@ SubscribableSettingValue<int>& Attachments::GetAttachmentSetting()
|
||||||
return m_selection_value;
|
return m_selection_value;
|
||||||
}
|
}
|
||||||
|
|
||||||
const std::vector<std::unique_ptr<EmulatedController>>& Attachments::GetAttachmentList() const
|
const std::vector<std::unique_ptr<AttachedController>>& Attachments::GetAttachmentList() const
|
||||||
{
|
{
|
||||||
return m_attachments;
|
return m_attachments;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Attachments::LoadConfig(Common::IniFile::Section* sec, const std::string& base)
|
||||||
|
{
|
||||||
|
ControlGroup::LoadConfig(sec, base);
|
||||||
|
|
||||||
|
SetSelectedAttachment(0);
|
||||||
|
|
||||||
|
std::string attachment_text;
|
||||||
|
sec->Get(base + name, &attachment_text, "");
|
||||||
|
|
||||||
|
// First assume attachment string is a valid expression.
|
||||||
|
// If it instead matches one of the names of our attachments it is overridden below.
|
||||||
|
GetSelectionSetting().GetInputReference().SetExpression(attachment_text);
|
||||||
|
|
||||||
|
u32 n = 0;
|
||||||
|
for (auto& ai : GetAttachmentList())
|
||||||
|
{
|
||||||
|
ai->LoadGroupsConfig(sec, base + ai->GetName() + "/");
|
||||||
|
|
||||||
|
if (ai->GetName() == attachment_text)
|
||||||
|
SetSelectedAttachment(n);
|
||||||
|
|
||||||
|
++n;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void Attachments::SaveConfig(Common::IniFile::Section* sec, const std::string& base)
|
||||||
|
{
|
||||||
|
if (GetSelectionSetting().IsSimpleValue())
|
||||||
|
{
|
||||||
|
sec->Set(base + name, GetAttachmentList()[GetSelectedAttachment()]->GetName(), "None");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
std::string expression = GetSelectionSetting().GetInputReference().GetExpression();
|
||||||
|
ReplaceBreaksWithSpaces(expression);
|
||||||
|
sec->Set(base + name, expression, "None");
|
||||||
|
}
|
||||||
|
|
||||||
|
for (auto& ai : GetAttachmentList())
|
||||||
|
ai->SaveGroupsConfig(sec, base + ai->GetName() + "/");
|
||||||
|
}
|
||||||
|
|
||||||
|
void Attachments::UpdateReferences(ciface::ExpressionParser::ControlEnvironment& env)
|
||||||
|
{
|
||||||
|
ControlGroup::UpdateReferences(env);
|
||||||
|
|
||||||
|
GetSelectionSetting().GetInputReference().UpdateReference(env);
|
||||||
|
|
||||||
|
for (auto& attachment : GetAttachmentList())
|
||||||
|
attachment->UpdateGroupsReferences(env);
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace ControllerEmu
|
} // namespace ControllerEmu
|
||||||
|
|
|
@ -3,19 +3,23 @@
|
||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include <atomic>
|
|
||||||
#include <memory>
|
#include <memory>
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
#include "Common/CommonTypes.h"
|
#include "Common/CommonTypes.h"
|
||||||
#include "Core/HW/WiimoteEmu/ExtensionPort.h"
|
|
||||||
#include "InputCommon/ControllerEmu/ControlGroup/ControlGroup.h"
|
#include "InputCommon/ControllerEmu/ControlGroup/ControlGroup.h"
|
||||||
#include "InputCommon/ControllerEmu/ControllerEmu.h"
|
#include "InputCommon/ControllerEmu/ControllerEmu.h"
|
||||||
#include "InputCommon/ControllerEmu/Setting/NumericSetting.h"
|
#include "InputCommon/ControllerEmu/Setting/NumericSetting.h"
|
||||||
|
|
||||||
namespace ControllerEmu
|
namespace ControllerEmu
|
||||||
{
|
{
|
||||||
|
class AttachedController : public ControlGroupContainer
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
virtual void LoadDefaults();
|
||||||
|
};
|
||||||
|
|
||||||
// A container of the selected and available attachments
|
// A container of the selected and available attachments
|
||||||
// for configuration saving/loading purposes
|
// for configuration saving/loading purposes
|
||||||
class Attachments : public ControlGroup
|
class Attachments : public ControlGroup
|
||||||
|
@ -23,7 +27,7 @@ class Attachments : public ControlGroup
|
||||||
public:
|
public:
|
||||||
explicit Attachments(const std::string& name);
|
explicit Attachments(const std::string& name);
|
||||||
|
|
||||||
void AddAttachment(std::unique_ptr<EmulatedController> att);
|
void AddAttachment(std::unique_ptr<AttachedController> att);
|
||||||
|
|
||||||
u32 GetSelectedAttachment() const;
|
u32 GetSelectedAttachment() const;
|
||||||
void SetSelectedAttachment(u32 val);
|
void SetSelectedAttachment(u32 val);
|
||||||
|
@ -31,16 +35,20 @@ public:
|
||||||
NumericSetting<int>& GetSelectionSetting();
|
NumericSetting<int>& GetSelectionSetting();
|
||||||
SubscribableSettingValue<int>& GetAttachmentSetting();
|
SubscribableSettingValue<int>& GetAttachmentSetting();
|
||||||
|
|
||||||
const std::vector<std::unique_ptr<EmulatedController>>& GetAttachmentList() const;
|
const std::vector<std::unique_ptr<AttachedController>>& GetAttachmentList() const;
|
||||||
|
|
||||||
|
void LoadConfig(Common::IniFile::Section* sec, const std::string& base) override;
|
||||||
|
void SaveConfig(Common::IniFile::Section* sec, const std::string& base) override;
|
||||||
|
|
||||||
|
void UpdateReferences(ciface::ExpressionParser::ControlEnvironment& env) override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
SubscribableSettingValue<int> m_selection_value;
|
SubscribableSettingValue<int> m_selection_value;
|
||||||
// This is here and not added to the list of numeric_settings because it's serialized differently,
|
// This is here and not added to the list of numeric_settings because it's serialized differently,
|
||||||
// by string (to be independent from the enum), and visualized differently in the UI.
|
// by string (to be independent from the enum), and visualized differently in the UI.
|
||||||
// For the rest, it's treated similarly to other numeric_settings in the group.
|
// For the rest, it's treated similarly to other numeric_settings in the group.
|
||||||
NumericSetting<int> m_selection_setting = {
|
NumericSetting<int> m_selection_setting = {&m_selection_value, {""}, 0, 0, 0};
|
||||||
&m_selection_value, {""}, 0, 0, WiimoteEmu::ExtensionNumber::MAX - 1};
|
|
||||||
|
|
||||||
std::vector<std::unique_ptr<EmulatedController>> m_attachments;
|
std::vector<std::unique_ptr<AttachedController>> m_attachments;
|
||||||
};
|
};
|
||||||
} // namespace ControllerEmu
|
} // namespace ControllerEmu
|
||||||
|
|
|
@ -3,13 +3,11 @@
|
||||||
|
|
||||||
#include "InputCommon/ControllerEmu/ControlGroup/ControlGroup.h"
|
#include "InputCommon/ControllerEmu/ControlGroup/ControlGroup.h"
|
||||||
|
|
||||||
#include "Common/CommonTypes.h"
|
|
||||||
#include "Common/IniFile.h"
|
#include "Common/IniFile.h"
|
||||||
|
|
||||||
#include "InputCommon/ControlReference/ControlReference.h"
|
#include "InputCommon/ControlReference/ControlReference.h"
|
||||||
#include "InputCommon/ControllerEmu/Control/Input.h"
|
#include "InputCommon/ControllerEmu/Control/Input.h"
|
||||||
#include "InputCommon/ControllerEmu/Control/Output.h"
|
#include "InputCommon/ControllerEmu/Control/Output.h"
|
||||||
#include "InputCommon/ControllerEmu/ControlGroup/Attachments.h"
|
|
||||||
#include "InputCommon/ControllerEmu/ControllerEmu.h"
|
#include "InputCommon/ControllerEmu/ControllerEmu.h"
|
||||||
#include "InputCommon/ControllerEmu/Setting/NumericSetting.h"
|
#include "InputCommon/ControllerEmu/Setting/NumericSetting.h"
|
||||||
|
|
||||||
|
@ -50,8 +48,7 @@ void ControlGroup::AddDeadzoneSetting(SettingValue<double>* value, double maximu
|
||||||
|
|
||||||
ControlGroup::~ControlGroup() = default;
|
ControlGroup::~ControlGroup() = default;
|
||||||
|
|
||||||
void ControlGroup::LoadConfig(Common::IniFile::Section* sec, const std::string& defdev,
|
void ControlGroup::LoadConfig(Common::IniFile::Section* sec, const std::string& base)
|
||||||
const std::string& base)
|
|
||||||
{
|
{
|
||||||
const std::string group(base + name + "/");
|
const std::string group(base + name + "/");
|
||||||
|
|
||||||
|
@ -75,36 +72,9 @@ void ControlGroup::LoadConfig(Common::IniFile::Section* sec, const std::string&
|
||||||
sec->Get(group + c->name + "/Range", &c->control_ref->range, 100.0);
|
sec->Get(group + c->name + "/Range", &c->control_ref->range, 100.0);
|
||||||
c->control_ref->range /= 100;
|
c->control_ref->range /= 100;
|
||||||
}
|
}
|
||||||
|
|
||||||
// extensions
|
|
||||||
if (type == GroupType::Attachments)
|
|
||||||
{
|
|
||||||
auto* const ext = static_cast<Attachments*>(this);
|
|
||||||
|
|
||||||
ext->SetSelectedAttachment(0);
|
|
||||||
u32 n = 0;
|
|
||||||
std::string attachment_text;
|
|
||||||
sec->Get(base + name, &attachment_text, "");
|
|
||||||
|
|
||||||
// First assume attachment string is a valid expression.
|
|
||||||
// If it instead matches one of the names of our attachments it is overridden below.
|
|
||||||
ext->GetSelectionSetting().GetInputReference().SetExpression(attachment_text);
|
|
||||||
|
|
||||||
for (auto& ai : ext->GetAttachmentList())
|
|
||||||
{
|
|
||||||
ai->SetDefaultDevice(defdev);
|
|
||||||
ai->LoadConfig(sec, base + ai->GetName() + "/");
|
|
||||||
|
|
||||||
if (ai->GetName() == attachment_text)
|
|
||||||
ext->SetSelectedAttachment(n);
|
|
||||||
|
|
||||||
n++;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void ControlGroup::SaveConfig(Common::IniFile::Section* sec, const std::string& defdev,
|
void ControlGroup::SaveConfig(Common::IniFile::Section* sec, const std::string& base)
|
||||||
const std::string& base)
|
|
||||||
{
|
{
|
||||||
const std::string group(base + name + "/");
|
const std::string group(base + name + "/");
|
||||||
|
|
||||||
|
@ -125,27 +95,15 @@ void ControlGroup::SaveConfig(Common::IniFile::Section* sec, const std::string&
|
||||||
// range
|
// range
|
||||||
sec->Set(group + c->name + "/Range", c->control_ref->range * 100.0, 100.0);
|
sec->Set(group + c->name + "/Range", c->control_ref->range * 100.0, 100.0);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// extensions
|
void ControlGroup::UpdateReferences(ciface::ExpressionParser::ControlEnvironment& env)
|
||||||
if (type == GroupType::Attachments)
|
{
|
||||||
{
|
for (auto& control : controls)
|
||||||
auto* const ext = static_cast<Attachments*>(this);
|
control->control_ref->UpdateReference(env);
|
||||||
|
|
||||||
if (ext->GetSelectionSetting().IsSimpleValue())
|
for (auto& setting : numeric_settings)
|
||||||
{
|
setting->GetInputReference().UpdateReference(env);
|
||||||
sec->Set(base + name, ext->GetAttachmentList()[ext->GetSelectedAttachment()]->GetName(),
|
|
||||||
"None");
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
std::string expression = ext->GetSelectionSetting().GetInputReference().GetExpression();
|
|
||||||
ReplaceBreaksWithSpaces(expression);
|
|
||||||
sec->Set(base + name, expression, "None");
|
|
||||||
}
|
|
||||||
|
|
||||||
for (auto& ai : ext->GetAttachmentList())
|
|
||||||
ai->SaveConfig(sec, base + ai->GetName() + "/");
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void ControlGroup::SetControlExpression(int index, const std::string& expression)
|
void ControlGroup::SetControlExpression(int index, const std::string& expression)
|
||||||
|
|
|
@ -13,7 +13,6 @@
|
||||||
#include <type_traits>
|
#include <type_traits>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
#include "Common/CommonTypes.h"
|
|
||||||
#include "Common/IniFile.h"
|
#include "Common/IniFile.h"
|
||||||
#include "InputCommon/ControllerEmu/Control/Control.h"
|
#include "InputCommon/ControllerEmu/Control/Control.h"
|
||||||
#include "InputCommon/ControllerInterface/CoreDevice.h"
|
#include "InputCommon/ControllerInterface/CoreDevice.h"
|
||||||
|
@ -69,10 +68,10 @@ public:
|
||||||
DefaultValue default_value = DefaultValue::AlwaysEnabled);
|
DefaultValue default_value = DefaultValue::AlwaysEnabled);
|
||||||
virtual ~ControlGroup();
|
virtual ~ControlGroup();
|
||||||
|
|
||||||
virtual void LoadConfig(Common::IniFile::Section* sec, const std::string& defdev = "",
|
virtual void LoadConfig(Common::IniFile::Section* sec, const std::string& base);
|
||||||
const std::string& base = "");
|
virtual void SaveConfig(Common::IniFile::Section* sec, const std::string& base);
|
||||||
virtual void SaveConfig(Common::IniFile::Section* sec, const std::string& defdev = "",
|
|
||||||
const std::string& base = "");
|
virtual void UpdateReferences(ciface::ExpressionParser::ControlEnvironment& env);
|
||||||
|
|
||||||
void SetControlExpression(int index, const std::string& expression);
|
void SetControlExpression(int index, const std::string& expression);
|
||||||
|
|
||||||
|
|
|
@ -11,10 +11,7 @@
|
||||||
#include "Common/IniFile.h"
|
#include "Common/IniFile.h"
|
||||||
|
|
||||||
#include "InputCommon/ControlReference/ControlReference.h"
|
#include "InputCommon/ControlReference/ControlReference.h"
|
||||||
#include "InputCommon/ControllerEmu/Control/Control.h"
|
|
||||||
#include "InputCommon/ControllerEmu/ControlGroup/Attachments.h"
|
|
||||||
#include "InputCommon/ControllerEmu/ControlGroup/ControlGroup.h"
|
#include "InputCommon/ControllerEmu/ControlGroup/ControlGroup.h"
|
||||||
#include "InputCommon/ControllerEmu/Setting/NumericSetting.h"
|
|
||||||
#include "InputCommon/ControllerInterface/ControllerInterface.h"
|
#include "InputCommon/ControllerInterface/ControllerInterface.h"
|
||||||
|
|
||||||
namespace ControllerEmu
|
namespace ControllerEmu
|
||||||
|
@ -23,7 +20,7 @@ namespace ControllerEmu
|
||||||
// though no EmulatedController usually run in parallel, so it makes little difference
|
// though no EmulatedController usually run in parallel, so it makes little difference
|
||||||
static std::recursive_mutex s_get_state_mutex;
|
static std::recursive_mutex s_get_state_mutex;
|
||||||
|
|
||||||
std::string EmulatedController::GetDisplayName() const
|
std::string ControlGroupContainer::GetDisplayName() const
|
||||||
{
|
{
|
||||||
return GetName();
|
return GetName();
|
||||||
}
|
}
|
||||||
|
@ -47,34 +44,18 @@ void EmulatedController::UpdateReferences(const ControllerInterface& devi)
|
||||||
|
|
||||||
ciface::ExpressionParser::ControlEnvironment env(devi, GetDefaultDevice(), m_expression_vars);
|
ciface::ExpressionParser::ControlEnvironment env(devi, GetDefaultDevice(), m_expression_vars);
|
||||||
|
|
||||||
UpdateReferences(env);
|
UpdateGroupsReferences(env);
|
||||||
|
|
||||||
env.CleanUnusedVariables();
|
env.CleanUnusedVariables();
|
||||||
}
|
}
|
||||||
|
|
||||||
void EmulatedController::UpdateReferences(ciface::ExpressionParser::ControlEnvironment& env)
|
void ControlGroupContainer::UpdateGroupsReferences(
|
||||||
|
ciface::ExpressionParser::ControlEnvironment& env)
|
||||||
{
|
{
|
||||||
const auto lock = GetStateLock();
|
const auto lock = EmulatedController::GetStateLock();
|
||||||
|
|
||||||
for (auto& ctrlGroup : groups)
|
for (auto& group : groups)
|
||||||
{
|
group->UpdateReferences(env);
|
||||||
for (auto& control : ctrlGroup->controls)
|
|
||||||
control->control_ref->UpdateReference(env);
|
|
||||||
|
|
||||||
for (auto& setting : ctrlGroup->numeric_settings)
|
|
||||||
setting->GetInputReference().UpdateReference(env);
|
|
||||||
|
|
||||||
// Attachments:
|
|
||||||
if (ctrlGroup->type == GroupType::Attachments)
|
|
||||||
{
|
|
||||||
auto* const attachments = static_cast<Attachments*>(ctrlGroup.get());
|
|
||||||
|
|
||||||
attachments->GetSelectionSetting().GetInputReference().UpdateReference(env);
|
|
||||||
|
|
||||||
for (auto& attachment : attachments->GetAttachmentList())
|
|
||||||
attachment->UpdateReferences(env);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void EmulatedController::UpdateSingleControlReference(const ControllerInterface& devi,
|
void EmulatedController::UpdateSingleControlReference(const ControllerInterface& devi,
|
||||||
|
@ -125,43 +106,40 @@ void EmulatedController::SetDefaultDevice(const std::string& device)
|
||||||
void EmulatedController::SetDefaultDevice(ciface::Core::DeviceQualifier devq)
|
void EmulatedController::SetDefaultDevice(ciface::Core::DeviceQualifier devq)
|
||||||
{
|
{
|
||||||
m_default_device = std::move(devq);
|
m_default_device = std::move(devq);
|
||||||
|
|
||||||
for (auto& ctrlGroup : groups)
|
|
||||||
{
|
|
||||||
// Attachments:
|
|
||||||
if (ctrlGroup->type == GroupType::Attachments)
|
|
||||||
{
|
|
||||||
for (auto& ai : static_cast<Attachments*>(ctrlGroup.get())->GetAttachmentList())
|
|
||||||
{
|
|
||||||
ai->SetDefaultDevice(m_default_device);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void EmulatedController::LoadConfig(Common::IniFile::Section* sec, const std::string& base)
|
ControlGroupContainer::~ControlGroupContainer() = default;
|
||||||
|
|
||||||
|
void EmulatedController::LoadConfig(Common::IniFile::Section* sec)
|
||||||
{
|
{
|
||||||
const auto lock = GetStateLock();
|
const auto lock = EmulatedController::GetStateLock();
|
||||||
std::string defdev = GetDefaultDevice().ToString();
|
|
||||||
if (base.empty())
|
std::string defdev;
|
||||||
{
|
if (sec->Get("Device", &defdev, ""))
|
||||||
sec->Get(base + "Device", &defdev, "");
|
|
||||||
SetDefaultDevice(defdev);
|
SetDefaultDevice(defdev);
|
||||||
}
|
|
||||||
|
|
||||||
for (auto& cg : groups)
|
LoadGroupsConfig(sec, "");
|
||||||
cg->LoadConfig(sec, defdev, base);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void EmulatedController::SaveConfig(Common::IniFile::Section* sec, const std::string& base)
|
void ControlGroupContainer::LoadGroupsConfig(Common::IniFile::Section* sec, const std::string& base)
|
||||||
{
|
{
|
||||||
const auto lock = GetStateLock();
|
for (auto& cg : groups)
|
||||||
const std::string defdev = GetDefaultDevice().ToString();
|
cg->LoadConfig(sec, base);
|
||||||
if (base.empty())
|
}
|
||||||
sec->Set(/*std::string(" ") +*/ base + "Device", defdev, "");
|
|
||||||
|
|
||||||
for (auto& ctrlGroup : groups)
|
void EmulatedController::SaveConfig(Common::IniFile::Section* sec)
|
||||||
ctrlGroup->SaveConfig(sec, defdev, base);
|
{
|
||||||
|
const auto lock = EmulatedController::GetStateLock();
|
||||||
|
|
||||||
|
sec->Set("Device", GetDefaultDevice().ToString(), "");
|
||||||
|
|
||||||
|
SaveGroupsConfig(sec, "");
|
||||||
|
}
|
||||||
|
|
||||||
|
void ControlGroupContainer::SaveGroupsConfig(Common::IniFile::Section* sec, const std::string& base)
|
||||||
|
{
|
||||||
|
for (auto& cg : groups)
|
||||||
|
cg->SaveConfig(sec, base);
|
||||||
}
|
}
|
||||||
|
|
||||||
void EmulatedController::LoadDefaults(const ControllerInterface& ciface)
|
void EmulatedController::LoadDefaults(const ControllerInterface& ciface)
|
||||||
|
@ -178,12 +156,12 @@ void EmulatedController::LoadDefaults(const ControllerInterface& ciface)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void EmulatedController::SetInputOverrideFunction(InputOverrideFunction override_func)
|
void ControlGroupContainer::SetInputOverrideFunction(InputOverrideFunction override_func)
|
||||||
{
|
{
|
||||||
m_input_override_function = std::move(override_func);
|
m_input_override_function = std::move(override_func);
|
||||||
}
|
}
|
||||||
|
|
||||||
void EmulatedController::ClearInputOverrideFunction()
|
void ControlGroupContainer::ClearInputOverrideFunction()
|
||||||
{
|
{
|
||||||
m_input_override_function = {};
|
m_input_override_function = {};
|
||||||
}
|
}
|
||||||
|
|
|
@ -172,29 +172,83 @@ struct RawValue
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
class EmulatedController
|
// Maps a float from -1.0..+1.0 to an integer in the provided range.
|
||||||
|
template <typename T, typename F>
|
||||||
|
T MapFloat(F input_value, T zero_value, T neg_1_value = std::numeric_limits<T>::min(),
|
||||||
|
T pos_1_value = std::numeric_limits<T>::max())
|
||||||
|
{
|
||||||
|
static_assert(std::is_integral<T>(), "T is only sane for int types.");
|
||||||
|
static_assert(std::is_floating_point<F>(), "F is only sane for float types.");
|
||||||
|
|
||||||
|
static_assert(std::numeric_limits<long long>::min() <= std::numeric_limits<T>::min() &&
|
||||||
|
std::numeric_limits<long long>::max() >= std::numeric_limits<T>::max(),
|
||||||
|
"long long is not a superset of T. use of std::llround is not sane.");
|
||||||
|
|
||||||
|
// Here we round when converting from float to int.
|
||||||
|
// After applying our deadzone, resizing, and reshaping math
|
||||||
|
// we sometimes have a near-zero value which is slightly negative. (e.g. -0.0001)
|
||||||
|
// Casting would round down but rounding will yield our "zero_value".
|
||||||
|
|
||||||
|
if (input_value > 0)
|
||||||
|
return T(std::llround((pos_1_value - zero_value) * input_value + zero_value));
|
||||||
|
else
|
||||||
|
return T(std::llround((zero_value - neg_1_value) * input_value + zero_value));
|
||||||
|
}
|
||||||
|
|
||||||
|
// The inverse of the function above.
|
||||||
|
// Maps an integer in the provided range to a float in the range -1.0..1.0.
|
||||||
|
template <typename F, typename T>
|
||||||
|
F MapToFloat(T input_value, T zero_value, T neg_1_value = std::numeric_limits<T>::min(),
|
||||||
|
T pos_1_value = std::numeric_limits<T>::max())
|
||||||
|
{
|
||||||
|
static_assert(std::is_integral<T>(), "T is only sane for int types.");
|
||||||
|
static_assert(std::is_floating_point<F>(), "F is only sane for float types.");
|
||||||
|
|
||||||
|
if (input_value >= zero_value)
|
||||||
|
return F(input_value - zero_value) / F(pos_1_value - zero_value);
|
||||||
|
else
|
||||||
|
return -F(zero_value - input_value) / F(zero_value - neg_1_value);
|
||||||
|
}
|
||||||
|
|
||||||
|
class ControlGroupContainer
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
virtual ~EmulatedController();
|
virtual ~ControlGroupContainer();
|
||||||
|
|
||||||
|
virtual void LoadGroupsConfig(Common::IniFile::Section* sec, const std::string& base);
|
||||||
|
virtual void SaveGroupsConfig(Common::IniFile::Section* sec, const std::string& base);
|
||||||
|
|
||||||
virtual std::string GetName() const = 0;
|
virtual std::string GetName() const = 0;
|
||||||
virtual std::string GetDisplayName() const;
|
virtual std::string GetDisplayName() const;
|
||||||
|
|
||||||
|
void UpdateGroupsReferences(ciface::ExpressionParser::ControlEnvironment& env);
|
||||||
|
|
||||||
|
void SetInputOverrideFunction(InputOverrideFunction override_func);
|
||||||
|
void ClearInputOverrideFunction();
|
||||||
|
|
||||||
|
std::vector<std::unique_ptr<ControlGroup>> groups;
|
||||||
|
|
||||||
|
protected:
|
||||||
|
InputOverrideFunction m_input_override_function;
|
||||||
|
};
|
||||||
|
|
||||||
|
class EmulatedController : public ControlGroupContainer
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
virtual ~EmulatedController();
|
||||||
|
|
||||||
virtual InputConfig* GetConfig() const = 0;
|
virtual InputConfig* GetConfig() const = 0;
|
||||||
|
|
||||||
virtual void LoadDefaults(const ControllerInterface& ciface);
|
virtual void LoadDefaults(const ControllerInterface& ciface);
|
||||||
|
|
||||||
virtual void LoadConfig(Common::IniFile::Section* sec, const std::string& base = "");
|
void LoadConfig(Common::IniFile::Section* sec);
|
||||||
virtual void SaveConfig(Common::IniFile::Section* sec, const std::string& base = "");
|
void SaveConfig(Common::IniFile::Section* sec);
|
||||||
|
|
||||||
bool IsDefaultDeviceConnected() const;
|
bool IsDefaultDeviceConnected() const;
|
||||||
const ciface::Core::DeviceQualifier& GetDefaultDevice() const;
|
const ciface::Core::DeviceQualifier& GetDefaultDevice() const;
|
||||||
void SetDefaultDevice(const std::string& device);
|
void SetDefaultDevice(const std::string& device);
|
||||||
void SetDefaultDevice(ciface::Core::DeviceQualifier devq);
|
void SetDefaultDevice(ciface::Core::DeviceQualifier devq);
|
||||||
|
|
||||||
void SetInputOverrideFunction(InputOverrideFunction override_func);
|
|
||||||
void ClearInputOverrideFunction();
|
|
||||||
|
|
||||||
void UpdateReferences(const ControllerInterface& devi);
|
void UpdateReferences(const ControllerInterface& devi);
|
||||||
void UpdateSingleControlReference(const ControllerInterface& devi, ControlReference* ref);
|
void UpdateSingleControlReference(const ControllerInterface& devi, ControlReference* ref);
|
||||||
|
|
||||||
|
@ -209,55 +263,9 @@ public:
|
||||||
// Resets the values while keeping the list.
|
// Resets the values while keeping the list.
|
||||||
void ResetExpressionVariables();
|
void ResetExpressionVariables();
|
||||||
|
|
||||||
std::vector<std::unique_ptr<ControlGroup>> groups;
|
|
||||||
|
|
||||||
// Maps a float from -1.0..+1.0 to an integer in the provided range.
|
|
||||||
template <typename T, typename F>
|
|
||||||
static T MapFloat(F input_value, T zero_value, T neg_1_value = std::numeric_limits<T>::min(),
|
|
||||||
T pos_1_value = std::numeric_limits<T>::max())
|
|
||||||
{
|
|
||||||
static_assert(std::is_integral<T>(), "T is only sane for int types.");
|
|
||||||
static_assert(std::is_floating_point<F>(), "F is only sane for float types.");
|
|
||||||
|
|
||||||
static_assert(std::numeric_limits<long long>::min() <= std::numeric_limits<T>::min() &&
|
|
||||||
std::numeric_limits<long long>::max() >= std::numeric_limits<T>::max(),
|
|
||||||
"long long is not a superset of T. use of std::llround is not sane.");
|
|
||||||
|
|
||||||
// Here we round when converting from float to int.
|
|
||||||
// After applying our deadzone, resizing, and reshaping math
|
|
||||||
// we sometimes have a near-zero value which is slightly negative. (e.g. -0.0001)
|
|
||||||
// Casting would round down but rounding will yield our "zero_value".
|
|
||||||
|
|
||||||
if (input_value > 0)
|
|
||||||
return T(std::llround((pos_1_value - zero_value) * input_value + zero_value));
|
|
||||||
else
|
|
||||||
return T(std::llround((zero_value - neg_1_value) * input_value + zero_value));
|
|
||||||
}
|
|
||||||
|
|
||||||
// The inverse of the function above.
|
|
||||||
// Maps an integer in the provided range to a float in the range -1.0..1.0.
|
|
||||||
template <typename F, typename T>
|
|
||||||
static F MapToFloat(T input_value, T zero_value, T neg_1_value = std::numeric_limits<T>::min(),
|
|
||||||
T pos_1_value = std::numeric_limits<T>::max())
|
|
||||||
{
|
|
||||||
static_assert(std::is_integral<T>(), "T is only sane for int types.");
|
|
||||||
static_assert(std::is_floating_point<F>(), "F is only sane for float types.");
|
|
||||||
|
|
||||||
if (input_value >= zero_value)
|
|
||||||
return F(input_value - zero_value) / F(pos_1_value - zero_value);
|
|
||||||
else
|
|
||||||
return -F(zero_value - input_value) / F(zero_value - neg_1_value);
|
|
||||||
}
|
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
// TODO: Wiimote attachments actually end up using their parent controller value for this,
|
|
||||||
// so theirs won't be used (and thus shouldn't even exist).
|
|
||||||
ciface::ExpressionParser::ControlEnvironment::VariableContainer m_expression_vars;
|
ciface::ExpressionParser::ControlEnvironment::VariableContainer m_expression_vars;
|
||||||
|
|
||||||
InputOverrideFunction m_input_override_function;
|
|
||||||
|
|
||||||
void UpdateReferences(ciface::ExpressionParser::ControlEnvironment& env);
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
ciface::Core::DeviceQualifier m_default_device;
|
ciface::Core::DeviceQualifier m_default_device;
|
||||||
bool m_default_device_is_connected{false};
|
bool m_default_device_is_connected{false};
|
||||||
|
|
|
@ -10,7 +10,6 @@
|
||||||
#include <fmt/format.h>
|
#include <fmt/format.h>
|
||||||
#include <fmt/ranges.h>
|
#include <fmt/ranges.h>
|
||||||
|
|
||||||
#include "Common/Common.h"
|
|
||||||
#include "Common/MathUtil.h"
|
#include "Common/MathUtil.h"
|
||||||
#include "Common/Matrix.h"
|
#include "Common/Matrix.h"
|
||||||
#include "Common/StringUtil.h"
|
#include "Common/StringUtil.h"
|
||||||
|
@ -228,10 +227,9 @@ void ReshapableInput::SetCenter(ReshapableInput::ReshapeData center)
|
||||||
m_center = center;
|
m_center = center;
|
||||||
}
|
}
|
||||||
|
|
||||||
void ReshapableInput::LoadConfig(Common::IniFile::Section* section,
|
void ReshapableInput::LoadConfig(Common::IniFile::Section* section, const std::string& base_name)
|
||||||
const std::string& default_device, const std::string& base_name)
|
|
||||||
{
|
{
|
||||||
ControlGroup::LoadConfig(section, default_device, base_name);
|
ControlGroup::LoadConfig(section, base_name);
|
||||||
|
|
||||||
const std::string group(base_name + name + '/');
|
const std::string group(base_name + name + '/');
|
||||||
|
|
||||||
|
@ -271,10 +269,9 @@ void ReshapableInput::LoadConfig(Common::IniFile::Section* section,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void ReshapableInput::SaveConfig(Common::IniFile::Section* section,
|
void ReshapableInput::SaveConfig(Common::IniFile::Section* section, const std::string& base_name)
|
||||||
const std::string& default_device, const std::string& base_name)
|
|
||||||
{
|
{
|
||||||
ControlGroup::SaveConfig(section, default_device, base_name);
|
ControlGroup::SaveConfig(section, base_name);
|
||||||
|
|
||||||
const std::string group(base_name + name + '/');
|
const std::string group(base_name + name + '/');
|
||||||
|
|
||||||
|
|
|
@ -8,7 +8,6 @@
|
||||||
|
|
||||||
#include "Common/Matrix.h"
|
#include "Common/Matrix.h"
|
||||||
|
|
||||||
#include "InputCommon/ControlReference/ControlReference.h"
|
|
||||||
#include "InputCommon/ControllerEmu/ControlGroup/ControlGroup.h"
|
#include "InputCommon/ControllerEmu/ControlGroup/ControlGroup.h"
|
||||||
#include "InputCommon/ControllerEmu/Setting/NumericSetting.h"
|
#include "InputCommon/ControllerEmu/Setting/NumericSetting.h"
|
||||||
|
|
||||||
|
@ -117,8 +116,8 @@ protected:
|
||||||
virtual Control* GetModifierInput() const;
|
virtual Control* GetModifierInput() const;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void LoadConfig(Common::IniFile::Section*, const std::string&, const std::string&) override;
|
void LoadConfig(Common::IniFile::Section*, const std::string& base_name) override;
|
||||||
void SaveConfig(Common::IniFile::Section*, const std::string&, const std::string&) override;
|
void SaveConfig(Common::IniFile::Section*, const std::string& base_name) override;
|
||||||
|
|
||||||
CalibrationData m_calibration;
|
CalibrationData m_calibration;
|
||||||
SettingValue<double> m_deadzone_setting;
|
SettingValue<double> m_deadzone_setting;
|
||||||
|
|
Loading…
Add table
Reference in a new issue