From a35269d2071b224bcd7403605acd45e86dde00e5 Mon Sep 17 00:00:00 2001 From: James Benton Date: Sat, 18 Jan 2020 10:28:30 +0000 Subject: [PATCH] vpad: Add VPAD{Get,Set}TPCalibrationParam. --- include/vpad/input.h | 27 +++++++++++++++++++++++++-- 1 file changed, 25 insertions(+), 2 deletions(-) diff --git a/include/vpad/input.h b/include/vpad/input.h index bc16a37..d6593eb 100644 --- a/include/vpad/input.h +++ b/include/vpad/input.h @@ -15,6 +15,7 @@ typedef struct VPADAccStatus VPADAccStatus; typedef struct VPADDirection VPADDirection; typedef struct VPADGyroStatus VPADGyroStatus; typedef struct VPADStatus VPADStatus; +typedef struct VPADTouchCalibrationParam VPADTouchCalibrationParam; typedef struct VPADTouchData VPADTouchData; typedef struct VPADVec2D VPADVec2D; typedef struct VPADVec3D VPADVec3D; @@ -128,6 +129,19 @@ WUT_CHECK_OFFSET(VPADDirection, 0x0C, y); WUT_CHECK_OFFSET(VPADDirection, 0x18, z); WUT_CHECK_SIZE(VPADDirection, 0x24); +struct VPADTouchCalibrationParam +{ + uint16_t adjustX; + uint16_t adjustY; + float scaleX; + float scaleY; +}; +WUT_CHECK_OFFSET(VPADTouchCalibrationParam, 0x00, adjustX); +WUT_CHECK_OFFSET(VPADTouchCalibrationParam, 0x02, adjustY); +WUT_CHECK_OFFSET(VPADTouchCalibrationParam, 0x04, scaleX); +WUT_CHECK_OFFSET(VPADTouchCalibrationParam, 0x08, scaleY); +WUT_CHECK_SIZE(VPADTouchCalibrationParam, 0x0C); + struct VPADTouchData { //! The x-coordinate of a touched point. @@ -243,6 +257,7 @@ WUT_CHECK_OFFSET(VPADStatus, 0xA2, micStatus); WUT_CHECK_OFFSET(VPADStatus, 0xA3, slideVolumeEx); WUT_CHECK_SIZE(VPADStatus, 0xAC); + /** * Initialises the VPAD library for use. * @@ -304,6 +319,14 @@ VPADRead(VPADChan chan, uint32_t count, VPADReadError *outError); +void +VPADGetTPCalibrationParam(VPADChan chan, + VPADTouchCalibrationParam *outParam); + +void +VPADSetTPCalibrationParam(VPADChan chan, + const VPADTouchCalibrationParam *param); + /** * Transform touch data according to the current calibration data. * The calibration used may either be the system default or set by the @@ -328,7 +351,7 @@ VPADRead(VPADChan chan, void VPADGetTPCalibratedPoint(VPADChan chan, VPADTouchData *calibratedData, - VPADTouchData *uncalibratedData); + const VPADTouchData *uncalibratedData); /** * Transform touch data according to the current calibration data. @@ -356,7 +379,7 @@ void VPADGetTPCalibratedPointEx(VPADChan chan, VPADTouchPadResolution tpResolution, VPADTouchData *calibratedData, - VPADTouchData *uncalibratedData); + const VPADTouchData *uncalibratedData); /** * Return a count representing the amount of time left for the given Gamepad's