early-access version 1636
@ -1,7 +1,7 @@
|
|||||||
yuzu emulator early access
|
yuzu emulator early access
|
||||||
=============
|
=============
|
||||||
|
|
||||||
This is the source code for early-access 1635.
|
This is the source code for early-access 1636.
|
||||||
|
|
||||||
## Legal Notice
|
## Legal Notice
|
||||||
|
|
||||||
|
BIN
dist/icons/overlay/osk_button_B.png
vendored
Before Width: | Height: | Size: 741 B After Width: | Height: | Size: 2.6 KiB |
BIN
dist/icons/overlay/osk_button_B_dark.png
vendored
Before Width: | Height: | Size: 767 B After Width: | Height: | Size: 2.7 KiB |
BIN
dist/icons/overlay/osk_button_B_dark_disabled.png
vendored
Before Width: | Height: | Size: 781 B After Width: | Height: | Size: 2.6 KiB |
BIN
dist/icons/overlay/osk_button_B_disabled.png
vendored
Before Width: | Height: | Size: 791 B After Width: | Height: | Size: 2.6 KiB |
BIN
dist/icons/overlay/osk_button_Y.png
vendored
Before Width: | Height: | Size: 726 B After Width: | Height: | Size: 2.6 KiB |
BIN
dist/icons/overlay/osk_button_Y_dark.png
vendored
Before Width: | Height: | Size: 502 B After Width: | Height: | Size: 2.0 KiB |
BIN
dist/icons/overlay/osk_button_Y_dark_disabled.png
vendored
Before Width: | Height: | Size: 694 B After Width: | Height: | Size: 2.6 KiB |
BIN
dist/icons/overlay/osk_button_Y_disabled.png
vendored
Before Width: | Height: | Size: 699 B After Width: | Height: | Size: 2.6 KiB |
BIN
dist/icons/overlay/osk_button_plus.png
vendored
Before Width: | Height: | Size: 626 B After Width: | Height: | Size: 2.2 KiB |
BIN
dist/icons/overlay/osk_button_plus_dark.png
vendored
Before Width: | Height: | Size: 676 B After Width: | Height: | Size: 2.2 KiB |
BIN
dist/icons/overlay/osk_button_plus_dark_disabled.png
vendored
Before Width: | Height: | Size: 645 B After Width: | Height: | Size: 2.2 KiB |
BIN
dist/icons/overlay/osk_button_plus_disabled.png
vendored
Before Width: | Height: | Size: 664 B After Width: | Height: | Size: 2.2 KiB |
BIN
dist/icons/overlay/osk_button_shift_lock_off.png
vendored
Before Width: | Height: | Size: 281 B After Width: | Height: | Size: 936 B |
BIN
dist/icons/overlay/osk_button_shift_lock_on.png
vendored
Before Width: | Height: | Size: 274 B After Width: | Height: | Size: 894 B |
36
dist/qt_themes/default/style.qss
vendored
@ -515,45 +515,35 @@ QDialog#QtSoftwareKeyboardDialog QPushButton#button_backspace_num:pressed {
|
|||||||
QDialog#QtSoftwareKeyboardDialog QPushButton#button_backspace,
|
QDialog#QtSoftwareKeyboardDialog QPushButton#button_backspace,
|
||||||
QDialog#QtSoftwareKeyboardDialog QPushButton#button_backspace_shift,
|
QDialog#QtSoftwareKeyboardDialog QPushButton#button_backspace_shift,
|
||||||
QDialog#QtSoftwareKeyboardDialog QPushButton#button_backspace_num {
|
QDialog#QtSoftwareKeyboardDialog QPushButton#button_backspace_num {
|
||||||
background-position: right top;
|
image: url(:/overlay/osk_button_B.png);
|
||||||
background-repeat: no-repeat;
|
image-position: right;
|
||||||
background-origin: content;
|
|
||||||
background-image: url(:/overlay/osk_button_B.png);
|
|
||||||
qproperty-icon: url(:/overlay/osk_button_backspace.png);
|
qproperty-icon: url(:/overlay/osk_button_backspace.png);
|
||||||
qproperty-iconSize: 36px;
|
qproperty-iconSize: 36px;
|
||||||
}
|
}
|
||||||
|
|
||||||
QDialog#QtSoftwareKeyboardDialog QPushButton#button_space,
|
QDialog#QtSoftwareKeyboardDialog QPushButton#button_space,
|
||||||
QDialog#QtSoftwareKeyboardDialog QPushButton#button_space_shift {
|
QDialog#QtSoftwareKeyboardDialog QPushButton#button_space_shift {
|
||||||
background-position: right top;
|
image: url(:/overlay/osk_button_Y.png);
|
||||||
background-repeat: no-repeat;
|
image-position: right;
|
||||||
background-origin: content;
|
|
||||||
background-image: url(:/overlay/osk_button_Y.png);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
QDialog#QtSoftwareKeyboardDialog QPushButton#button_ok,
|
QDialog#QtSoftwareKeyboardDialog QPushButton#button_ok,
|
||||||
QDialog#QtSoftwareKeyboardDialog QPushButton#button_ok_shift,
|
QDialog#QtSoftwareKeyboardDialog QPushButton#button_ok_shift,
|
||||||
QDialog#QtSoftwareKeyboardDialog QPushButton#button_ok_num {
|
QDialog#QtSoftwareKeyboardDialog QPushButton#button_ok_num {
|
||||||
background-position: right top;
|
image: url(:/overlay/osk_button_plus.png);
|
||||||
background-repeat: no-repeat;
|
image-position: right;
|
||||||
background-origin: content;
|
|
||||||
background-image: url(:/overlay/osk_button_plus.png);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
QDialog#QtSoftwareKeyboardDialog QPushButton#button_shift {
|
QDialog#QtSoftwareKeyboardDialog QPushButton#button_shift {
|
||||||
background-position: left top;
|
image: url(:/overlay/osk_button_shift_lock_off.png);
|
||||||
background-repeat: no-repeat;
|
image-position: left;
|
||||||
background-origin: content;
|
|
||||||
background-image: url(:/overlay/osk_button_shift_lock_off.png);
|
|
||||||
qproperty-icon: url(:/overlay/osk_button_shift.png);
|
qproperty-icon: url(:/overlay/osk_button_shift.png);
|
||||||
qproperty-iconSize: 36px;
|
qproperty-iconSize: 36px;
|
||||||
}
|
}
|
||||||
|
|
||||||
QDialog#QtSoftwareKeyboardDialog QPushButton#button_shift_shift {
|
QDialog#QtSoftwareKeyboardDialog QPushButton#button_shift_shift {
|
||||||
background-position: left top;
|
image: url(:/overlay/osk_button_shift_lock_off.png);
|
||||||
background-repeat: no-repeat;
|
image-position: left;
|
||||||
background-origin: content;
|
|
||||||
background-image: url(:/overlay/osk_button_shift_lock_off.png);
|
|
||||||
qproperty-icon: url(:/overlay/osk_button_shift_on.png);
|
qproperty-icon: url(:/overlay/osk_button_shift_on.png);
|
||||||
qproperty-iconSize: 36px;
|
qproperty-iconSize: 36px;
|
||||||
}
|
}
|
||||||
@ -645,16 +635,16 @@ QDialog#QtSoftwareKeyboardDialog QPushButton#button_return:disabled {
|
|||||||
QDialog#QtSoftwareKeyboardDialog QPushButton#button_ok:disabled,
|
QDialog#QtSoftwareKeyboardDialog QPushButton#button_ok:disabled,
|
||||||
QDialog#QtSoftwareKeyboardDialog QPushButton#button_ok_shift:disabled,
|
QDialog#QtSoftwareKeyboardDialog QPushButton#button_ok_shift:disabled,
|
||||||
QDialog#QtSoftwareKeyboardDialog QPushButton#button_ok_num:disabled {
|
QDialog#QtSoftwareKeyboardDialog QPushButton#button_ok_num:disabled {
|
||||||
background-image: url(:/overlay/osk_button_plus_disabled.png);
|
image: url(:/overlay/osk_button_plus_disabled.png);
|
||||||
}
|
}
|
||||||
|
|
||||||
QDialog#QtSoftwareKeyboardDialog QPushButton#button_backspace:disabled,
|
QDialog#QtSoftwareKeyboardDialog QPushButton#button_backspace:disabled,
|
||||||
QDialog#QtSoftwareKeyboardDialog QPushButton#button_backspace_shift:disabled,
|
QDialog#QtSoftwareKeyboardDialog QPushButton#button_backspace_shift:disabled,
|
||||||
QDialog#QtSoftwareKeyboardDialog QPushButton#button_backspace_num:disabled {
|
QDialog#QtSoftwareKeyboardDialog QPushButton#button_backspace_num:disabled {
|
||||||
background-image: url(:/overlay/osk_button_B_disabled.png);
|
image: url(:/overlay/osk_button_B_disabled.png);
|
||||||
}
|
}
|
||||||
|
|
||||||
QDialog#QtSoftwareKeyboardDialog QPushButton#button_space:disabled,
|
QDialog#QtSoftwareKeyboardDialog QPushButton#button_space:disabled,
|
||||||
QDialog#QtSoftwareKeyboardDialog QPushButton#button_space_shift:disabled {
|
QDialog#QtSoftwareKeyboardDialog QPushButton#button_space_shift:disabled {
|
||||||
background-image: url(:/overlay/osk_button_Y_disabled.png);
|
image: url(:/overlay/osk_button_Y_disabled.png);
|
||||||
}
|
}
|
||||||
|
36
dist/qt_themes/qdarkstyle/style.qss
vendored
@ -1805,46 +1805,36 @@ QDialog#QtSoftwareKeyboardDialog QPushButton#button_backspace_num:pressed {
|
|||||||
QDialog#QtSoftwareKeyboardDialog QPushButton#button_backspace,
|
QDialog#QtSoftwareKeyboardDialog QPushButton#button_backspace,
|
||||||
QDialog#QtSoftwareKeyboardDialog QPushButton#button_backspace_shift,
|
QDialog#QtSoftwareKeyboardDialog QPushButton#button_backspace_shift,
|
||||||
QDialog#QtSoftwareKeyboardDialog QPushButton#button_backspace_num {
|
QDialog#QtSoftwareKeyboardDialog QPushButton#button_backspace_num {
|
||||||
background-position: right top;
|
image: url(:/overlay/osk_button_B_dark.png);
|
||||||
background-repeat: no-repeat;
|
image-position: right;
|
||||||
background-origin: content;
|
|
||||||
background-image: url(:/overlay/osk_button_B_dark.png);
|
|
||||||
qproperty-icon: url(:/overlay/osk_button_backspace_dark.png);
|
qproperty-icon: url(:/overlay/osk_button_backspace_dark.png);
|
||||||
qproperty-iconSize: 36px;
|
qproperty-iconSize: 36px;
|
||||||
}
|
}
|
||||||
|
|
||||||
QDialog#QtSoftwareKeyboardDialog QPushButton#button_space,
|
QDialog#QtSoftwareKeyboardDialog QPushButton#button_space,
|
||||||
QDialog#QtSoftwareKeyboardDialog QPushButton#button_space_shift {
|
QDialog#QtSoftwareKeyboardDialog QPushButton#button_space_shift {
|
||||||
background-position: right top;
|
image: url(:/overlay/osk_button_Y_dark.png);
|
||||||
background-repeat: no-repeat;
|
image-position: right;
|
||||||
background-origin: content;
|
|
||||||
background-image: url(:/overlay/osk_button_Y_dark.png);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
QDialog#QtSoftwareKeyboardDialog QPushButton#button_ok,
|
QDialog#QtSoftwareKeyboardDialog QPushButton#button_ok,
|
||||||
QDialog#QtSoftwareKeyboardDialog QPushButton#button_ok_shift,
|
QDialog#QtSoftwareKeyboardDialog QPushButton#button_ok_shift,
|
||||||
QDialog#QtSoftwareKeyboardDialog QPushButton#button_ok_num {
|
QDialog#QtSoftwareKeyboardDialog QPushButton#button_ok_num {
|
||||||
color: rgba(44, 44, 44, 1);
|
color: rgba(44, 44, 44, 1);
|
||||||
background-position: right top;
|
image: url(:/overlay/osk_button_plus_dark.png);
|
||||||
background-repeat: no-repeat;
|
image-position: right;
|
||||||
background-origin: content;
|
|
||||||
background-image: url(:/overlay/osk_button_plus_dark.png);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
QDialog#QtSoftwareKeyboardDialog QPushButton#button_shift {
|
QDialog#QtSoftwareKeyboardDialog QPushButton#button_shift {
|
||||||
background-position: left top;
|
image: url(:/overlay/osk_button_shift_lock_off.png);
|
||||||
background-repeat: no-repeat;
|
image-position: left;
|
||||||
background-origin: content;
|
|
||||||
background-image: url(:/overlay/osk_button_shift_lock_off.png);
|
|
||||||
qproperty-icon: url(:/overlay/osk_button_shift_dark.png);
|
qproperty-icon: url(:/overlay/osk_button_shift_dark.png);
|
||||||
qproperty-iconSize: 36px;
|
qproperty-iconSize: 36px;
|
||||||
}
|
}
|
||||||
|
|
||||||
QDialog#QtSoftwareKeyboardDialog QPushButton#button_shift_shift {
|
QDialog#QtSoftwareKeyboardDialog QPushButton#button_shift_shift {
|
||||||
background-position: left top;
|
image: url(:/overlay/osk_button_shift_lock_off.png);
|
||||||
background-repeat: no-repeat;
|
image-position: left;
|
||||||
background-origin: content;
|
|
||||||
background-image: url(:/overlay/osk_button_shift_lock_off.png);
|
|
||||||
qproperty-icon: url(:/overlay/osk_button_shift_on_dark.png);
|
qproperty-icon: url(:/overlay/osk_button_shift_on_dark.png);
|
||||||
qproperty-iconSize: 36px;
|
qproperty-iconSize: 36px;
|
||||||
}
|
}
|
||||||
@ -1936,18 +1926,18 @@ QDialog#QtSoftwareKeyboardDialog QPushButton#button_return:disabled {
|
|||||||
QDialog#QtSoftwareKeyboardDialog QPushButton#button_ok:disabled,
|
QDialog#QtSoftwareKeyboardDialog QPushButton#button_ok:disabled,
|
||||||
QDialog#QtSoftwareKeyboardDialog QPushButton#button_ok_shift:disabled,
|
QDialog#QtSoftwareKeyboardDialog QPushButton#button_ok_shift:disabled,
|
||||||
QDialog#QtSoftwareKeyboardDialog QPushButton#button_ok_num:disabled {
|
QDialog#QtSoftwareKeyboardDialog QPushButton#button_ok_num:disabled {
|
||||||
background-image: url(:/overlay/osk_button_plus_dark_disabled.png);
|
image: url(:/overlay/osk_button_plus_dark_disabled.png);
|
||||||
}
|
}
|
||||||
|
|
||||||
QDialog#QtSoftwareKeyboardDialog QPushButton#button_backspace:disabled,
|
QDialog#QtSoftwareKeyboardDialog QPushButton#button_backspace:disabled,
|
||||||
QDialog#QtSoftwareKeyboardDialog QPushButton#button_backspace_shift:disabled,
|
QDialog#QtSoftwareKeyboardDialog QPushButton#button_backspace_shift:disabled,
|
||||||
QDialog#QtSoftwareKeyboardDialog QPushButton#button_backspace_num:disabled {
|
QDialog#QtSoftwareKeyboardDialog QPushButton#button_backspace_num:disabled {
|
||||||
background-image: url(:/overlay/osk_button_B_dark_disabled.png);
|
image: url(:/overlay/osk_button_B_dark_disabled.png);
|
||||||
}
|
}
|
||||||
|
|
||||||
QDialog#QtSoftwareKeyboardDialog QPushButton#button_space:disabled,
|
QDialog#QtSoftwareKeyboardDialog QPushButton#button_space:disabled,
|
||||||
QDialog#QtSoftwareKeyboardDialog QPushButton#button_space_shift:disabled {
|
QDialog#QtSoftwareKeyboardDialog QPushButton#button_space_shift:disabled {
|
||||||
background-image: url(:/overlay/osk_button_Y_dark_disabled.png);
|
image: url(:/overlay/osk_button_Y_dark_disabled.png);
|
||||||
}
|
}
|
||||||
|
|
||||||
QDialog#QtSoftwareKeyboardDialog QFrame,
|
QDialog#QtSoftwareKeyboardDialog QFrame,
|
||||||
|
@ -2740,46 +2740,36 @@ QDialog#QtSoftwareKeyboardDialog QPushButton#button_backspace_num:pressed {
|
|||||||
QDialog#QtSoftwareKeyboardDialog QPushButton#button_backspace,
|
QDialog#QtSoftwareKeyboardDialog QPushButton#button_backspace,
|
||||||
QDialog#QtSoftwareKeyboardDialog QPushButton#button_backspace_shift,
|
QDialog#QtSoftwareKeyboardDialog QPushButton#button_backspace_shift,
|
||||||
QDialog#QtSoftwareKeyboardDialog QPushButton#button_backspace_num {
|
QDialog#QtSoftwareKeyboardDialog QPushButton#button_backspace_num {
|
||||||
background-position: right top;
|
image: url(:/overlay/osk_button_B_dark.png);
|
||||||
background-repeat: no-repeat;
|
image-position: right;
|
||||||
background-origin: content;
|
|
||||||
background-image: url(:/overlay/osk_button_B_dark.png);
|
|
||||||
qproperty-icon: url(:/overlay/osk_button_backspace_dark.png);
|
qproperty-icon: url(:/overlay/osk_button_backspace_dark.png);
|
||||||
qproperty-iconSize: 36px;
|
qproperty-iconSize: 36px;
|
||||||
}
|
}
|
||||||
|
|
||||||
QDialog#QtSoftwareKeyboardDialog QPushButton#button_space,
|
QDialog#QtSoftwareKeyboardDialog QPushButton#button_space,
|
||||||
QDialog#QtSoftwareKeyboardDialog QPushButton#button_space_shift {
|
QDialog#QtSoftwareKeyboardDialog QPushButton#button_space_shift {
|
||||||
background-position: right top;
|
image: url(:/overlay/osk_button_Y_dark.png);
|
||||||
background-repeat: no-repeat;
|
image-position: right;
|
||||||
background-origin: content;
|
|
||||||
background-image: url(:/overlay/osk_button_Y_dark.png);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
QDialog#QtSoftwareKeyboardDialog QPushButton#button_ok,
|
QDialog#QtSoftwareKeyboardDialog QPushButton#button_ok,
|
||||||
QDialog#QtSoftwareKeyboardDialog QPushButton#button_ok_shift,
|
QDialog#QtSoftwareKeyboardDialog QPushButton#button_ok_shift,
|
||||||
QDialog#QtSoftwareKeyboardDialog QPushButton#button_ok_num {
|
QDialog#QtSoftwareKeyboardDialog QPushButton#button_ok_num {
|
||||||
color: rgba(44, 44, 44, 1);
|
color: rgba(44, 44, 44, 1);
|
||||||
background-position: right top;
|
image: url(:/overlay/osk_button_plus_dark.png);
|
||||||
background-repeat: no-repeat;
|
image-position: right;
|
||||||
background-origin: content;
|
|
||||||
background-image: url(:/overlay/osk_button_plus_dark.png);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
QDialog#QtSoftwareKeyboardDialog QPushButton#button_shift {
|
QDialog#QtSoftwareKeyboardDialog QPushButton#button_shift {
|
||||||
background-position: left top;
|
image: url(:/overlay/osk_button_shift_lock_off.png);
|
||||||
background-repeat: no-repeat;
|
image-position: left;
|
||||||
background-origin: content;
|
|
||||||
background-image: url(:/overlay/osk_button_shift_lock_off.png);
|
|
||||||
qproperty-icon: url(:/overlay/osk_button_shift_dark.png);
|
qproperty-icon: url(:/overlay/osk_button_shift_dark.png);
|
||||||
qproperty-iconSize: 36px;
|
qproperty-iconSize: 36px;
|
||||||
}
|
}
|
||||||
|
|
||||||
QDialog#QtSoftwareKeyboardDialog QPushButton#button_shift_shift {
|
QDialog#QtSoftwareKeyboardDialog QPushButton#button_shift_shift {
|
||||||
background-position: left top;
|
image: url(:/overlay/osk_button_shift_lock_off.png);
|
||||||
background-repeat: no-repeat;
|
image-position: left;
|
||||||
background-origin: content;
|
|
||||||
background-image: url(:/overlay/osk_button_shift_lock_off.png);
|
|
||||||
qproperty-icon: url(:/overlay/osk_button_shift_on_dark.png);
|
qproperty-icon: url(:/overlay/osk_button_shift_on_dark.png);
|
||||||
qproperty-iconSize: 36px;
|
qproperty-iconSize: 36px;
|
||||||
}
|
}
|
||||||
@ -2871,16 +2861,16 @@ QDialog#QtSoftwareKeyboardDialog QPushButton#button_return:disabled {
|
|||||||
QDialog#QtSoftwareKeyboardDialog QPushButton#button_ok:disabled,
|
QDialog#QtSoftwareKeyboardDialog QPushButton#button_ok:disabled,
|
||||||
QDialog#QtSoftwareKeyboardDialog QPushButton#button_ok_shift:disabled,
|
QDialog#QtSoftwareKeyboardDialog QPushButton#button_ok_shift:disabled,
|
||||||
QDialog#QtSoftwareKeyboardDialog QPushButton#button_ok_num:disabled {
|
QDialog#QtSoftwareKeyboardDialog QPushButton#button_ok_num:disabled {
|
||||||
background-image: url(:/overlay/osk_button_plus_dark_disabled.png);
|
image: url(:/overlay/osk_button_plus_dark_disabled.png);
|
||||||
}
|
}
|
||||||
|
|
||||||
QDialog#QtSoftwareKeyboardDialog QPushButton#button_backspace:disabled,
|
QDialog#QtSoftwareKeyboardDialog QPushButton#button_backspace:disabled,
|
||||||
QDialog#QtSoftwareKeyboardDialog QPushButton#button_backspace_shift:disabled,
|
QDialog#QtSoftwareKeyboardDialog QPushButton#button_backspace_shift:disabled,
|
||||||
QDialog#QtSoftwareKeyboardDialog QPushButton#button_backspace_num:disabled {
|
QDialog#QtSoftwareKeyboardDialog QPushButton#button_backspace_num:disabled {
|
||||||
background-image: url(:/overlay/osk_button_B_dark_disabled.png);
|
image: url(:/overlay/osk_button_B_dark_disabled.png);
|
||||||
}
|
}
|
||||||
|
|
||||||
QDialog#QtSoftwareKeyboardDialog QPushButton#button_space:disabled,
|
QDialog#QtSoftwareKeyboardDialog QPushButton#button_space:disabled,
|
||||||
QDialog#QtSoftwareKeyboardDialog QPushButton#button_space_shift:disabled {
|
QDialog#QtSoftwareKeyboardDialog QPushButton#button_space_shift:disabled {
|
||||||
background-image: url(:/overlay/osk_button_Y_dark_disabled.png);
|
image: url(:/overlay/osk_button_Y_dark_disabled.png);
|
||||||
}
|
}
|
||||||
|
@ -393,6 +393,8 @@ add_library(core STATIC
|
|||||||
hle/service/hid/xcd.cpp
|
hle/service/hid/xcd.cpp
|
||||||
hle/service/hid/xcd.h
|
hle/service/hid/xcd.h
|
||||||
hle/service/hid/errors.h
|
hle/service/hid/errors.h
|
||||||
|
hle/service/hid/controllers/console_sixaxis.cpp
|
||||||
|
hle/service/hid/controllers/console_sixaxis.h
|
||||||
hle/service/hid/controllers/controller_base.cpp
|
hle/service/hid/controllers/controller_base.cpp
|
||||||
hle/service/hid/controllers/controller_base.h
|
hle/service/hid/controllers/controller_base.h
|
||||||
hle/service/hid/controllers/debug_pad.cpp
|
hle/service/hid/controllers/debug_pad.cpp
|
||||||
|
@ -11,6 +11,7 @@
|
|||||||
#include <utility>
|
#include <utility>
|
||||||
#include "common/logging/log.h"
|
#include "common/logging/log.h"
|
||||||
#include "common/param_package.h"
|
#include "common/param_package.h"
|
||||||
|
#include "common/quaternion.h"
|
||||||
#include "common/vector_math.h"
|
#include "common/vector_math.h"
|
||||||
|
|
||||||
namespace Input {
|
namespace Input {
|
||||||
@ -143,9 +144,10 @@ using VibrationDevice = InputDevice<u8>;
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* A motion status is an object that returns a tuple of accelerometer state vector,
|
* A motion status is an object that returns a tuple of accelerometer state vector,
|
||||||
* gyroscope state vector, rotation state vector and orientation state matrix.
|
* gyroscope state vector, rotation state vector, orientation state matrix and quaterion state
|
||||||
|
* vector.
|
||||||
*
|
*
|
||||||
* For both vectors:
|
* For both 3D vectors:
|
||||||
* x+ is the same direction as RIGHT on D-pad.
|
* x+ is the same direction as RIGHT on D-pad.
|
||||||
* y+ is normal to the touch screen, pointing outward.
|
* y+ is normal to the touch screen, pointing outward.
|
||||||
* z+ is the same direction as UP on D-pad.
|
* z+ is the same direction as UP on D-pad.
|
||||||
@ -164,9 +166,13 @@ using VibrationDevice = InputDevice<u8>;
|
|||||||
* x vector
|
* x vector
|
||||||
* y vector
|
* y vector
|
||||||
* z vector
|
* z vector
|
||||||
|
*
|
||||||
|
* For quaternion state vector
|
||||||
|
* xyz vector
|
||||||
|
* w float
|
||||||
*/
|
*/
|
||||||
using MotionStatus = std::tuple<Common::Vec3<float>, Common::Vec3<float>, Common::Vec3<float>,
|
using MotionStatus = std::tuple<Common::Vec3<float>, Common::Vec3<float>, Common::Vec3<float>,
|
||||||
std::array<Common::Vec3f, 3>>;
|
std::array<Common::Vec3f, 3>, Common::Quaternion<f32>>;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A motion device is an input device that returns a motion status object
|
* A motion device is an input device that returns a motion status object
|
||||||
|
@ -36,6 +36,10 @@ std::shared_ptr<TransferMemory> TransferMemory::Create(KernelCore& kernel,
|
|||||||
return transfer_memory;
|
return transfer_memory;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
u8* TransferMemory::GetPointer() {
|
||||||
|
return memory.GetPointer(base_address);
|
||||||
|
}
|
||||||
|
|
||||||
const u8* TransferMemory::GetPointer() const {
|
const u8* TransferMemory::GetPointer() const {
|
||||||
return memory.GetPointer(base_address);
|
return memory.GetPointer(base_address);
|
||||||
}
|
}
|
||||||
|
@ -56,6 +56,9 @@ public:
|
|||||||
return HANDLE_TYPE;
|
return HANDLE_TYPE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Gets a pointer to the backing block of this instance.
|
||||||
|
u8* GetPointer();
|
||||||
|
|
||||||
/// Gets a pointer to the backing block of this instance.
|
/// Gets a pointer to the backing block of this instance.
|
||||||
const u8* GetPointer() const;
|
const u8* GetPointer() const;
|
||||||
|
|
||||||
|
90
src/core/hle/service/hid/controllers/console_sixaxis.cpp
Executable file
@ -0,0 +1,90 @@
|
|||||||
|
// Copyright 2021 yuzu Emulator Project
|
||||||
|
// Licensed under GPLv2 or any later version
|
||||||
|
// Refer to the license.txt file included.
|
||||||
|
|
||||||
|
#include "common/settings.h"
|
||||||
|
#include "core/core_timing.h"
|
||||||
|
#include "core/hle/service/hid/controllers/console_sixaxis.h"
|
||||||
|
|
||||||
|
namespace Service::HID {
|
||||||
|
constexpr std::size_t SHARED_MEMORY_OFFSET = 0x3C200;
|
||||||
|
|
||||||
|
Controller_ConsoleSixAxis::Controller_ConsoleSixAxis(Core::System& system)
|
||||||
|
: ControllerBase(system) {}
|
||||||
|
Controller_ConsoleSixAxis::~Controller_ConsoleSixAxis() = default;
|
||||||
|
|
||||||
|
void Controller_ConsoleSixAxis::OnInit() {}
|
||||||
|
|
||||||
|
void Controller_ConsoleSixAxis::OnRelease() {}
|
||||||
|
|
||||||
|
void Controller_ConsoleSixAxis::OnUpdate(const Core::Timing::CoreTiming& core_timing, u8* data,
|
||||||
|
std::size_t size) {
|
||||||
|
seven_six_axis.header.timestamp = core_timing.GetCPUTicks();
|
||||||
|
seven_six_axis.header.total_entry_count = 17;
|
||||||
|
|
||||||
|
if (!IsControllerActivated() || !is_transfer_memory_set) {
|
||||||
|
seven_six_axis.header.entry_count = 0;
|
||||||
|
seven_six_axis.header.last_entry_index = 0;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
seven_six_axis.header.entry_count = 16;
|
||||||
|
|
||||||
|
const auto& last_entry =
|
||||||
|
seven_six_axis.sevensixaxis_states[seven_six_axis.header.last_entry_index];
|
||||||
|
seven_six_axis.header.last_entry_index = (seven_six_axis.header.last_entry_index + 1) % 17;
|
||||||
|
auto& cur_entry = seven_six_axis.sevensixaxis_states[seven_six_axis.header.last_entry_index];
|
||||||
|
|
||||||
|
cur_entry.sampling_number = last_entry.sampling_number + 1;
|
||||||
|
cur_entry.sampling_number2 = cur_entry.sampling_number;
|
||||||
|
|
||||||
|
// Try to read sixaxis sensor states
|
||||||
|
MotionDevice motion_device{};
|
||||||
|
const auto& device = motions[0];
|
||||||
|
if (device) {
|
||||||
|
std::tie(motion_device.accel, motion_device.gyro, motion_device.rotation,
|
||||||
|
motion_device.orientation, motion_device.quaternion) = device->GetStatus();
|
||||||
|
console_six_axis.is_seven_six_axis_sensor_at_rest = motion_device.gyro.Length2() < 0.0001f;
|
||||||
|
}
|
||||||
|
|
||||||
|
cur_entry.accel = motion_device.accel;
|
||||||
|
// Zero gyro values as they just mess up with the camera
|
||||||
|
// Note: Probably a correct sensivity setting must be set
|
||||||
|
cur_entry.gyro = {};
|
||||||
|
cur_entry.quaternion = {
|
||||||
|
{
|
||||||
|
motion_device.quaternion.xyz.y,
|
||||||
|
motion_device.quaternion.xyz.x,
|
||||||
|
-motion_device.quaternion.w,
|
||||||
|
},
|
||||||
|
-motion_device.quaternion.xyz.z,
|
||||||
|
};
|
||||||
|
|
||||||
|
console_six_axis.sampling_number++;
|
||||||
|
// TODO(German77): Find the purpose of those values
|
||||||
|
console_six_axis.verticalization_error = 0.0f;
|
||||||
|
console_six_axis.gyro_bias = {0.0f, 0.0f, 0.0f};
|
||||||
|
|
||||||
|
// Update console six axis shared memory
|
||||||
|
std::memcpy(data + SHARED_MEMORY_OFFSET, &console_six_axis, sizeof(console_six_axis));
|
||||||
|
// Update seven six axis transfer memory
|
||||||
|
std::memcpy(transfer_memory, &seven_six_axis, sizeof(seven_six_axis));
|
||||||
|
}
|
||||||
|
|
||||||
|
void Controller_ConsoleSixAxis::OnLoadInputDevices() {
|
||||||
|
const auto player = Settings::values.players.GetValue()[0];
|
||||||
|
std::transform(player.motions.begin() + Settings::NativeMotion::MOTION_HID_BEGIN,
|
||||||
|
player.motions.begin() + Settings::NativeMotion::MOTION_HID_END, motions.begin(),
|
||||||
|
Input::CreateDevice<Input::MotionDevice>);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Controller_ConsoleSixAxis::SetTransferMemoryPointer(u8* t_mem_1) {
|
||||||
|
is_transfer_memory_set = true;
|
||||||
|
transfer_memory = t_mem_1;
|
||||||
|
};
|
||||||
|
|
||||||
|
void Controller_ConsoleSixAxis::ResetTimestamp() {
|
||||||
|
auto& cur_entry = seven_six_axis.sevensixaxis_states[seven_six_axis.header.last_entry_index];
|
||||||
|
cur_entry.sampling_number = 0;
|
||||||
|
cur_entry.sampling_number2 = 0;
|
||||||
|
}
|
||||||
|
} // namespace Service::HID
|
80
src/core/hle/service/hid/controllers/console_sixaxis.h
Executable file
@ -0,0 +1,80 @@
|
|||||||
|
// Copyright 2021 yuzu Emulator Project
|
||||||
|
// Licensed under GPLv2 or any later version
|
||||||
|
// Refer to the license.txt file included.
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include <array>
|
||||||
|
#include "common/bit_field.h"
|
||||||
|
#include "common/common_types.h"
|
||||||
|
#include "common/quaternion.h"
|
||||||
|
#include "core/frontend/input.h"
|
||||||
|
#include "core/hle/service/hid/controllers/controller_base.h"
|
||||||
|
|
||||||
|
namespace Service::HID {
|
||||||
|
class Controller_ConsoleSixAxis final : public ControllerBase {
|
||||||
|
public:
|
||||||
|
explicit Controller_ConsoleSixAxis(Core::System& system);
|
||||||
|
~Controller_ConsoleSixAxis() override;
|
||||||
|
|
||||||
|
// Called when the controller is initialized
|
||||||
|
void OnInit() override;
|
||||||
|
|
||||||
|
// When the controller is released
|
||||||
|
void OnRelease() override;
|
||||||
|
|
||||||
|
// When the controller is requesting an update for the shared memory
|
||||||
|
void OnUpdate(const Core::Timing::CoreTiming& core_timing, u8* data, size_t size) override;
|
||||||
|
|
||||||
|
// Called when input devices should be loaded
|
||||||
|
void OnLoadInputDevices() override;
|
||||||
|
|
||||||
|
// Called on InitializeSevenSixAxisSensor
|
||||||
|
void SetTransferMemoryPointer(u8* t_mem_1);
|
||||||
|
|
||||||
|
// Called on ResetSevenSixAxisSensorTimestamp
|
||||||
|
void ResetTimestamp();
|
||||||
|
|
||||||
|
private:
|
||||||
|
struct SevenSixAxisState {
|
||||||
|
INSERT_PADDING_WORDS(4); // unused
|
||||||
|
s64_le sampling_number{};
|
||||||
|
s64_le sampling_number2{};
|
||||||
|
u64 unknown{};
|
||||||
|
Common::Vec3f accel{};
|
||||||
|
Common::Vec3f gyro{};
|
||||||
|
Common::Quaternion<f32> quaternion{};
|
||||||
|
};
|
||||||
|
static_assert(sizeof(SevenSixAxisState) == 0x50, "SevenSixAxisState is an invalid size");
|
||||||
|
|
||||||
|
struct SevenSixAxisMemory {
|
||||||
|
CommonHeader header{};
|
||||||
|
std::array<SevenSixAxisState, 0x21> sevensixaxis_states{};
|
||||||
|
};
|
||||||
|
static_assert(sizeof(SevenSixAxisMemory) == 0xA70, "SevenSixAxisMemory is an invalid size");
|
||||||
|
|
||||||
|
struct ConsoleSharedMemory {
|
||||||
|
u64_le sampling_number{};
|
||||||
|
bool is_seven_six_axis_sensor_at_rest{};
|
||||||
|
f32 verticalization_error{};
|
||||||
|
Common::Vec3f gyro_bias{};
|
||||||
|
};
|
||||||
|
static_assert(sizeof(ConsoleSharedMemory) == 0x20, "ConsoleSharedMemory is an invalid size");
|
||||||
|
|
||||||
|
struct MotionDevice {
|
||||||
|
Common::Vec3f accel;
|
||||||
|
Common::Vec3f gyro;
|
||||||
|
Common::Vec3f rotation;
|
||||||
|
std::array<Common::Vec3f, 3> orientation;
|
||||||
|
Common::Quaternion<f32> quaternion;
|
||||||
|
};
|
||||||
|
|
||||||
|
using MotionArray =
|
||||||
|
std::array<std::unique_ptr<Input::MotionDevice>, Settings::NativeMotion::NUM_MOTIONS_HID>;
|
||||||
|
u8* transfer_memory;
|
||||||
|
MotionArray motions;
|
||||||
|
bool is_transfer_memory_set = false;
|
||||||
|
ConsoleSharedMemory console_six_axis{};
|
||||||
|
SevenSixAxisMemory seven_six_axis{};
|
||||||
|
};
|
||||||
|
} // namespace Service::HID
|
@ -654,8 +654,8 @@ void Controller_NPad::OnMotionUpdate(const Core::Timing::CoreTiming& core_timing
|
|||||||
const auto& device = motions[i][e];
|
const auto& device = motions[i][e];
|
||||||
if (device) {
|
if (device) {
|
||||||
std::tie(motion_devices[e].accel, motion_devices[e].gyro,
|
std::tie(motion_devices[e].accel, motion_devices[e].gyro,
|
||||||
motion_devices[e].rotation, motion_devices[e].orientation) =
|
motion_devices[e].rotation, motion_devices[e].orientation,
|
||||||
device->GetStatus();
|
motion_devices[e].quaternion) = device->GetStatus();
|
||||||
sixaxis_at_rest = sixaxis_at_rest && motion_devices[e].gyro.Length2() < 0.0001f;
|
sixaxis_at_rest = sixaxis_at_rest && motion_devices[e].gyro.Length2() < 0.0001f;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -8,6 +8,7 @@
|
|||||||
#include <atomic>
|
#include <atomic>
|
||||||
#include "common/bit_field.h"
|
#include "common/bit_field.h"
|
||||||
#include "common/common_types.h"
|
#include "common/common_types.h"
|
||||||
|
#include "common/quaternion.h"
|
||||||
#include "common/settings.h"
|
#include "common/settings.h"
|
||||||
#include "core/frontend/input.h"
|
#include "core/frontend/input.h"
|
||||||
#include "core/hle/kernel/object.h"
|
#include "core/hle/kernel/object.h"
|
||||||
@ -467,6 +468,7 @@ private:
|
|||||||
Common::Vec3f gyro;
|
Common::Vec3f gyro;
|
||||||
Common::Vec3f rotation;
|
Common::Vec3f rotation;
|
||||||
std::array<Common::Vec3f, 3> orientation;
|
std::array<Common::Vec3f, 3> orientation;
|
||||||
|
Common::Quaternion<f32> quaternion;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct NfcXcdHandle {
|
struct NfcXcdHandle {
|
||||||
|
@ -26,6 +26,7 @@
|
|||||||
#include "core/hle/service/hid/xcd.h"
|
#include "core/hle/service/hid/xcd.h"
|
||||||
#include "core/hle/service/service.h"
|
#include "core/hle/service/service.h"
|
||||||
|
|
||||||
|
#include "core/hle/service/hid/controllers/console_sixaxis.h"
|
||||||
#include "core/hle/service/hid/controllers/controller_base.h"
|
#include "core/hle/service/hid/controllers/controller_base.h"
|
||||||
#include "core/hle/service/hid/controllers/debug_pad.h"
|
#include "core/hle/service/hid/controllers/debug_pad.h"
|
||||||
#include "core/hle/service/hid/controllers/gesture.h"
|
#include "core/hle/service/hid/controllers/gesture.h"
|
||||||
@ -67,7 +68,7 @@ IAppletResource::IAppletResource(Core::System& system_)
|
|||||||
MakeController<Controller_Stubbed>(HidController::UniquePad);
|
MakeController<Controller_Stubbed>(HidController::UniquePad);
|
||||||
MakeController<Controller_NPad>(HidController::NPad);
|
MakeController<Controller_NPad>(HidController::NPad);
|
||||||
MakeController<Controller_Gesture>(HidController::Gesture);
|
MakeController<Controller_Gesture>(HidController::Gesture);
|
||||||
MakeController<Controller_Stubbed>(HidController::ConsoleSixAxisSensor);
|
MakeController<Controller_ConsoleSixAxis>(HidController::ConsoleSixAxisSensor);
|
||||||
|
|
||||||
// Homebrew doesn't try to activate some controllers, so we activate them by default
|
// Homebrew doesn't try to activate some controllers, so we activate them by default
|
||||||
GetController<Controller_NPad>(HidController::NPad).ActivateController();
|
GetController<Controller_NPad>(HidController::NPad).ActivateController();
|
||||||
@ -78,8 +79,6 @@ IAppletResource::IAppletResource(Core::System& system_)
|
|||||||
GetController<Controller_Stubbed>(HidController::CaptureButton).SetCommonHeaderOffset(0x5000);
|
GetController<Controller_Stubbed>(HidController::CaptureButton).SetCommonHeaderOffset(0x5000);
|
||||||
GetController<Controller_Stubbed>(HidController::InputDetector).SetCommonHeaderOffset(0x5200);
|
GetController<Controller_Stubbed>(HidController::InputDetector).SetCommonHeaderOffset(0x5200);
|
||||||
GetController<Controller_Stubbed>(HidController::UniquePad).SetCommonHeaderOffset(0x5A00);
|
GetController<Controller_Stubbed>(HidController::UniquePad).SetCommonHeaderOffset(0x5A00);
|
||||||
GetController<Controller_Stubbed>(HidController::ConsoleSixAxisSensor)
|
|
||||||
.SetCommonHeaderOffset(0x3C200);
|
|
||||||
|
|
||||||
// Register update callbacks
|
// Register update callbacks
|
||||||
pad_update_event = Core::Timing::CreateEvent(
|
pad_update_event = Core::Timing::CreateEvent(
|
||||||
@ -1404,8 +1403,9 @@ void Hid::ActivateConsoleSixAxisSensor(Kernel::HLERequestContext& ctx) {
|
|||||||
IPC::RequestParser rp{ctx};
|
IPC::RequestParser rp{ctx};
|
||||||
const auto applet_resource_user_id{rp.Pop<u64>()};
|
const auto applet_resource_user_id{rp.Pop<u64>()};
|
||||||
|
|
||||||
LOG_WARNING(Service_HID, "(STUBBED) called, applet_resource_user_id={}",
|
applet_resource->ActivateController(HidController::ConsoleSixAxisSensor);
|
||||||
applet_resource_user_id);
|
|
||||||
|
LOG_WARNING(Service_HID, "called, applet_resource_user_id={}", applet_resource_user_id);
|
||||||
|
|
||||||
IPC::ResponseBuilder rb{ctx, 2};
|
IPC::ResponseBuilder rb{ctx, 2};
|
||||||
rb.Push(RESULT_SUCCESS);
|
rb.Push(RESULT_SUCCESS);
|
||||||
@ -1455,8 +1455,9 @@ void Hid::ActivateSevenSixAxisSensor(Kernel::HLERequestContext& ctx) {
|
|||||||
IPC::RequestParser rp{ctx};
|
IPC::RequestParser rp{ctx};
|
||||||
const auto applet_resource_user_id{rp.Pop<u64>()};
|
const auto applet_resource_user_id{rp.Pop<u64>()};
|
||||||
|
|
||||||
LOG_WARNING(Service_HID, "(STUBBED) called, applet_resource_user_id={}",
|
applet_resource->ActivateController(HidController::ConsoleSixAxisSensor);
|
||||||
applet_resource_user_id);
|
|
||||||
|
LOG_WARNING(Service_HID, "called, applet_resource_user_id={}", applet_resource_user_id);
|
||||||
|
|
||||||
IPC::ResponseBuilder rb{ctx, 2};
|
IPC::ResponseBuilder rb{ctx, 2};
|
||||||
rb.Push(RESULT_SUCCESS);
|
rb.Push(RESULT_SUCCESS);
|
||||||
@ -1518,8 +1519,15 @@ void Hid::InitializeSevenSixAxisSensor(Kernel::HLERequestContext& ctx) {
|
|||||||
ASSERT_MSG(t_mem_1->GetSize() == 0x1000, "t_mem_1 has incorrect size");
|
ASSERT_MSG(t_mem_1->GetSize() == 0x1000, "t_mem_1 has incorrect size");
|
||||||
ASSERT_MSG(t_mem_2->GetSize() == 0x7F000, "t_mem_2 has incorrect size");
|
ASSERT_MSG(t_mem_2->GetSize() == 0x7F000, "t_mem_2 has incorrect size");
|
||||||
|
|
||||||
|
// Activate console six axis controller
|
||||||
|
applet_resource->GetController<Controller_ConsoleSixAxis>(HidController::ConsoleSixAxisSensor)
|
||||||
|
.ActivateController();
|
||||||
|
|
||||||
|
applet_resource->GetController<Controller_ConsoleSixAxis>(HidController::ConsoleSixAxisSensor)
|
||||||
|
.SetTransferMemoryPointer(t_mem_1->GetPointer());
|
||||||
|
|
||||||
LOG_WARNING(Service_HID,
|
LOG_WARNING(Service_HID,
|
||||||
"(STUBBED) called, t_mem_1_handle=0x{:08X}, t_mem_2_handle=0x{:08X}, "
|
"called, t_mem_1_handle=0x{:08X}, t_mem_2_handle=0x{:08X}, "
|
||||||
"applet_resource_user_id={}",
|
"applet_resource_user_id={}",
|
||||||
t_mem_1_handle, t_mem_2_handle, applet_resource_user_id);
|
t_mem_1_handle, t_mem_2_handle, applet_resource_user_id);
|
||||||
|
|
||||||
@ -1542,8 +1550,10 @@ void Hid::ResetSevenSixAxisSensorTimestamp(Kernel::HLERequestContext& ctx) {
|
|||||||
IPC::RequestParser rp{ctx};
|
IPC::RequestParser rp{ctx};
|
||||||
const auto applet_resource_user_id{rp.Pop<u64>()};
|
const auto applet_resource_user_id{rp.Pop<u64>()};
|
||||||
|
|
||||||
LOG_WARNING(Service_HID, "(STUBBED) called, applet_resource_user_id={}",
|
applet_resource->GetController<Controller_ConsoleSixAxis>(HidController::ConsoleSixAxisSensor)
|
||||||
applet_resource_user_id);
|
.ResetTimestamp();
|
||||||
|
|
||||||
|
LOG_WARNING(Service_HID, "called, applet_resource_user_id={}", applet_resource_user_id);
|
||||||
|
|
||||||
IPC::ResponseBuilder rb{ctx, 2};
|
IPC::ResponseBuilder rb{ctx, 2};
|
||||||
rb.Push(RESULT_SUCCESS);
|
rb.Push(RESULT_SUCCESS);
|
||||||
|
@ -155,12 +155,19 @@ void Adapter::UpdateStateAxes(std::size_t port, const AdapterPayload& adapter_pa
|
|||||||
for (const PadAxes axis : axes) {
|
for (const PadAxes axis : axes) {
|
||||||
const auto index = static_cast<std::size_t>(axis);
|
const auto index = static_cast<std::size_t>(axis);
|
||||||
const u8 axis_value = adapter_payload[offset + 3 + index];
|
const u8 axis_value = adapter_payload[offset + 3 + index];
|
||||||
if (pads[port].axis_origin[index] == 255) {
|
if (pads[port].reset_origin_counter <= 3) {
|
||||||
|
if (pads[port].axis_origin[index] != axis_value) {
|
||||||
|
pads[port].reset_origin_counter = 0;
|
||||||
|
}
|
||||||
pads[port].axis_origin[index] = axis_value;
|
pads[port].axis_origin[index] = axis_value;
|
||||||
}
|
}
|
||||||
pads[port].axis_values[index] =
|
pads[port].axis_values[index] =
|
||||||
static_cast<s16>(axis_value - pads[port].axis_origin[index]);
|
static_cast<s16>(axis_value - pads[port].axis_origin[index]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (pads[port].reset_origin_counter <= 3) {
|
||||||
|
pads[port].reset_origin_counter++;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void Adapter::UpdateYuzuSettings(std::size_t port) {
|
void Adapter::UpdateYuzuSettings(std::size_t port) {
|
||||||
@ -375,7 +382,7 @@ void Adapter::ResetDevice(std::size_t port) {
|
|||||||
pads[port].buttons = 0;
|
pads[port].buttons = 0;
|
||||||
pads[port].last_button = PadButton::Undefined;
|
pads[port].last_button = PadButton::Undefined;
|
||||||
pads[port].axis_values.fill(0);
|
pads[port].axis_values.fill(0);
|
||||||
pads[port].axis_origin.fill(255);
|
pads[port].reset_origin_counter = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void Adapter::Reset() {
|
void Adapter::Reset() {
|
||||||
|
@ -70,6 +70,7 @@ struct GCController {
|
|||||||
PadButton last_button{};
|
PadButton last_button{};
|
||||||
std::array<s16, 6> axis_values{};
|
std::array<s16, 6> axis_values{};
|
||||||
std::array<u8, 6> axis_origin{};
|
std::array<u8, 6> axis_origin{};
|
||||||
|
u8 reset_origin_counter{};
|
||||||
};
|
};
|
||||||
|
|
||||||
class Adapter {
|
class Adapter {
|
||||||
|
@ -195,7 +195,8 @@ Input::MotionStatus MotionInput::GetMotion() const {
|
|||||||
const Common::Vec3f accelerometer = GetAcceleration();
|
const Common::Vec3f accelerometer = GetAcceleration();
|
||||||
const Common::Vec3f rotation = GetRotations();
|
const Common::Vec3f rotation = GetRotations();
|
||||||
const std::array<Common::Vec3f, 3> orientation = GetOrientation();
|
const std::array<Common::Vec3f, 3> orientation = GetOrientation();
|
||||||
return {accelerometer, gyroscope, rotation, orientation};
|
const Common::Quaternion<f32> quaternion = GetQuaternion();
|
||||||
|
return {accelerometer, gyroscope, rotation, orientation, quaternion};
|
||||||
}
|
}
|
||||||
|
|
||||||
Input::MotionStatus MotionInput::GetRandomMotion(int accel_magnitude, int gyro_magnitude) const {
|
Input::MotionStatus MotionInput::GetRandomMotion(int accel_magnitude, int gyro_magnitude) const {
|
||||||
@ -218,7 +219,12 @@ Input::MotionStatus MotionInput::GetRandomMotion(int accel_magnitude, int gyro_m
|
|||||||
Common::Vec3f{0.0f, 1.0f, 0.0f},
|
Common::Vec3f{0.0f, 1.0f, 0.0f},
|
||||||
Common::Vec3f{0.0f, 0.0f, 1.0f},
|
Common::Vec3f{0.0f, 0.0f, 1.0f},
|
||||||
};
|
};
|
||||||
return {accelerometer * accel_magnitude, gyroscope * gyro_magnitude, rotation, orientation};
|
constexpr Common::Quaternion<f32> quaternion{
|
||||||
|
{0.0f, 0.0f, 0.0f},
|
||||||
|
1.0f,
|
||||||
|
};
|
||||||
|
return {accelerometer * accel_magnitude, gyroscope * gyro_magnitude, rotation, orientation,
|
||||||
|
quaternion};
|
||||||
}
|
}
|
||||||
|
|
||||||
void MotionInput::ResetOrientation() {
|
void MotionInput::ResetOrientation() {
|
||||||
|
@ -1027,10 +1027,8 @@ void QtSoftwareKeyboardDialog::ChangeBottomOSKIndex() {
|
|||||||
ui->bottomOSK->setCurrentIndex(static_cast<int>(bottom_osk_index));
|
ui->bottomOSK->setCurrentIndex(static_cast<int>(bottom_osk_index));
|
||||||
|
|
||||||
ui->button_shift_shift->setStyleSheet(
|
ui->button_shift_shift->setStyleSheet(
|
||||||
QStringLiteral("background-image: url(:/overlay/osk_button_shift_lock_off.png);"
|
QStringLiteral("image: url(:/overlay/osk_button_shift_lock_off.png);"
|
||||||
"\nbackground-position: left top;"
|
"\nimage-position: left;"));
|
||||||
"\nbackground-repeat: no-repeat;"
|
|
||||||
"\nbackground-origin: content;"));
|
|
||||||
|
|
||||||
ui->button_shift_shift->setIconSize(ui->button_shift->iconSize());
|
ui->button_shift_shift->setIconSize(ui->button_shift->iconSize());
|
||||||
ui->button_backspace_shift->setIconSize(ui->button_backspace->iconSize());
|
ui->button_backspace_shift->setIconSize(ui->button_backspace->iconSize());
|
||||||
@ -1040,10 +1038,8 @@ void QtSoftwareKeyboardDialog::ChangeBottomOSKIndex() {
|
|||||||
caps_lock_enabled = false;
|
caps_lock_enabled = false;
|
||||||
|
|
||||||
ui->button_shift_shift->setStyleSheet(
|
ui->button_shift_shift->setStyleSheet(
|
||||||
QStringLiteral("background-image: url(:/overlay/osk_button_shift_lock_off.png);"
|
QStringLiteral("image: url(:/overlay/osk_button_shift_lock_off.png);"
|
||||||
"\nbackground-position: left top;"
|
"\nimage-position: left;"));
|
||||||
"\nbackground-repeat: no-repeat;"
|
|
||||||
"\nbackground-origin: content;"));
|
|
||||||
|
|
||||||
ui->button_shift_shift->setIconSize(ui->button_shift->iconSize());
|
ui->button_shift_shift->setIconSize(ui->button_shift->iconSize());
|
||||||
ui->button_backspace_shift->setIconSize(ui->button_backspace->iconSize());
|
ui->button_backspace_shift->setIconSize(ui->button_backspace->iconSize());
|
||||||
@ -1056,10 +1052,8 @@ void QtSoftwareKeyboardDialog::ChangeBottomOSKIndex() {
|
|||||||
caps_lock_enabled = true;
|
caps_lock_enabled = true;
|
||||||
|
|
||||||
ui->button_shift_shift->setStyleSheet(
|
ui->button_shift_shift->setStyleSheet(
|
||||||
QStringLiteral("background-image: url(:/overlay/osk_button_shift_lock_on.png);"
|
QStringLiteral("image: url(:/overlay/osk_button_shift_lock_on.png);"
|
||||||
"\nbackground-position: left top;"
|
"\nimage-position: left;"));
|
||||||
"\nbackground-repeat: no-repeat;"
|
|
||||||
"\nbackground-origin: content;"));
|
|
||||||
|
|
||||||
ui->button_shift_shift->setIconSize(ui->button_shift->iconSize());
|
ui->button_shift_shift->setIconSize(ui->button_shift->iconSize());
|
||||||
ui->button_backspace_shift->setIconSize(ui->button_backspace->iconSize());
|
ui->button_backspace_shift->setIconSize(ui->button_backspace->iconSize());
|
||||||
|