/** * jsPsych plugin for showing scenes that mimic the experiments described in * * Fiser, J., & Aslin, R. N. (2001). Unsupervised statistical learning of * higher-order spatial structures from visual scenes. Psychological science, * 12(6), 499-504. * * Josh de Leeuw * * documentation: docs.jspsych.org * */ (function($) { jsPsych['vsl-grid-scene'] = (function() { var plugin = {}; plugin.create = function(params) { //params = jsPsych.pluginAPI.enforceArray(params, ['data']) var trials = new Array(params.stimuli.length); for (var i = 0; i < trials.length; i++) { trials[i] = {}; trials[i].stimuli = params.stimuli[i]; trials[i].image_size = params.image_size || [100, 100]; trials[i].timing_duration = (typeof params.timing_duration === 'undefined') ? 2000 : params.timing_duration; //trials[i].prompt = (typeof params.prompt === 'undefined') ? "" : params.prompt; } return trials; }; plugin.trial = function(display_element, trial) { // if any trial variables are functions // this evaluates the function and replaces // it with the output of the function trial = jsPsych.pluginAPI.normalizeTrialVariables(trial); display_element.html(plugin.generate_stimulus(trial.stimuli, trial.image_size)); setTimeout(function() { endTrial(); }, trial.timing_duration); function endTrial() { display_element.html(''); jsPsych.data.write({ "stimulus": JSON.stringify(trial.stimuli) }); jsPsych.finishTrial(); } }; plugin.generate_stimulus = function(pattern, image_size) { var nrows = pattern.length; var ncols = pattern[0].length; // create blank element to hold code that we generate $('body').append($('
', {
id: 'jspsych-vsl-grid-scene-table-' + row + '-' + col,
css: {
padding: image_size[1] / 10 + "px " + image_size[0] / 10 + "px",
border: '1px solid #555'
}
}));
$('#jspsych-vsl-grid-scene-table-' + row + '-' + col).append($(' ', {
id: 'jspsych-vsl-grid-scene-table-cell-' + row + '-' + col,
css: {
width: image_size[0] + "px",
height: image_size[1] + "px"
}
}));
}
}
for (var row = 0; row < nrows; row++) {
for (var col = 0; col < ncols; col++) {
if (pattern[row][col] !== 0) {
$('#jspsych-vsl-grid-scene-table-cell-' + row + '-' + col).append($(' |