/** * jspsych-same-different * Josh de Leeuw (Updated Oct 2013) * * plugin for showing two stimuli sequentially and getting a same / different judgment * * parameters: * stimuli: array of arrays. inner most array should have two elements, corresponding to the two items that will be shown. * items can be image paths or HTML strings. each inner array is a trial. * answer: array of strings. acceptable values are "same" and "different". represents the correct answer for each trial. * same_key: which key to press to indicate a 'same' response. * different_key: which key to press to indicate a 'different' response. * timing_first_stim: how long to show the first stimulus * timing_second_stim: how long to show the second stim. can be -1, which means to show until a response is given. * timing_gap: how long to show a blank screen in between the two stimuli. * timing_post_trial: how long to show a blank screen after the trial ends. * is_html: must set to true if the stimulus is HTML code. * prompt: HTML string to show when the subject is viewing the stimulus and making a categorization decision. * data: the optional data object * * */ (function($) { jsPsych['same-different'] = (function() { var plugin = {}; plugin.create = function(params) { var trials = new Array(params.stimuli.length); for (var i = 0; i < trials.length; i++) { trials[i] = {}; trials[i].type = "same-different"; trials[i].a_path = params.stimuli[i][0]; trials[i].b_path = params.stimuli[i][1]; trials[i].answer = params.answer[i]; trials[i].same_key = params.same_key || 81; // default is 'q' trials[i].different_key = params.different_key || 80; // default is 'p' // timing parameters trials[i].timing_first_stim = params.timing_first_stim || 1000; trials[i].timing_second_stim = params.timing_second_stim || 1000; // if -1, then second stim is shown until response. trials[i].timing_gap = params.timing_gap || 500; trials[i].timing_post_trial = params.timing_post_trial || 1000; // optional parameters trials[i].is_html = (typeof params.is_html === 'undefined') ? false : true; trials[i].prompt = (typeof params.prompt === 'undefined') ? "" : params.prompt; trials[i].data = (typeof params.data === 'undefined') ? {} : params.data[i]; } return trials; }; var sd_trial_complete = false; plugin.trial = function(display_element, block, trial, part) { switch (part) { case 1: sd_trial_complete = false; // show image if (!trial.is_html) { display_element.append($('', { src: trial.a_path, "class": 'jspsych-same-different-stimulus' })); } else { display_element.append($('
', { html: trial.a_path, "class": 'jspsych-same-different-stimulus' })); } setTimeout(function() { plugin.trial(display_element, block, trial, part + 1); }, trial.timing_first_stim); break; case 2: $('.jspsych-same-different-stimulus').remove(); setTimeout(function() { plugin.trial(display_element, block, trial, part + 1); }, trial.timing_gap); break; case 3: if (!trial.is_html) { display_element.append($('', { src: trial.b_path, "class": 'jspsych-same-different-stimulus', id: 'jspsych-same-different-second-stimulus' })); } else { display_element.append($('
', { html: trial.b_path, "class": 'jspsych-same-different-stimulus', id: 'jspsych-same-different-second-stimulus' })); } if (trial.timing_second_stim > 0) { setTimeout(function() { if (!sd_trial_complete) { $("#jspsych-same-different-second-stimulus").css('visibility', 'hidden'); } }, trial.timing_second_stim); } //show prompt here if (trial.prompt !== "") { display_element.append(trial.prompt); } var startTime = (new Date()).getTime(); var resp_func = function(e) { var flag = false; var correct = false; if (e.which == trial.same_key) { flag = true; if (trial.answer == "same") { correct = true; } } else if (e.which == trial.different_key) { flag = true; if (trial.answer == "different") { correct = true; } } if (flag) { var endTime = (new Date()).getTime(); var rt = (endTime - startTime); var trial_data = { "trial_type": "same-different", "trial_index": block.trial_idx, "rt": rt, "correct": correct, "stimulus": trial.a_path, "stimulus_2": trial.b_path, "key_press": e.which }; block.data[block.trial_idx] = $.extend({}, trial_data, trial.data); $(document).unbind('keyup', resp_func); display_element.html(''); setTimeout(function() { block.next(); }, trial.timing_post_trial); } }; $(document).keyup(resp_func); break; } }; return plugin; })(); })(jQuery);