Skip to content

Commit

Permalink
Merge pull request #546 from andytwoods/min_RT
Browse files Browse the repository at this point in the history
minimum_valid_rt
  • Loading branch information
jodeleeuw committed Oct 23, 2020
2 parents b8ad672 + eb08de2 commit a7916b8
Showing 1 changed file with 23 additions and 11 deletions.
34 changes: 23 additions & 11 deletions jspsych.js
Original file line number Diff line number Diff line change
Expand Up @@ -105,6 +105,7 @@ window.jsPsych = (function() {
'max_load_time': 60000,
'max_preload_attempts': 10,
'default_iti': 0,
'minimum_valid_rt': 0,
'experiment_width': null
};

Expand Down Expand Up @@ -2039,6 +2040,7 @@ jsPsych.pluginAPI = (function() {
}

module.getKeyboardResponse = function(parameters) {

//parameters are: callback_function, valid_responses, rt_method, persist, audio_context, audio_context_start_time, allow_held_key?

parameters.rt_method = (typeof parameters.rt_method === 'undefined') ? 'performance' : parameters.rt_method;
Expand All @@ -2050,46 +2052,56 @@ jsPsych.pluginAPI = (function() {
var start_time;
if (parameters.rt_method == 'performance') {
start_time = performance.now();
} else if (parameters.rt_method == 'audio') {
} else if (parameters.rt_method === 'audio') {
start_time = parameters.audio_context_start_time;
}

var listener_id;

var listener_function = function(e) {

var key_time;
if (parameters.rt_method == 'performance') {
key_time = performance.now();
} else if (parameters.rt_method == 'audio') {
} else if (parameters.rt_method === 'audio') {
key_time = parameters.audio_context.currentTime
}
var rt = key_time - start_time;

// overiding via parameters for testing purposes.
var minimum_valid_rt = parameters.minimum_valid_rt;
if(!minimum_valid_rt){
minimum_valid_rt = jsPsych.initSettings().minimum_valid_rt || 0;
}

if(rt <= minimum_valid_rt){
return;
}

var valid_response = false;
if (typeof parameters.valid_responses === 'undefined' || parameters.valid_responses == jsPsych.ALL_KEYS) {
if (typeof parameters.valid_responses === 'undefined' || parameters.valid_responses === jsPsych.ALL_KEYS) {
valid_response = true;
} else {
if(parameters.valid_responses != jsPsych.NO_KEYS){
if(parameters.valid_responses !== jsPsych.NO_KEYS){
for (var i = 0; i < parameters.valid_responses.length; i++) {
if (typeof parameters.valid_responses[i] == 'string') {
if (typeof parameters.valid_responses[i] === 'string') {
var kc = jsPsych.pluginAPI.convertKeyCharacterToKeyCode(parameters.valid_responses[i]);
if (typeof kc !== 'undefined') {
if (e.keyCode == kc) {
if (e.keyCode === kc) {
valid_response = true;
}
} else {
throw new Error('Invalid key string specified for getKeyboardResponse');
}
} else if (e.keyCode == parameters.valid_responses[i]) {
} else if (e.keyCode === parameters.valid_responses[i]) {
valid_response = true;
}
}
}
}
// check if key was already held down

if (((typeof parameters.allow_held_key == 'undefined') || !parameters.allow_held_key) && valid_response) {
if (typeof held_keys[e.keyCode] !== 'undefined' && held_keys[e.keyCode] == true) {
if (((typeof parameters.allow_held_key === 'undefined') || !parameters.allow_held_key) && valid_response) {
if (typeof held_keys[e.keyCode] !== 'undefined' && held_keys[e.keyCode] === true) {
valid_response = false;
}
}
Expand All @@ -2101,7 +2113,7 @@ jsPsych.pluginAPI = (function() {

parameters.callback_function({
key: e.keyCode,
rt: key_time - start_time
rt: rt,
});

if (keyboard_listeners.includes(listener_id)) {
Expand Down

0 comments on commit a7916b8

Please sign in to comment.