jspsych 6.3.0 → 7.1.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +36 -37
- package/css/jspsych.css +39 -39
- package/dist/JsPsych.d.ts +112 -0
- package/dist/TimelineNode.d.ts +34 -0
- package/dist/index.browser.js +3164 -0
- package/dist/index.browser.js.map +1 -0
- package/dist/index.browser.min.js +2 -0
- package/dist/index.browser.min.js.map +1 -0
- package/dist/index.cjs +3158 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.ts +11 -0
- package/dist/index.js +3152 -0
- package/dist/index.js.map +1 -0
- package/dist/migration.d.ts +3 -0
- package/dist/modules/data/DataCollection.d.ts +45 -0
- package/dist/modules/data/DataColumn.d.ts +15 -0
- package/dist/modules/data/index.d.ts +25 -0
- package/dist/modules/data/utils.d.ts +3 -0
- package/dist/modules/extensions.d.ts +22 -0
- package/dist/modules/plugin-api/HardwareAPI.d.ts +15 -0
- package/dist/modules/plugin-api/KeyboardListenerAPI.d.ts +34 -0
- package/dist/modules/plugin-api/MediaAPI.d.ts +27 -0
- package/dist/modules/plugin-api/SimulationAPI.d.ts +41 -0
- package/dist/modules/plugin-api/TimeoutAPI.d.ts +5 -0
- package/dist/modules/plugin-api/index.d.ts +8 -0
- package/dist/modules/plugins.d.ts +129 -0
- package/dist/modules/randomization.d.ts +35 -0
- package/dist/modules/turk.d.ts +40 -0
- package/dist/modules/utils.d.ts +7 -0
- package/package.json +32 -15
- package/src/JsPsych.ts +884 -0
- package/src/TimelineNode.ts +536 -0
- package/src/index.ts +71 -0
- package/src/migration.ts +37 -0
- package/src/modules/data/DataCollection.ts +198 -0
- package/src/modules/data/DataColumn.ts +86 -0
- package/src/modules/data/index.ts +174 -0
- package/src/modules/data/utils.ts +75 -0
- package/src/modules/extensions.ts +23 -0
- package/src/modules/plugin-api/HardwareAPI.ts +32 -0
- package/src/modules/plugin-api/KeyboardListenerAPI.ts +165 -0
- package/src/modules/plugin-api/MediaAPI.ts +337 -0
- package/src/modules/plugin-api/SimulationAPI.ts +181 -0
- package/src/modules/plugin-api/TimeoutAPI.ts +16 -0
- package/src/modules/plugin-api/index.ts +28 -0
- package/src/modules/plugins.ts +158 -0
- package/src/modules/randomization.ts +327 -0
- package/src/modules/turk.ts +99 -0
- package/src/modules/utils.ts +30 -0
- package/.github/workflows/jest.yml +0 -20
- package/code-of-conduct.md +0 -56
- package/contributors.md +0 -61
- package/docs/CNAME +0 -1
- package/docs/about/about.md +0 -18
- package/docs/about/contributing.md +0 -43
- package/docs/about/license.md +0 -25
- package/docs/about/support.md +0 -7
- package/docs/core_library/jspsych-core.md +0 -734
- package/docs/core_library/jspsych-data.md +0 -589
- package/docs/core_library/jspsych-pluginAPI.md +0 -610
- package/docs/core_library/jspsych-randomization.md +0 -397
- package/docs/core_library/jspsych-turk.md +0 -102
- package/docs/extensions/extensions.md +0 -83
- package/docs/extensions/jspsych-ext-webgazer.md +0 -106
- package/docs/img/blue.png +0 -0
- package/docs/img/devtools-change-css.png +0 -0
- package/docs/img/devtools-css-errors.png +0 -0
- package/docs/img/devtools-inspect-element.png +0 -0
- package/docs/img/folder-setup.png +0 -0
- package/docs/img/folder-with-html.png +0 -0
- package/docs/img/githubreleases.jpg +0 -0
- package/docs/img/jspsych-favicon.png +0 -0
- package/docs/img/jspsych-logo-no-text-mono.svg +0 -493
- package/docs/img/jspsych-logo.jpg +0 -0
- package/docs/img/orange.png +0 -0
- package/docs/img/palmer_stim.png +0 -0
- package/docs/img/progress_bar.png +0 -0
- package/docs/img/prolific-study-completion.png +0 -0
- package/docs/img/prolific-study-link.png +0 -0
- package/docs/img/visual_search_example.jpg +0 -0
- package/docs/index.md +0 -9
- package/docs/overview/browser-device-support.md +0 -35
- package/docs/overview/callbacks.md +0 -184
- package/docs/overview/data.md +0 -281
- package/docs/overview/dynamic-parameters.md +0 -147
- package/docs/overview/exclude-browser.md +0 -32
- package/docs/overview/experiment-options.md +0 -149
- package/docs/overview/eye-tracking.md +0 -237
- package/docs/overview/fullscreen.md +0 -36
- package/docs/overview/media-preloading.md +0 -369
- package/docs/overview/mturk.md +0 -77
- package/docs/overview/plugins.md +0 -320
- package/docs/overview/progress-bar.md +0 -110
- package/docs/overview/prolific.md +0 -78
- package/docs/overview/record-browser-interactions.md +0 -23
- package/docs/overview/running-experiments.md +0 -95
- package/docs/overview/style.md +0 -293
- package/docs/overview/timeline.md +0 -457
- package/docs/plugins/jspsych-animation.md +0 -40
- package/docs/plugins/jspsych-audio-button-response.md +0 -60
- package/docs/plugins/jspsych-audio-keyboard-response.md +0 -58
- package/docs/plugins/jspsych-audio-slider-response.md +0 -53
- package/docs/plugins/jspsych-call-function.md +0 -81
- package/docs/plugins/jspsych-canvas-button-response.md +0 -66
- package/docs/plugins/jspsych-canvas-keyboard-response.md +0 -68
- package/docs/plugins/jspsych-canvas-slider-response.md +0 -89
- package/docs/plugins/jspsych-categorize-animation.md +0 -60
- package/docs/plugins/jspsych-categorize-html.md +0 -53
- package/docs/plugins/jspsych-categorize-image.md +0 -53
- package/docs/plugins/jspsych-cloze.md +0 -45
- package/docs/plugins/jspsych-external-html.md +0 -70
- package/docs/plugins/jspsych-free-sort.md +0 -56
- package/docs/plugins/jspsych-fullscreen.md +0 -57
- package/docs/plugins/jspsych-html-button-response.md +0 -42
- package/docs/plugins/jspsych-html-keyboard-response.md +0 -51
- package/docs/plugins/jspsych-html-slider-response.md +0 -45
- package/docs/plugins/jspsych-iat-html.md +0 -64
- package/docs/plugins/jspsych-iat-image.md +0 -64
- package/docs/plugins/jspsych-image-button-response.md +0 -48
- package/docs/plugins/jspsych-image-keyboard-response.md +0 -58
- package/docs/plugins/jspsych-image-slider-response.md +0 -54
- package/docs/plugins/jspsych-instructions.md +0 -58
- package/docs/plugins/jspsych-maxdiff.md +0 -41
- package/docs/plugins/jspsych-preload.md +0 -128
- package/docs/plugins/jspsych-rdk.md +0 -119
- package/docs/plugins/jspsych-reconstruction.md +0 -48
- package/docs/plugins/jspsych-resize.md +0 -39
- package/docs/plugins/jspsych-same-different-html.md +0 -53
- package/docs/plugins/jspsych-same-different-image.md +0 -66
- package/docs/plugins/jspsych-serial-reaction-time-mouse.md +0 -52
- package/docs/plugins/jspsych-serial-reaction-time.md +0 -57
- package/docs/plugins/jspsych-survey-html-form.md +0 -50
- package/docs/plugins/jspsych-survey-likert.md +0 -70
- package/docs/plugins/jspsych-survey-multi-choice.md +0 -48
- package/docs/plugins/jspsych-survey-multi-select.md +0 -53
- package/docs/plugins/jspsych-survey-text.md +0 -63
- package/docs/plugins/jspsych-video-button-response.md +0 -54
- package/docs/plugins/jspsych-video-keyboard-response.md +0 -50
- package/docs/plugins/jspsych-video-slider-response.md +0 -60
- package/docs/plugins/jspsych-virtual-chinrest.md +0 -105
- package/docs/plugins/jspsych-visual-search-circle.md +0 -52
- package/docs/plugins/jspsych-vsl-animate-occlusion.md +0 -55
- package/docs/plugins/jspsych-vsl-grid-scene.md +0 -62
- package/docs/plugins/jspsych-webgazer-calibrate.md +0 -60
- package/docs/plugins/jspsych-webgazer-init-camera.md +0 -31
- package/docs/plugins/jspsych-webgazer-validate.md +0 -43
- package/docs/plugins/list-of-plugins.md +0 -54
- package/docs/tutorials/hello-world.md +0 -162
- package/docs/tutorials/rt-task.md +0 -1334
- package/docs/tutorials/video-tutorials.md +0 -11
- package/examples/add-to-end-of-timeline.html +0 -38
- package/examples/case-sensitive-responses.html +0 -45
- package/examples/conditional-and-loop-functions.html +0 -64
- package/examples/css/jquery-ui.css +0 -1225
- package/examples/css-classes-parameter.html +0 -145
- package/examples/data-add-properties.html +0 -44
- package/examples/data-as-function.html +0 -39
- package/examples/data-from-timeline.html +0 -52
- package/examples/data-from-url.html +0 -21
- package/examples/demo-flanker.html +0 -117
- package/examples/demo-simple-rt-task.html +0 -120
- package/examples/demos/demo_1.html +0 -35
- package/examples/demos/demo_2.html +0 -50
- package/examples/demos/demo_3.html +0 -63
- package/examples/display-element-to-embed-experiment.html +0 -79
- package/examples/end-active-node.html +0 -52
- package/examples/end-experiment.html +0 -45
- package/examples/exclusions.html +0 -32
- package/examples/external_html/simple_consent.html +0 -4
- package/examples/img/1.gif +0 -0
- package/examples/img/10.gif +0 -0
- package/examples/img/11.gif +0 -0
- package/examples/img/12.gif +0 -0
- package/examples/img/2.gif +0 -0
- package/examples/img/3.gif +0 -0
- package/examples/img/4.gif +0 -0
- package/examples/img/5.gif +0 -0
- package/examples/img/6.gif +0 -0
- package/examples/img/7.gif +0 -0
- package/examples/img/8.gif +0 -0
- package/examples/img/9.gif +0 -0
- package/examples/img/age/of1.jpg +0 -0
- package/examples/img/age/of2.jpg +0 -0
- package/examples/img/age/of3.jpg +0 -0
- package/examples/img/age/om1.jpg +0 -0
- package/examples/img/age/om2.jpg +0 -0
- package/examples/img/age/om3.jpg +0 -0
- package/examples/img/age/yf1.jpg +0 -0
- package/examples/img/age/yf4.jpg +0 -0
- package/examples/img/age/yf5.jpg +0 -0
- package/examples/img/age/ym2.jpg +0 -0
- package/examples/img/age/ym3.jpg +0 -0
- package/examples/img/age/ym5.jpg +0 -0
- package/examples/img/backwardN.gif +0 -0
- package/examples/img/blue.png +0 -0
- package/examples/img/card.png +0 -0
- package/examples/img/con1.png +0 -0
- package/examples/img/con2.png +0 -0
- package/examples/img/fixation.gif +0 -0
- package/examples/img/happy_face_1.jpg +0 -0
- package/examples/img/happy_face_2.jpg +0 -0
- package/examples/img/happy_face_3.jpg +0 -0
- package/examples/img/happy_face_4.jpg +0 -0
- package/examples/img/inc1.png +0 -0
- package/examples/img/inc2.png +0 -0
- package/examples/img/normalN.gif +0 -0
- package/examples/img/orange.png +0 -0
- package/examples/img/redX.png +0 -0
- package/examples/img/ribbon.jpg +0 -0
- package/examples/img/sad_face_1.jpg +0 -0
- package/examples/img/sad_face_2.jpg +0 -0
- package/examples/img/sad_face_3.jpg +0 -0
- package/examples/img/sad_face_4.jpg +0 -0
- package/examples/js/snap.svg-min.js +0 -21
- package/examples/js/webgazer.js +0 -88886
- package/examples/jspsych-RDK.html +0 -58
- package/examples/jspsych-animation.html +0 -39
- package/examples/jspsych-audio-button-response.html +0 -58
- package/examples/jspsych-audio-keyboard-response.html +0 -68
- package/examples/jspsych-audio-slider-response.html +0 -61
- package/examples/jspsych-call-function.html +0 -32
- package/examples/jspsych-canvas-button-response.html +0 -95
- package/examples/jspsych-canvas-keyboard-response.html +0 -78
- package/examples/jspsych-canvas-slider-response.html +0 -67
- package/examples/jspsych-categorize-animation.html +0 -49
- package/examples/jspsych-categorize-html.html +0 -33
- package/examples/jspsych-categorize-image.html +0 -44
- package/examples/jspsych-cloze.html +0 -37
- package/examples/jspsych-free-sort.html +0 -109
- package/examples/jspsych-fullscreen.html +0 -45
- package/examples/jspsych-html-button-response.html +0 -43
- package/examples/jspsych-html-keyboard-response.html +0 -42
- package/examples/jspsych-html-slider-response.html +0 -53
- package/examples/jspsych-iat.html +0 -520
- package/examples/jspsych-image-button-response.html +0 -91
- package/examples/jspsych-image-keyboard-response.html +0 -85
- package/examples/jspsych-image-slider-response.html +0 -85
- package/examples/jspsych-instructions.html +0 -37
- package/examples/jspsych-maxdiff.html +0 -33
- package/examples/jspsych-preload.html +0 -140
- package/examples/jspsych-reconstruction.html +0 -43
- package/examples/jspsych-resize.html +0 -34
- package/examples/jspsych-same-different-html.html +0 -28
- package/examples/jspsych-same-different-image.html +0 -39
- package/examples/jspsych-serial-reaction-time-mouse.html +0 -98
- package/examples/jspsych-serial-reaction-time.html +0 -54
- package/examples/jspsych-survey-html-form.html +0 -33
- package/examples/jspsych-survey-likert.html +0 -42
- package/examples/jspsych-survey-multi-choice.html +0 -40
- package/examples/jspsych-survey-multi-select.html +0 -42
- package/examples/jspsych-survey-text.html +0 -34
- package/examples/jspsych-video-button-response.html +0 -65
- package/examples/jspsych-video-keyboard-response.html +0 -61
- package/examples/jspsych-video-slider-response.html +0 -63
- package/examples/jspsych-virtual-chinrest.html +0 -69
- package/examples/jspsych-visual-search-circle.html +0 -64
- package/examples/jspsych-vsl-animate-occlusion.html +0 -35
- package/examples/jspsych-vsl-grid-scene.html +0 -47
- package/examples/lexical-decision.html +0 -134
- package/examples/manual-preloading.html +0 -59
- package/examples/pause-unpause.html +0 -33
- package/examples/progress-bar.html +0 -68
- package/examples/save-trial-parameters.html +0 -98
- package/examples/sound/hammer.mp3 +0 -0
- package/examples/sound/sound.mp3 +0 -0
- package/examples/sound/speech_blue.mp3 +0 -0
- package/examples/sound/speech_green.mp3 +0 -0
- package/examples/sound/speech_joke.mp3 +0 -0
- package/examples/sound/speech_red.mp3 +0 -0
- package/examples/sound/tone.mp3 +0 -0
- package/examples/timeline-variables-sampling.html +0 -50
- package/examples/timeline-variables.html +0 -64
- package/examples/video/sample_video.mp4 +0 -0
- package/examples/webgazer.html +0 -162
- package/examples/webgazer_image.html +0 -60
- package/extensions/jspsych-ext-webgazer.js +0 -185
- package/jspsych.js +0 -3015
- package/license.txt +0 -21
- package/mkdocs.yml +0 -118
- package/plugins/jspsych-animation.js +0 -189
- package/plugins/jspsych-audio-button-response.js +0 -269
- package/plugins/jspsych-audio-keyboard-response.js +0 -212
- package/plugins/jspsych-audio-slider-response.js +0 -278
- package/plugins/jspsych-call-function.js +0 -58
- package/plugins/jspsych-canvas-button-response.js +0 -199
- package/plugins/jspsych-canvas-keyboard-response.js +0 -155
- package/plugins/jspsych-canvas-slider-response.js +0 -207
- package/plugins/jspsych-categorize-animation.js +0 -266
- package/plugins/jspsych-categorize-html.js +0 -220
- package/plugins/jspsych-categorize-image.js +0 -222
- package/plugins/jspsych-cloze.js +0 -112
- package/plugins/jspsych-external-html.js +0 -112
- package/plugins/jspsych-free-sort.js +0 -478
- package/plugins/jspsych-fullscreen.js +0 -106
- package/plugins/jspsych-html-button-response.js +0 -188
- package/plugins/jspsych-html-keyboard-response.js +0 -149
- package/plugins/jspsych-html-slider-response.js +0 -202
- package/plugins/jspsych-iat-html.js +0 -284
- package/plugins/jspsych-iat-image.js +0 -286
- package/plugins/jspsych-image-button-response.js +0 -327
- package/plugins/jspsych-image-keyboard-response.js +0 -263
- package/plugins/jspsych-image-slider-response.js +0 -369
- package/plugins/jspsych-instructions.js +0 -237
- package/plugins/jspsych-maxdiff.js +0 -173
- package/plugins/jspsych-preload.js +0 -345
- package/plugins/jspsych-rdk.js +0 -1373
- package/plugins/jspsych-reconstruction.js +0 -134
- package/plugins/jspsych-resize.js +0 -166
- package/plugins/jspsych-same-different-html.js +0 -168
- package/plugins/jspsych-same-different-image.js +0 -169
- package/plugins/jspsych-serial-reaction-time-mouse.js +0 -212
- package/plugins/jspsych-serial-reaction-time.js +0 -247
- package/plugins/jspsych-survey-html-form.js +0 -171
- package/plugins/jspsych-survey-likert.js +0 -195
- package/plugins/jspsych-survey-multi-choice.js +0 -208
- package/plugins/jspsych-survey-multi-select.js +0 -232
- package/plugins/jspsych-survey-text.js +0 -185
- package/plugins/jspsych-video-button-response.js +0 -335
- package/plugins/jspsych-video-keyboard-response.js +0 -279
- package/plugins/jspsych-video-slider-response.js +0 -351
- package/plugins/jspsych-virtual-chinrest.js +0 -471
- package/plugins/jspsych-visual-search-circle.js +0 -259
- package/plugins/jspsych-vsl-animate-occlusion.js +0 -196
- package/plugins/jspsych-vsl-grid-scene.js +0 -103
- package/plugins/jspsych-webgazer-calibrate.js +0 -166
- package/plugins/jspsych-webgazer-init-camera.js +0 -95
- package/plugins/jspsych-webgazer-validate.js +0 -304
- package/plugins/template/jspsych-plugin-template.js +0 -35
- package/tests/README.md +0 -7
- package/tests/jsPsych/case-sensitive-responses.test.js +0 -53
- package/tests/jsPsych/css-classes-parameter.test.js +0 -107
- package/tests/jsPsych/default-iti.test.js +0 -51
- package/tests/jsPsych/default-parameters.test.js +0 -58
- package/tests/jsPsych/endexperiment.test.js +0 -49
- package/tests/jsPsych/events.test.js +0 -606
- package/tests/jsPsych/functions-as-parameters.test.js +0 -210
- package/tests/jsPsych/init.test.js +0 -48
- package/tests/jsPsych/loads.test.js +0 -7
- package/tests/jsPsych/min-rt.test.js +0 -58
- package/tests/jsPsych/progressbar.test.js +0 -202
- package/tests/jsPsych/timeline-variables.test.js +0 -531
- package/tests/jsPsych/timelines.test.js +0 -569
- package/tests/jsPsych.data/data-csv-conversion.test.js +0 -85
- package/tests/jsPsych.data/data-json-conversion.test.js +0 -120
- package/tests/jsPsych.data/datacollection.test.js +0 -117
- package/tests/jsPsych.data/datacolumn.test.js +0 -50
- package/tests/jsPsych.data/datamodule.test.js +0 -152
- package/tests/jsPsych.data/dataparameter.test.js +0 -251
- package/tests/jsPsych.data/interactions.test.js +0 -109
- package/tests/jsPsych.data/trialparameters.test.js +0 -175
- package/tests/jsPsych.extensions/extensions.test.js +0 -207
- package/tests/jsPsych.extensions/test-extension.js +0 -42
- package/tests/jsPsych.pluginAPI/pluginapi.test.js +0 -341
- package/tests/jsPsych.pluginAPI/preloads.test.js +0 -43
- package/tests/jsPsych.randomization/randomziation.test.js +0 -27
- package/tests/jsPsych.utils/utils.test.js +0 -58
- package/tests/plugins/plugin-animation.test.js +0 -34
- package/tests/plugins/plugin-audio-button-response.test.js +0 -15
- package/tests/plugins/plugin-audio-keyboard-response.test.js +0 -15
- package/tests/plugins/plugin-audio-slider-response.test.js +0 -15
- package/tests/plugins/plugin-call-function.test.js +0 -49
- package/tests/plugins/plugin-categorize-animation.test.js +0 -263
- package/tests/plugins/plugin-categorize-html.test.js +0 -17
- package/tests/plugins/plugin-categorize-image.test.js +0 -17
- package/tests/plugins/plugin-cloze.test.js +0 -157
- package/tests/plugins/plugin-free-sort.test.js +0 -106
- package/tests/plugins/plugin-fullscreen.test.js +0 -41
- package/tests/plugins/plugin-html-button-response.test.js +0 -161
- package/tests/plugins/plugin-html-keyboard-response.test.js +0 -139
- package/tests/plugins/plugin-html-slider-response.test.js +0 -155
- package/tests/plugins/plugin-iat-html.test.js +0 -299
- package/tests/plugins/plugin-iat-image.test.js +0 -298
- package/tests/plugins/plugin-image-button-response.test.js +0 -174
- package/tests/plugins/plugin-image-keyboard-response.test.js +0 -147
- package/tests/plugins/plugin-image-slider-response.test.js +0 -174
- package/tests/plugins/plugin-instructions.test.js +0 -85
- package/tests/plugins/plugin-maxdiff.test.js +0 -39
- package/tests/plugins/plugin-preload.test.js +0 -916
- package/tests/plugins/plugin-rdk.test.js +0 -61
- package/tests/plugins/plugin-reconstruction.test.js +0 -16
- package/tests/plugins/plugin-resize.test.js +0 -16
- package/tests/plugins/plugin-same-different-html.test.js +0 -17
- package/tests/plugins/plugin-same-different-image.test.js +0 -17
- package/tests/plugins/plugin-serial-reaction-time-mouse.test.js +0 -42
- package/tests/plugins/plugin-serial-reaction-time.test.js +0 -109
- package/tests/plugins/plugin-survey-html-form.test.js +0 -44
- package/tests/plugins/plugin-survey-likert.test.js +0 -48
- package/tests/plugins/plugin-survey-multi-choice.test.js +0 -47
- package/tests/plugins/plugin-survey-multi-select.test.js +0 -71
- package/tests/plugins/plugin-survey-text.test.js +0 -115
- package/tests/plugins/plugin-video-button-response.test.js +0 -32
- package/tests/plugins/plugin-video-keyboard-response.test.js +0 -32
- package/tests/plugins/plugin-video-slider-response.test.js +0 -31
- package/tests/plugins/plugin-visual-search-circle.test.js +0 -16
- package/tests/plugins/plugin-vsl-animate-occlusion.test.js +0 -16
- package/tests/plugins/plugin-vsl-grid-scene.test.js +0 -16
- package/tests/testing-utils.js +0 -13
|
@@ -1,327 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* jspsych-image-button-response
|
|
3
|
-
* Josh de Leeuw
|
|
4
|
-
*
|
|
5
|
-
* plugin for displaying a stimulus and getting a button response
|
|
6
|
-
*
|
|
7
|
-
* documentation: docs.jspsych.org
|
|
8
|
-
*
|
|
9
|
-
**/
|
|
10
|
-
|
|
11
|
-
jsPsych.plugins["image-button-response"] = (function() {
|
|
12
|
-
|
|
13
|
-
var plugin = {};
|
|
14
|
-
|
|
15
|
-
jsPsych.pluginAPI.registerPreload('image-button-response', 'stimulus', 'image');
|
|
16
|
-
|
|
17
|
-
plugin.info = {
|
|
18
|
-
name: 'image-button-response',
|
|
19
|
-
description: '',
|
|
20
|
-
parameters: {
|
|
21
|
-
stimulus: {
|
|
22
|
-
type: jsPsych.plugins.parameterType.IMAGE,
|
|
23
|
-
pretty_name: 'Stimulus',
|
|
24
|
-
default: undefined,
|
|
25
|
-
description: 'The image to be displayed'
|
|
26
|
-
},
|
|
27
|
-
stimulus_height: {
|
|
28
|
-
type: jsPsych.plugins.parameterType.INT,
|
|
29
|
-
pretty_name: 'Image height',
|
|
30
|
-
default: null,
|
|
31
|
-
description: 'Set the image height in pixels'
|
|
32
|
-
},
|
|
33
|
-
stimulus_width: {
|
|
34
|
-
type: jsPsych.plugins.parameterType.INT,
|
|
35
|
-
pretty_name: 'Image width',
|
|
36
|
-
default: null,
|
|
37
|
-
description: 'Set the image width in pixels'
|
|
38
|
-
},
|
|
39
|
-
maintain_aspect_ratio: {
|
|
40
|
-
type: jsPsych.plugins.parameterType.BOOL,
|
|
41
|
-
pretty_name: 'Maintain aspect ratio',
|
|
42
|
-
default: true,
|
|
43
|
-
description: 'Maintain the aspect ratio after setting width or height'
|
|
44
|
-
},
|
|
45
|
-
choices: {
|
|
46
|
-
type: jsPsych.plugins.parameterType.STRING,
|
|
47
|
-
pretty_name: 'Choices',
|
|
48
|
-
default: undefined,
|
|
49
|
-
array: true,
|
|
50
|
-
description: 'The labels for the buttons.'
|
|
51
|
-
},
|
|
52
|
-
button_html: {
|
|
53
|
-
type: jsPsych.plugins.parameterType.STRING,
|
|
54
|
-
pretty_name: 'Button HTML',
|
|
55
|
-
default: '<button class="jspsych-btn">%choice%</button>',
|
|
56
|
-
array: true,
|
|
57
|
-
description: 'The html of the button. Can create own style.'
|
|
58
|
-
},
|
|
59
|
-
prompt: {
|
|
60
|
-
type: jsPsych.plugins.parameterType.STRING,
|
|
61
|
-
pretty_name: 'Prompt',
|
|
62
|
-
default: null,
|
|
63
|
-
description: 'Any content here will be displayed under the button.'
|
|
64
|
-
},
|
|
65
|
-
stimulus_duration: {
|
|
66
|
-
type: jsPsych.plugins.parameterType.INT,
|
|
67
|
-
pretty_name: 'Stimulus duration',
|
|
68
|
-
default: null,
|
|
69
|
-
description: 'How long to hide the stimulus.'
|
|
70
|
-
},
|
|
71
|
-
trial_duration: {
|
|
72
|
-
type: jsPsych.plugins.parameterType.INT,
|
|
73
|
-
pretty_name: 'Trial duration',
|
|
74
|
-
default: null,
|
|
75
|
-
description: 'How long to show the trial.'
|
|
76
|
-
},
|
|
77
|
-
margin_vertical: {
|
|
78
|
-
type: jsPsych.plugins.parameterType.STRING,
|
|
79
|
-
pretty_name: 'Margin vertical',
|
|
80
|
-
default: '0px',
|
|
81
|
-
description: 'The vertical margin of the button.'
|
|
82
|
-
},
|
|
83
|
-
margin_horizontal: {
|
|
84
|
-
type: jsPsych.plugins.parameterType.STRING,
|
|
85
|
-
pretty_name: 'Margin horizontal',
|
|
86
|
-
default: '8px',
|
|
87
|
-
description: 'The horizontal margin of the button.'
|
|
88
|
-
},
|
|
89
|
-
response_ends_trial: {
|
|
90
|
-
type: jsPsych.plugins.parameterType.BOOL,
|
|
91
|
-
pretty_name: 'Response ends trial',
|
|
92
|
-
default: true,
|
|
93
|
-
description: 'If true, then trial will end when user responds.'
|
|
94
|
-
},
|
|
95
|
-
render_on_canvas: {
|
|
96
|
-
type: jsPsych.plugins.parameterType.BOOL,
|
|
97
|
-
pretty_name: 'Render on canvas',
|
|
98
|
-
default: true,
|
|
99
|
-
description: 'If true, the image will be drawn onto a canvas element (prevents blank screen between consecutive images in some browsers).'+
|
|
100
|
-
'If false, the image will be shown via an img element.'
|
|
101
|
-
}
|
|
102
|
-
}
|
|
103
|
-
}
|
|
104
|
-
|
|
105
|
-
plugin.trial = function(display_element, trial) {
|
|
106
|
-
|
|
107
|
-
var height, width;
|
|
108
|
-
var html;
|
|
109
|
-
if (trial.render_on_canvas) {
|
|
110
|
-
var image_drawn = false;
|
|
111
|
-
// first clear the display element (because the render_on_canvas method appends to display_element instead of overwriting it with .innerHTML)
|
|
112
|
-
if (display_element.hasChildNodes()) {
|
|
113
|
-
// can't loop through child list because the list will be modified by .removeChild()
|
|
114
|
-
while (display_element.firstChild) {
|
|
115
|
-
display_element.removeChild(display_element.firstChild);
|
|
116
|
-
}
|
|
117
|
-
}
|
|
118
|
-
// create canvas element and image
|
|
119
|
-
var canvas = document.createElement("canvas");
|
|
120
|
-
canvas.id = "jspsych-image-button-response-stimulus";
|
|
121
|
-
canvas.style.margin = 0;
|
|
122
|
-
canvas.style.padding = 0;
|
|
123
|
-
var ctx = canvas.getContext("2d");
|
|
124
|
-
var img = new Image();
|
|
125
|
-
img.onload = function() {
|
|
126
|
-
// if image wasn't preloaded, then it will need to be drawn whenever it finishes loading
|
|
127
|
-
if (!image_drawn) {
|
|
128
|
-
getHeightWidth(); // only possible to get width/height after image loads
|
|
129
|
-
ctx.drawImage(img,0,0,width,height);
|
|
130
|
-
}
|
|
131
|
-
};
|
|
132
|
-
img.src = trial.stimulus;
|
|
133
|
-
// get/set image height and width - this can only be done after image loads because uses image's naturalWidth/naturalHeight properties
|
|
134
|
-
function getHeightWidth() {
|
|
135
|
-
if (trial.stimulus_height !== null) {
|
|
136
|
-
height = trial.stimulus_height;
|
|
137
|
-
if (trial.stimulus_width == null && trial.maintain_aspect_ratio) {
|
|
138
|
-
width = img.naturalWidth * (trial.stimulus_height/img.naturalHeight);
|
|
139
|
-
}
|
|
140
|
-
} else {
|
|
141
|
-
height = img.naturalHeight;
|
|
142
|
-
}
|
|
143
|
-
if (trial.stimulus_width !== null) {
|
|
144
|
-
width = trial.stimulus_width;
|
|
145
|
-
if (trial.stimulus_height == null && trial.maintain_aspect_ratio) {
|
|
146
|
-
height = img.naturalHeight * (trial.stimulus_width/img.naturalWidth);
|
|
147
|
-
}
|
|
148
|
-
} else if (!(trial.stimulus_height !== null & trial.maintain_aspect_ratio)) {
|
|
149
|
-
// if stimulus width is null, only use the image's natural width if the width value wasn't set
|
|
150
|
-
// in the if statement above, based on a specified height and maintain_aspect_ratio = true
|
|
151
|
-
width = img.naturalWidth;
|
|
152
|
-
}
|
|
153
|
-
canvas.height = height;
|
|
154
|
-
canvas.width = width;
|
|
155
|
-
}
|
|
156
|
-
getHeightWidth(); // call now, in case image loads immediately (is cached)
|
|
157
|
-
// create buttons
|
|
158
|
-
var buttons = [];
|
|
159
|
-
if (Array.isArray(trial.button_html)) {
|
|
160
|
-
if (trial.button_html.length == trial.choices.length) {
|
|
161
|
-
buttons = trial.button_html;
|
|
162
|
-
} else {
|
|
163
|
-
console.error('Error in image-button-response plugin. The length of the button_html array does not equal the length of the choices array');
|
|
164
|
-
}
|
|
165
|
-
} else {
|
|
166
|
-
for (var i = 0; i < trial.choices.length; i++) {
|
|
167
|
-
buttons.push(trial.button_html);
|
|
168
|
-
}
|
|
169
|
-
}
|
|
170
|
-
var btngroup_div = document.createElement('div');
|
|
171
|
-
btngroup_div.id = "jspsych-image-button-response-btngroup";
|
|
172
|
-
html = '';
|
|
173
|
-
for (var i = 0; i < trial.choices.length; i++) {
|
|
174
|
-
var str = buttons[i].replace(/%choice%/g, trial.choices[i]);
|
|
175
|
-
html += '<div class="jspsych-image-button-response-button" style="display: inline-block; margin:'+trial.margin_vertical+' '+trial.margin_horizontal+'" id="jspsych-image-button-response-button-' + i +'" data-choice="'+i+'">'+str+'</div>';
|
|
176
|
-
}
|
|
177
|
-
btngroup_div.innerHTML = html;
|
|
178
|
-
// add canvas to screen and draw image
|
|
179
|
-
display_element.insertBefore(canvas, null);
|
|
180
|
-
if (img.complete && Number.isFinite(width) && Number.isFinite(height)) {
|
|
181
|
-
// if image has loaded and width/height have been set, then draw it now
|
|
182
|
-
// (don't rely on img onload function to draw image when image is in the cache, because that causes a delay in the image presentation)
|
|
183
|
-
ctx.drawImage(img,0,0,width,height);
|
|
184
|
-
image_drawn = true;
|
|
185
|
-
}
|
|
186
|
-
// add buttons to screen
|
|
187
|
-
display_element.insertBefore(btngroup_div, canvas.nextElementSibling);
|
|
188
|
-
// add prompt if there is one
|
|
189
|
-
if (trial.prompt !== null) {
|
|
190
|
-
display_element.insertAdjacentHTML('beforeend', trial.prompt);
|
|
191
|
-
}
|
|
192
|
-
|
|
193
|
-
} else {
|
|
194
|
-
|
|
195
|
-
// display stimulus as an image element
|
|
196
|
-
html = '<img src="'+trial.stimulus+'" id="jspsych-image-button-response-stimulus">';
|
|
197
|
-
//display buttons
|
|
198
|
-
var buttons = [];
|
|
199
|
-
if (Array.isArray(trial.button_html)) {
|
|
200
|
-
if (trial.button_html.length == trial.choices.length) {
|
|
201
|
-
buttons = trial.button_html;
|
|
202
|
-
} else {
|
|
203
|
-
console.error('Error in image-button-response plugin. The length of the button_html array does not equal the length of the choices array');
|
|
204
|
-
}
|
|
205
|
-
} else {
|
|
206
|
-
for (var i = 0; i < trial.choices.length; i++) {
|
|
207
|
-
buttons.push(trial.button_html);
|
|
208
|
-
}
|
|
209
|
-
}
|
|
210
|
-
html += '<div id="jspsych-image-button-response-btngroup">';
|
|
211
|
-
|
|
212
|
-
for (var i = 0; i < trial.choices.length; i++) {
|
|
213
|
-
var str = buttons[i].replace(/%choice%/g, trial.choices[i]);
|
|
214
|
-
html += '<div class="jspsych-image-button-response-button" style="display: inline-block; margin:'+trial.margin_vertical+' '+trial.margin_horizontal+'" id="jspsych-image-button-response-button-' + i +'" data-choice="'+i+'">'+str+'</div>';
|
|
215
|
-
}
|
|
216
|
-
html += '</div>';
|
|
217
|
-
// add prompt
|
|
218
|
-
if (trial.prompt !== null){
|
|
219
|
-
html += trial.prompt;
|
|
220
|
-
}
|
|
221
|
-
// update the page content
|
|
222
|
-
display_element.innerHTML = html;
|
|
223
|
-
|
|
224
|
-
// set image dimensions after image has loaded (so that we have access to naturalHeight/naturalWidth)
|
|
225
|
-
var img = display_element.querySelector('#jspsych-image-button-response-stimulus');
|
|
226
|
-
if (trial.stimulus_height !== null) {
|
|
227
|
-
height = trial.stimulus_height;
|
|
228
|
-
if (trial.stimulus_width == null && trial.maintain_aspect_ratio) {
|
|
229
|
-
width = img.naturalWidth * (trial.stimulus_height/img.naturalHeight);
|
|
230
|
-
}
|
|
231
|
-
} else {
|
|
232
|
-
height = img.naturalHeight;
|
|
233
|
-
}
|
|
234
|
-
if (trial.stimulus_width !== null) {
|
|
235
|
-
width = trial.stimulus_width;
|
|
236
|
-
if (trial.stimulus_height == null && trial.maintain_aspect_ratio) {
|
|
237
|
-
height = img.naturalHeight * (trial.stimulus_width/img.naturalWidth);
|
|
238
|
-
}
|
|
239
|
-
} else if (!(trial.stimulus_height !== null & trial.maintain_aspect_ratio)) {
|
|
240
|
-
// if stimulus width is null, only use the image's natural width if the width value wasn't set
|
|
241
|
-
// in the if statement above, based on a specified height and maintain_aspect_ratio = true
|
|
242
|
-
width = img.naturalWidth;
|
|
243
|
-
}
|
|
244
|
-
img.style.height = height.toString() + "px";
|
|
245
|
-
img.style.width = width.toString() + "px";
|
|
246
|
-
}
|
|
247
|
-
|
|
248
|
-
// start timing
|
|
249
|
-
var start_time = performance.now();
|
|
250
|
-
|
|
251
|
-
for (var i = 0; i < trial.choices.length; i++) {
|
|
252
|
-
display_element.querySelector('#jspsych-image-button-response-button-' + i).addEventListener('click', function(e){
|
|
253
|
-
var choice = e.currentTarget.getAttribute('data-choice'); // don't use dataset for jsdom compatibility
|
|
254
|
-
after_response(choice);
|
|
255
|
-
});
|
|
256
|
-
}
|
|
257
|
-
|
|
258
|
-
// store response
|
|
259
|
-
var response = {
|
|
260
|
-
rt: null,
|
|
261
|
-
button: null
|
|
262
|
-
};
|
|
263
|
-
|
|
264
|
-
// function to handle responses by the subject
|
|
265
|
-
function after_response(choice) {
|
|
266
|
-
|
|
267
|
-
// measure rt
|
|
268
|
-
var end_time = performance.now();
|
|
269
|
-
var rt = end_time - start_time;
|
|
270
|
-
response.button = parseInt(choice);
|
|
271
|
-
response.rt = rt;
|
|
272
|
-
|
|
273
|
-
// after a valid response, the stimulus will have the CSS class 'responded'
|
|
274
|
-
// which can be used to provide visual feedback that a response was recorded
|
|
275
|
-
display_element.querySelector('#jspsych-image-button-response-stimulus').className += ' responded';
|
|
276
|
-
|
|
277
|
-
// disable all the buttons after a response
|
|
278
|
-
var btns = document.querySelectorAll('.jspsych-image-button-response-button button');
|
|
279
|
-
for(var i=0; i<btns.length; i++){
|
|
280
|
-
//btns[i].removeEventListener('click');
|
|
281
|
-
btns[i].setAttribute('disabled', 'disabled');
|
|
282
|
-
}
|
|
283
|
-
|
|
284
|
-
if (trial.response_ends_trial) {
|
|
285
|
-
end_trial();
|
|
286
|
-
}
|
|
287
|
-
};
|
|
288
|
-
|
|
289
|
-
// function to end trial when it is time
|
|
290
|
-
function end_trial() {
|
|
291
|
-
|
|
292
|
-
// kill any remaining setTimeout handlers
|
|
293
|
-
jsPsych.pluginAPI.clearAllTimeouts();
|
|
294
|
-
|
|
295
|
-
// gather the data to store for the trial
|
|
296
|
-
var trial_data = {
|
|
297
|
-
rt: response.rt,
|
|
298
|
-
stimulus: trial.stimulus,
|
|
299
|
-
response: response.button
|
|
300
|
-
};
|
|
301
|
-
|
|
302
|
-
// clear the display
|
|
303
|
-
display_element.innerHTML = '';
|
|
304
|
-
|
|
305
|
-
// move on to the next trial
|
|
306
|
-
jsPsych.finishTrial(trial_data);
|
|
307
|
-
};
|
|
308
|
-
|
|
309
|
-
// hide image if timing is set
|
|
310
|
-
if (trial.stimulus_duration !== null) {
|
|
311
|
-
jsPsych.pluginAPI.setTimeout(function() {
|
|
312
|
-
display_element.querySelector('#jspsych-image-button-response-stimulus').style.visibility = 'hidden';
|
|
313
|
-
}, trial.stimulus_duration);
|
|
314
|
-
}
|
|
315
|
-
|
|
316
|
-
// end trial if time limit is set
|
|
317
|
-
if (trial.trial_duration !== null) {
|
|
318
|
-
jsPsych.pluginAPI.setTimeout(function() {
|
|
319
|
-
end_trial();
|
|
320
|
-
}, trial.trial_duration);
|
|
321
|
-
} else if (trial.response_ends_trial === false) {
|
|
322
|
-
console.warn("The experiment may be deadlocked. Try setting a trial duration or set response_ends_trial to true.");
|
|
323
|
-
}
|
|
324
|
-
};
|
|
325
|
-
|
|
326
|
-
return plugin;
|
|
327
|
-
})();
|
|
@@ -1,263 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* jspsych-image-keyboard-response
|
|
3
|
-
* Josh de Leeuw
|
|
4
|
-
*
|
|
5
|
-
* plugin for displaying a stimulus and getting a keyboard response
|
|
6
|
-
*
|
|
7
|
-
* documentation: docs.jspsych.org
|
|
8
|
-
*
|
|
9
|
-
**/
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
jsPsych.plugins["image-keyboard-response"] = (function() {
|
|
13
|
-
|
|
14
|
-
var plugin = {};
|
|
15
|
-
|
|
16
|
-
jsPsych.pluginAPI.registerPreload('image-keyboard-response', 'stimulus', 'image');
|
|
17
|
-
|
|
18
|
-
plugin.info = {
|
|
19
|
-
name: 'image-keyboard-response',
|
|
20
|
-
description: '',
|
|
21
|
-
parameters: {
|
|
22
|
-
stimulus: {
|
|
23
|
-
type: jsPsych.plugins.parameterType.IMAGE,
|
|
24
|
-
pretty_name: 'Stimulus',
|
|
25
|
-
default: undefined,
|
|
26
|
-
description: 'The image to be displayed'
|
|
27
|
-
},
|
|
28
|
-
stimulus_height: {
|
|
29
|
-
type: jsPsych.plugins.parameterType.INT,
|
|
30
|
-
pretty_name: 'Image height',
|
|
31
|
-
default: null,
|
|
32
|
-
description: 'Set the image height in pixels'
|
|
33
|
-
},
|
|
34
|
-
stimulus_width: {
|
|
35
|
-
type: jsPsych.plugins.parameterType.INT,
|
|
36
|
-
pretty_name: 'Image width',
|
|
37
|
-
default: null,
|
|
38
|
-
description: 'Set the image width in pixels'
|
|
39
|
-
},
|
|
40
|
-
maintain_aspect_ratio: {
|
|
41
|
-
type: jsPsych.plugins.parameterType.BOOL,
|
|
42
|
-
pretty_name: 'Maintain aspect ratio',
|
|
43
|
-
default: true,
|
|
44
|
-
description: 'Maintain the aspect ratio after setting width or height'
|
|
45
|
-
},
|
|
46
|
-
choices: {
|
|
47
|
-
type: jsPsych.plugins.parameterType.KEY,
|
|
48
|
-
array: true,
|
|
49
|
-
pretty_name: 'Choices',
|
|
50
|
-
default: jsPsych.ALL_KEYS,
|
|
51
|
-
description: 'The keys the subject is allowed to press to respond to the stimulus.'
|
|
52
|
-
},
|
|
53
|
-
prompt: {
|
|
54
|
-
type: jsPsych.plugins.parameterType.STRING,
|
|
55
|
-
pretty_name: 'Prompt',
|
|
56
|
-
default: null,
|
|
57
|
-
description: 'Any content here will be displayed below the stimulus.'
|
|
58
|
-
},
|
|
59
|
-
stimulus_duration: {
|
|
60
|
-
type: jsPsych.plugins.parameterType.INT,
|
|
61
|
-
pretty_name: 'Stimulus duration',
|
|
62
|
-
default: null,
|
|
63
|
-
description: 'How long to hide the stimulus.'
|
|
64
|
-
},
|
|
65
|
-
trial_duration: {
|
|
66
|
-
type: jsPsych.plugins.parameterType.INT,
|
|
67
|
-
pretty_name: 'Trial duration',
|
|
68
|
-
default: null,
|
|
69
|
-
description: 'How long to show trial before it ends.'
|
|
70
|
-
},
|
|
71
|
-
response_ends_trial: {
|
|
72
|
-
type: jsPsych.plugins.parameterType.BOOL,
|
|
73
|
-
pretty_name: 'Response ends trial',
|
|
74
|
-
default: true,
|
|
75
|
-
description: 'If true, trial will end when subject makes a response.'
|
|
76
|
-
},
|
|
77
|
-
render_on_canvas: {
|
|
78
|
-
type: jsPsych.plugins.parameterType.BOOL,
|
|
79
|
-
pretty_name: 'Render on canvas',
|
|
80
|
-
default: true,
|
|
81
|
-
description: 'If true, the image will be drawn onto a canvas element (prevents blank screen between consecutive images in some browsers).'+
|
|
82
|
-
'If false, the image will be shown via an img element.'
|
|
83
|
-
}
|
|
84
|
-
}
|
|
85
|
-
}
|
|
86
|
-
|
|
87
|
-
plugin.trial = function(display_element, trial) {
|
|
88
|
-
|
|
89
|
-
var height, width;
|
|
90
|
-
if (trial.render_on_canvas) {
|
|
91
|
-
var image_drawn = false;
|
|
92
|
-
// first clear the display element (because the render_on_canvas method appends to display_element instead of overwriting it with .innerHTML)
|
|
93
|
-
if (display_element.hasChildNodes()) {
|
|
94
|
-
// can't loop through child list because the list will be modified by .removeChild()
|
|
95
|
-
while (display_element.firstChild) {
|
|
96
|
-
display_element.removeChild(display_element.firstChild);
|
|
97
|
-
}
|
|
98
|
-
}
|
|
99
|
-
// create canvas element and image
|
|
100
|
-
var canvas = document.createElement("canvas");
|
|
101
|
-
canvas.id = "jspsych-image-keyboard-response-stimulus";
|
|
102
|
-
canvas.style.margin = 0;
|
|
103
|
-
canvas.style.padding = 0;
|
|
104
|
-
var ctx = canvas.getContext("2d");
|
|
105
|
-
var img = new Image();
|
|
106
|
-
img.onload = function() {
|
|
107
|
-
// if image wasn't preloaded, then it will need to be drawn whenever it finishes loading
|
|
108
|
-
if (!image_drawn) {
|
|
109
|
-
getHeightWidth(); // only possible to get width/height after image loads
|
|
110
|
-
ctx.drawImage(img,0,0,width,height);
|
|
111
|
-
}
|
|
112
|
-
};
|
|
113
|
-
img.src = trial.stimulus;
|
|
114
|
-
// get/set image height and width - this can only be done after image loads because uses image's naturalWidth/naturalHeight properties
|
|
115
|
-
function getHeightWidth() {
|
|
116
|
-
if (trial.stimulus_height !== null) {
|
|
117
|
-
height = trial.stimulus_height;
|
|
118
|
-
if (trial.stimulus_width == null && trial.maintain_aspect_ratio) {
|
|
119
|
-
width = img.naturalWidth * (trial.stimulus_height/img.naturalHeight);
|
|
120
|
-
}
|
|
121
|
-
} else {
|
|
122
|
-
height = img.naturalHeight;
|
|
123
|
-
}
|
|
124
|
-
if (trial.stimulus_width !== null) {
|
|
125
|
-
width = trial.stimulus_width;
|
|
126
|
-
if (trial.stimulus_height == null && trial.maintain_aspect_ratio) {
|
|
127
|
-
height = img.naturalHeight * (trial.stimulus_width/img.naturalWidth);
|
|
128
|
-
}
|
|
129
|
-
} else if (!(trial.stimulus_height !== null & trial.maintain_aspect_ratio)) {
|
|
130
|
-
// if stimulus width is null, only use the image's natural width if the width value wasn't set
|
|
131
|
-
// in the if statement above, based on a specified height and maintain_aspect_ratio = true
|
|
132
|
-
width = img.naturalWidth;
|
|
133
|
-
}
|
|
134
|
-
canvas.height = height;
|
|
135
|
-
canvas.width = width;
|
|
136
|
-
}
|
|
137
|
-
getHeightWidth(); // call now, in case image loads immediately (is cached)
|
|
138
|
-
// add canvas and draw image
|
|
139
|
-
display_element.insertBefore(canvas, null);
|
|
140
|
-
if (img.complete && Number.isFinite(width) && Number.isFinite(height)) {
|
|
141
|
-
// if image has loaded and width/height have been set, then draw it now
|
|
142
|
-
// (don't rely on img onload function to draw image when image is in the cache, because that causes a delay in the image presentation)
|
|
143
|
-
ctx.drawImage(img,0,0,width,height);
|
|
144
|
-
image_drawn = true;
|
|
145
|
-
}
|
|
146
|
-
// add prompt if there is one
|
|
147
|
-
if (trial.prompt !== null) {
|
|
148
|
-
display_element.insertAdjacentHTML('beforeend', trial.prompt);
|
|
149
|
-
}
|
|
150
|
-
|
|
151
|
-
} else {
|
|
152
|
-
|
|
153
|
-
// display stimulus as an image element
|
|
154
|
-
var html = '<img src="'+trial.stimulus+'" id="jspsych-image-keyboard-response-stimulus">';
|
|
155
|
-
// add prompt
|
|
156
|
-
if (trial.prompt !== null){
|
|
157
|
-
html += trial.prompt;
|
|
158
|
-
}
|
|
159
|
-
// update the page content
|
|
160
|
-
display_element.innerHTML = html;
|
|
161
|
-
|
|
162
|
-
// set image dimensions after image has loaded (so that we have access to naturalHeight/naturalWidth)
|
|
163
|
-
var img = display_element.querySelector('#jspsych-image-keyboard-response-stimulus');
|
|
164
|
-
if (trial.stimulus_height !== null) {
|
|
165
|
-
height = trial.stimulus_height;
|
|
166
|
-
if (trial.stimulus_width == null && trial.maintain_aspect_ratio) {
|
|
167
|
-
width = img.naturalWidth * (trial.stimulus_height/img.naturalHeight);
|
|
168
|
-
}
|
|
169
|
-
} else {
|
|
170
|
-
height = img.naturalHeight;
|
|
171
|
-
}
|
|
172
|
-
if (trial.stimulus_width !== null) {
|
|
173
|
-
width = trial.stimulus_width;
|
|
174
|
-
if (trial.stimulus_height == null && trial.maintain_aspect_ratio) {
|
|
175
|
-
height = img.naturalHeight * (trial.stimulus_width/img.naturalWidth);
|
|
176
|
-
}
|
|
177
|
-
} else if (!(trial.stimulus_height !== null & trial.maintain_aspect_ratio)) {
|
|
178
|
-
// if stimulus width is null, only use the image's natural width if the width value wasn't set
|
|
179
|
-
// in the if statement above, based on a specified height and maintain_aspect_ratio = true
|
|
180
|
-
width = img.naturalWidth;
|
|
181
|
-
}
|
|
182
|
-
img.style.height = height.toString() + "px";
|
|
183
|
-
img.style.width = width.toString() + "px";
|
|
184
|
-
}
|
|
185
|
-
|
|
186
|
-
// store response
|
|
187
|
-
var response = {
|
|
188
|
-
rt: null,
|
|
189
|
-
key: null
|
|
190
|
-
};
|
|
191
|
-
|
|
192
|
-
// function to end trial when it is time
|
|
193
|
-
var end_trial = function() {
|
|
194
|
-
|
|
195
|
-
// kill any remaining setTimeout handlers
|
|
196
|
-
jsPsych.pluginAPI.clearAllTimeouts();
|
|
197
|
-
|
|
198
|
-
// kill keyboard listeners
|
|
199
|
-
if (typeof keyboardListener !== 'undefined') {
|
|
200
|
-
jsPsych.pluginAPI.cancelKeyboardResponse(keyboardListener);
|
|
201
|
-
}
|
|
202
|
-
|
|
203
|
-
// gather the data to store for the trial
|
|
204
|
-
var trial_data = {
|
|
205
|
-
rt: response.rt,
|
|
206
|
-
stimulus: trial.stimulus,
|
|
207
|
-
response: response.key
|
|
208
|
-
};
|
|
209
|
-
|
|
210
|
-
// clear the display
|
|
211
|
-
display_element.innerHTML = '';
|
|
212
|
-
|
|
213
|
-
// move on to the next trial
|
|
214
|
-
jsPsych.finishTrial(trial_data);
|
|
215
|
-
};
|
|
216
|
-
|
|
217
|
-
// function to handle responses by the subject
|
|
218
|
-
var after_response = function(info) {
|
|
219
|
-
|
|
220
|
-
// after a valid response, the stimulus will have the CSS class 'responded'
|
|
221
|
-
// which can be used to provide visual feedback that a response was recorded
|
|
222
|
-
display_element.querySelector('#jspsych-image-keyboard-response-stimulus').className += ' responded';
|
|
223
|
-
|
|
224
|
-
// only record the first response
|
|
225
|
-
if (response.key == null) {
|
|
226
|
-
response = info;
|
|
227
|
-
}
|
|
228
|
-
|
|
229
|
-
if (trial.response_ends_trial) {
|
|
230
|
-
end_trial();
|
|
231
|
-
}
|
|
232
|
-
};
|
|
233
|
-
|
|
234
|
-
// start the response listener
|
|
235
|
-
if (trial.choices != jsPsych.NO_KEYS) {
|
|
236
|
-
var keyboardListener = jsPsych.pluginAPI.getKeyboardResponse({
|
|
237
|
-
callback_function: after_response,
|
|
238
|
-
valid_responses: trial.choices,
|
|
239
|
-
rt_method: 'performance',
|
|
240
|
-
persist: false,
|
|
241
|
-
allow_held_key: false
|
|
242
|
-
});
|
|
243
|
-
}
|
|
244
|
-
|
|
245
|
-
// hide stimulus if stimulus_duration is set
|
|
246
|
-
if (trial.stimulus_duration !== null) {
|
|
247
|
-
jsPsych.pluginAPI.setTimeout(function() {
|
|
248
|
-
display_element.querySelector('#jspsych-image-keyboard-response-stimulus').style.visibility = 'hidden';
|
|
249
|
-
}, trial.stimulus_duration);
|
|
250
|
-
}
|
|
251
|
-
|
|
252
|
-
// end trial if trial_duration is set
|
|
253
|
-
if (trial.trial_duration !== null) {
|
|
254
|
-
jsPsych.pluginAPI.setTimeout(function() {
|
|
255
|
-
end_trial();
|
|
256
|
-
}, trial.trial_duration);
|
|
257
|
-
} else if (trial.response_ends_trial === false) {
|
|
258
|
-
console.warn("The experiment may be deadlocked. Try setting a trial duration or set response_ends_trial to true.");
|
|
259
|
-
}
|
|
260
|
-
};
|
|
261
|
-
|
|
262
|
-
return plugin;
|
|
263
|
-
})();
|