1
0
mirror of https://github.com/XProger/OpenLara.git synced 2025-01-17 21:09:00 +01:00

#15 Linux vibration improvements; #11 turn off gamepad vibration for inventory and loading screen

This commit is contained in:
XProger 2018-03-06 03:50:23 +03:00
parent 9c0573116c
commit 6fb0e2781e
8 changed files with 62 additions and 48 deletions

9
bin/.gitignore vendored Normal file
View File

@ -0,0 +1,9 @@
*.PHD
*.ogg
*.PSX
*.PNG
*.PCX
*.RAW
*.zip
*.txt

View File

@ -345,7 +345,7 @@ struct Camera : ICamera {
virtual void update() {
if (shake > 0.0f) {
shake = max(0.0f, shake - Core::deltaTime);
Input::setJoyVibrate(cameraIndex, clamp(shake, 0.0f, 1.0f), 0);
Input::setJoyVibration(cameraIndex, clamp(shake, 0.0f, 1.0f), 0);
}
if (mode == MODE_CUTSCENE) {

View File

@ -14,6 +14,7 @@ namespace Game {
Stream *nextLevel;
void startLevel(Stream *lvl) {
Input::stopJoyVibration();
delete level;
level = new Level(*lvl);
UI::game = level;

View File

@ -117,12 +117,17 @@ namespace Input {
setJoyDown(index, key, pos.x > 0.0f); // gamepad LT, RT auto-down state
}
void setJoyVibrate(int playerIndex, float L, float R) {
void setJoyVibration(int playerIndex, float L, float R) {
if (!Core::settings.controls[playerIndex].vibration)
return;
osJoyVibrate(Core::settings.controls[playerIndex].joyIndex, L, R);
}
void stopJoyVibration() {
osJoyVibrate(Core::settings.controls[0].joyIndex, 0.0f, 0.0f);
osJoyVibrate(Core::settings.controls[1].joyIndex, 0.0f, 0.0f);
}
InputKey getTouch(int id) {
for (int i = 0; i < COUNT(touch); i++)
if (down[ikTouchA + i] && touch[i].id == id)

View File

@ -647,6 +647,8 @@ struct Inventory {
}
bool toggle(int playerIndex = 0, Page curPage = PAGE_INVENTORY, TR::Entity::Type type = TR::Entity::LARA) {
Input::stopJoyVibration();
this->playerIndex = playerIndex;
titleTimer = 0.0f;

View File

@ -2733,9 +2733,9 @@ struct Lara : Character {
if (hitTimer > 0.0f) {
hitTimer -= Core::deltaTime;
if (hitTimer > 0.0f)
Input::setJoyVibrate(camera->cameraIndex, 0.5f, 0.5f);
Input::setJoyVibration(camera->cameraIndex, 0.5f, 0.5f);
else
Input::setJoyVibrate(camera->cameraIndex, 0, 0);
Input::setJoyVibration(camera->cameraIndex, 0, 0);
}
if (level->isCutsceneLevel())

View File

@ -139,7 +139,6 @@ void* sndFill(void *arg) {
}
void sndInit() {
return;
static const pa_sample_spec spec = {
.format = PA_SAMPLE_S16LE,
.rate = 44100,
@ -198,15 +197,18 @@ InputKey mouseToInputKey(int btn) {
return ikNone;
}
struct JoyDevice {
int fd;
int fe;
vec2 L, R;
ff_effect fx;
char event[128];
int time;
#define JOY_DEAD_ZONE_STICK 8192
#define JOY_DEAD_ZONE_TRIGGER 8192
#define JOY_MIN_UPDATE_FX_TIME 50.0f
float vL, vR, oL, oR;
struct JoyDevice {
int fd; // device file descriptor
int fe; // event file descriptor
vec2 L, R; // left/right stick axes values
float vL, vR; // current value for left/right motor vibration
float oL, oR; // last applied value
int time; // time when we can send effect update
ff_effect fx; // effect structure
} joyDevice[INPUT_JOY_COUNT];
bool osJoyReady(int index) {
@ -219,10 +221,6 @@ void osJoyVibrate(int index, float L, float R) {
joyDevice[index].vR = R;
}
#define JOY_DEAD_ZONE_STICK 8192
#define JOY_DEAD_ZONE_TRIGGER 8192
#define TEST_BIT(arr, bit) ((arr[bit / 32] >> (bit % 32)) & 1)
void joyInit() {
LOG("init gamepads:\n");
char name[128];
@ -261,8 +259,8 @@ void joyInit() {
DIR *dir = opendir(name);
if (!dir) continue;
closedir(dir);
sprintf(joy.event, "/dev/input/event%d", j);
joy.fe = open(joy.event, O_RDWR);
sprintf(name, "/dev/input/event%d", j);
joy.fe = open(name, O_RDWR);
break;
}
@ -273,11 +271,16 @@ void joyInit() {
}
if (joy.fe > -1) {
LOG(" vibration feature\n");
joy.fx.id = -1;
joy.time = osGetTime();
int n_effects;
if (ioctl(joy.fe, EVIOCGEFFECTS, &n_effects) == -1) {
perror("Ioctl query");
}
LOG(" vibration feature %d\n", n_effects);
joy.fx.id = -1;
joy.fx.type = FF_RUMBLE;
joy.fx.replay.delay = 0;
joy.vL = joy.oL = joy.vR = joy.oR = 0.0f;
close(joy.fe);
joy.time = osGetTime();
}
}
}
@ -317,39 +320,32 @@ void joyRumble(JoyDevice &joy) {
if (osGetTime() < joy.time)
return;
close(joy.fe);
joy.fe = open(joy.event, O_RDWR);
if (joy.fe == -1)
LOG("can't open event\n");
input_event event;
event.type = EV_FF;
if (joy.oL != 0.0f || joy.oR != 0.0f) {
event.value = 0;
event.code = joy.fx.id;
if (write(joy.fe, &event, sizeof(event)) == -1)
LOG("! joy stop fx\n");
}
if (joy.vL != 0.0f || joy.vR != 0.0f) {
joy.fx.type = FF_RUMBLE;
// update effect
joy.fx.u.rumble.strong_magnitude = int(joy.vL * 65535);
joy.fx.u.rumble.weak_magnitude = int(joy.vR * 65535);
joy.fx.replay.length = int(max(50.0f, 1000.0f / Core::stats.fps));
joy.fx.replay.delay = 0;
joy.fx.id = -1;
joy.fx.replay.length = int(max(JOY_MIN_UPDATE_FX_TIME, 1000.0f / Core::stats.fps));
if (ioctl(joy.fe, EVIOCSFF, &joy.fx) == -1) {
LOG("! joy drv send fx\n");
return;
LOG("! joy update fx\n");
}
// play effect
event.value = 1;
event.code = joy.fx.id;
if (write(joy.fe, &event, sizeof(event)) == -1)
LOG("! joy play fx\n");
}
} else
if (joy.oL != 0.0f || joy.oR != 0.0f) {
// stop effect
event.value = 0;
event.code = joy.fx.id;
if (write(joy.fe, &event, sizeof(event)) == -1)
LOG("! joy stop fx\n");
}
joy.oL = joy.vL;
joy.oR = joy.vR;

View File

@ -73,10 +73,11 @@ typedef unsigned char uint8;
typedef unsigned short uint16;
typedef unsigned int uint32;
#define FOURCC(str) uint32(((uint8*)(str))[0] | (((uint8*)(str))[1] << 8) | (((uint8*)(str))[2] << 16) | (((uint8*)(str))[3] << 24) )
#define FOURCC(str) uint32(((uint8*)(str))[0] | (((uint8*)(str))[1] << 8) | (((uint8*)(str))[2] << 16) | (((uint8*)(str))[3] << 24) )
#define COUNT(arr) (sizeof(arr) / sizeof(arr[0]))
#define OFFSETOF(T, E) ((size_t)&(((T*)0)->E))
#define COUNT(arr) (sizeof(arr) / sizeof(arr[0]))
#define OFFSETOF(T, E) ((size_t)&(((T*)0)->E))
#define TEST_BIT(arr, bit) ((arr[bit / 32] >> (bit % 32)) & 1)
template <typename T>
inline const T& min(const T &a, const T &b) {