jspsych 6.2.0 → 7.1.0
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 +43 -29
- 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 -661
- package/docs/core_library/jspsych-data.md +0 -589
- package/docs/core_library/jspsych-pluginAPI.md +0 -510
- package/docs/core_library/jspsych-randomization.md +0 -397
- package/docs/core_library/jspsych-turk.md +0 -102
- package/docs/img/blue.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/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 -140
- package/docs/overview/data.md +0 -281
- package/docs/overview/exclude-browser.md +0 -32
- package/docs/overview/experiment-options.md +0 -121
- package/docs/overview/fullscreen.md +0 -36
- package/docs/overview/media-preloading.md +0 -91
- package/docs/overview/mturk.md +0 -77
- package/docs/overview/progress-bar.md +0 -110
- package/docs/overview/record-browser-interactions.md +0 -23
- package/docs/overview/running-experiments.md +0 -95
- package/docs/overview/timeline.md +0 -387
- package/docs/overview/trial.md +0 -142
- package/docs/plugins/creating-a-plugin.md +0 -79
- 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 -52
- 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 -55
- 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 -46
- package/docs/plugins/jspsych-image-keyboard-response.md +0 -57
- package/docs/plugins/jspsych-image-slider-response.md +0 -52
- package/docs/plugins/jspsych-instructions.md +0 -58
- package/docs/plugins/jspsych-maxdiff.md +0 -42
- 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 -50
- 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 -52
- package/docs/plugins/jspsych-video-keyboard-response.md +0 -48
- package/docs/plugins/jspsych-video-slider-response.md +0 -58
- 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/overview.md +0 -111
- package/docs/tutorials/hello-world.md +0 -144
- package/docs/tutorials/rt-task.md +0 -1107
- package/examples/add-to-end-of-timeline.html +0 -32
- package/examples/conditional-and-loop-functions.html +0 -63
- package/examples/css/jquery-ui.css +0 -1225
- package/examples/data-add-properties.html +0 -40
- package/examples/data-as-function.html +0 -36
- package/examples/data-from-timeline.html +0 -45
- package/examples/data-from-url.html +0 -21
- package/examples/demo-flanker.html +0 -108
- package/examples/demo-simple-rt-task.html +0 -104
- package/examples/demos/demo_1.html +0 -29
- package/examples/demos/demo_2.html +0 -43
- package/examples/demos/demo_3.html +0 -58
- package/examples/display-element-to-embed-experiment.html +0 -73
- package/examples/end-active-node.html +0 -52
- package/examples/end-experiment.html +0 -43
- 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/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/jspsych-RDK.html +0 -58
- package/examples/jspsych-animation.html +0 -33
- package/examples/jspsych-audio-button-response.html +0 -52
- package/examples/jspsych-audio-keyboard-response.html +0 -62
- package/examples/jspsych-audio-slider-response.html +0 -55
- 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 -46
- package/examples/jspsych-categorize-html.html +0 -38
- package/examples/jspsych-categorize-image.html +0 -38
- package/examples/jspsych-cloze.html +0 -42
- package/examples/jspsych-free-sort.html +0 -97
- package/examples/jspsych-fullscreen.html +0 -44
- package/examples/jspsych-html-button-response.html +0 -46
- package/examples/jspsych-html-keyboard-response.html +0 -42
- package/examples/jspsych-html-slider-response.html +0 -53
- package/examples/jspsych-iat.html +0 -510
- package/examples/jspsych-image-button-response.html +0 -84
- package/examples/jspsych-image-keyboard-response.html +0 -78
- package/examples/jspsych-image-slider-response.html +0 -76
- package/examples/jspsych-instructions.html +0 -37
- package/examples/jspsych-maxdiff.html +0 -33
- 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 -33
- 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 -57
- package/examples/jspsych-video-keyboard-response.html +0 -53
- package/examples/jspsych-video-slider-response.html +0 -55
- package/examples/jspsych-visual-search-circle.html +0 -58
- package/examples/jspsych-vsl-animate-occlusion.html +0 -29
- package/examples/jspsych-vsl-grid-scene.html +0 -41
- package/examples/lexical-decision.html +0 -132
- package/examples/manual-preloading.html +0 -53
- package/examples/pause-unpause.html +0 -33
- package/examples/progress-bar.html +0 -62
- 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 -55
- package/examples/video/sample_video.mp4 +0 -0
- package/jspsych.js +0 -2796
- package/license.txt +0 -21
- package/mkdocs.yml +0 -104
- package/plugins/jspsych-animation.js +0 -189
- package/plugins/jspsych-audio-button-response.js +0 -247
- package/plugins/jspsych-audio-keyboard-response.js +0 -204
- package/plugins/jspsych-audio-slider-response.js +0 -262
- 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 -444
- package/plugins/jspsych-fullscreen.js +0 -104
- 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 -311
- package/plugins/jspsych-image-keyboard-response.js +0 -247
- package/plugins/jspsych-image-slider-response.js +0 -353
- package/plugins/jspsych-instructions.js +0 -237
- package/plugins/jspsych-maxdiff.js +0 -174
- 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 -213
- 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 -320
- package/plugins/jspsych-video-keyboard-response.js +0 -279
- package/plugins/jspsych-video-slider-response.js +0 -351
- 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/template/jspsych-plugin-template.js +0 -35
- package/tests/README.md +0 -7
- 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 -369
- 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 -254
- package/tests/jsPsych/timelines.test.js +0 -498
- package/tests/jsPsych.data/datacollection.test.js +0 -116
- 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.pluginAPI/pluginapi.test.js +0 -144
- package/tests/jsPsych.randomization/randomziation.test.js +0 -27
- package/tests/jsPsych.utils/utils.test.js +0 -58
- package/tests/media/blue.png +0 -0
- package/tests/media/orange.png +0 -0
- package/tests/media/sample_video.mp4 +0 -0
- package/tests/media/sound.mp3 +0 -0
- package/tests/plugins/plugin-animation.test.js +0 -35
- 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 -274
- 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 -140
- package/tests/plugins/plugin-free-sort.test.js +0 -112
- 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 -328
- package/tests/plugins/plugin-iat-image.test.js +0 -308
- package/tests/plugins/plugin-image-button-response.test.js +0 -183
- package/tests/plugins/plugin-image-keyboard-response.test.js +0 -154
- package/tests/plugins/plugin-image-slider-response.test.js +0 -183
- package/tests/plugins/plugin-instructions.test.js +0 -66
- package/tests/plugins/plugin-maxdiff.test.js +0 -39
- package/tests/plugins/plugin-rdk.test.js +0 -17
- 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 -69
- 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 -48
- package/tests/plugins/plugin-survey-multi-select.test.js +0 -72
- package/tests/plugins/plugin-survey-text.test.js +0 -115
- package/tests/plugins/plugin-video-button-response.test.js +0 -35
- package/tests/plugins/plugin-video-keyboard-response.test.js +0 -35
- package/tests/plugins/plugin-video-slider-response.test.js +0 -34
- 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,279 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* jspsych-video-keyboard-response
|
|
3
|
-
* Josh de Leeuw
|
|
4
|
-
*
|
|
5
|
-
* plugin for playing a video file and getting a keyboard response
|
|
6
|
-
*
|
|
7
|
-
* documentation: docs.jspsych.org
|
|
8
|
-
*
|
|
9
|
-
**/
|
|
10
|
-
|
|
11
|
-
jsPsych.plugins["video-keyboard-response"] = (function() {
|
|
12
|
-
|
|
13
|
-
var plugin = {};
|
|
14
|
-
|
|
15
|
-
jsPsych.pluginAPI.registerPreload('video-keyboard-response', 'stimulus', 'video');
|
|
16
|
-
|
|
17
|
-
plugin.info = {
|
|
18
|
-
name: 'video-keyboard-response',
|
|
19
|
-
description: '',
|
|
20
|
-
parameters: {
|
|
21
|
-
stimulus: {
|
|
22
|
-
type: jsPsych.plugins.parameterType.VIDEO,
|
|
23
|
-
pretty_name: 'Video',
|
|
24
|
-
default: undefined,
|
|
25
|
-
description: 'The video file to play.'
|
|
26
|
-
},
|
|
27
|
-
choices: {
|
|
28
|
-
type: jsPsych.plugins.parameterType.KEYCODE,
|
|
29
|
-
pretty_name: 'Choices',
|
|
30
|
-
array: true,
|
|
31
|
-
default: jsPsych.ALL_KEYS,
|
|
32
|
-
description: 'The keys the subject is allowed to press to respond to the stimulus.'
|
|
33
|
-
},
|
|
34
|
-
prompt: {
|
|
35
|
-
type: jsPsych.plugins.parameterType.STRING,
|
|
36
|
-
pretty_name: 'Prompt',
|
|
37
|
-
default: null,
|
|
38
|
-
description: 'Any content here will be displayed below the stimulus.'
|
|
39
|
-
},
|
|
40
|
-
width: {
|
|
41
|
-
type: jsPsych.plugins.parameterType.INT,
|
|
42
|
-
pretty_name: 'Width',
|
|
43
|
-
default: '',
|
|
44
|
-
description: 'The width of the video in pixels.'
|
|
45
|
-
},
|
|
46
|
-
height: {
|
|
47
|
-
type: jsPsych.plugins.parameterType.INT,
|
|
48
|
-
pretty_name: 'Height',
|
|
49
|
-
default: '',
|
|
50
|
-
description: 'The height of the video display in pixels.'
|
|
51
|
-
},
|
|
52
|
-
autoplay: {
|
|
53
|
-
type: jsPsych.plugins.parameterType.BOOL,
|
|
54
|
-
pretty_name: 'Autoplay',
|
|
55
|
-
default: true,
|
|
56
|
-
description: 'If true, the video will begin playing as soon as it has loaded.'
|
|
57
|
-
},
|
|
58
|
-
controls: {
|
|
59
|
-
type: jsPsych.plugins.parameterType.BOOL,
|
|
60
|
-
pretty_name: 'Controls',
|
|
61
|
-
default: false,
|
|
62
|
-
description: 'If true, the subject will be able to pause the video or move the playback to any point in the video.'
|
|
63
|
-
},
|
|
64
|
-
start: {
|
|
65
|
-
type: jsPsych.plugins.parameterType.FLOAT,
|
|
66
|
-
pretty_name: 'Start',
|
|
67
|
-
default: null,
|
|
68
|
-
description: 'Time to start the clip.'
|
|
69
|
-
},
|
|
70
|
-
stop: {
|
|
71
|
-
type: jsPsych.plugins.parameterType.FLOAT,
|
|
72
|
-
pretty_name: 'Stop',
|
|
73
|
-
default: null,
|
|
74
|
-
description: 'Time to stop the clip.'
|
|
75
|
-
},
|
|
76
|
-
rate: {
|
|
77
|
-
type: jsPsych.plugins.parameterType.FLOAT,
|
|
78
|
-
pretty_name: 'Rate',
|
|
79
|
-
default: 1,
|
|
80
|
-
description: 'The playback rate of the video. 1 is normal, <1 is slower, >1 is faster.'
|
|
81
|
-
},
|
|
82
|
-
trial_ends_after_video: {
|
|
83
|
-
type: jsPsych.plugins.parameterType.BOOL,
|
|
84
|
-
pretty_name: 'End trial after video finishes',
|
|
85
|
-
default: false,
|
|
86
|
-
description: 'If true, the trial will end immediately after the video finishes playing.'
|
|
87
|
-
},
|
|
88
|
-
trial_duration: {
|
|
89
|
-
type: jsPsych.plugins.parameterType.INT,
|
|
90
|
-
pretty_name: 'Trial duration',
|
|
91
|
-
default: null,
|
|
92
|
-
description: 'How long to show trial before it ends.'
|
|
93
|
-
},
|
|
94
|
-
response_ends_trial: {
|
|
95
|
-
type: jsPsych.plugins.parameterType.BOOL,
|
|
96
|
-
pretty_name: 'Response ends trial',
|
|
97
|
-
default: true,
|
|
98
|
-
description: 'If true, the trial will end when subject makes a response.'
|
|
99
|
-
},
|
|
100
|
-
response_allowed_while_playing: {
|
|
101
|
-
type: jsPsych.plugins.parameterType.BOOL,
|
|
102
|
-
pretty_name: 'Response allowed while playing',
|
|
103
|
-
default: true,
|
|
104
|
-
description: 'If true, then responses are allowed while the video is playing. '+
|
|
105
|
-
'If false, then the video must finish playing before a response is accepted.'
|
|
106
|
-
}
|
|
107
|
-
}
|
|
108
|
-
}
|
|
109
|
-
|
|
110
|
-
plugin.trial = function(display_element, trial) {
|
|
111
|
-
|
|
112
|
-
// setup stimulus
|
|
113
|
-
var video_html = '<div>'
|
|
114
|
-
video_html += '<video id="jspsych-video-keyboard-response-stimulus"';
|
|
115
|
-
|
|
116
|
-
if(trial.width) {
|
|
117
|
-
video_html += ' width="'+trial.width+'"';
|
|
118
|
-
}
|
|
119
|
-
if(trial.height) {
|
|
120
|
-
video_html += ' height="'+trial.height+'"';
|
|
121
|
-
}
|
|
122
|
-
if(trial.autoplay & (trial.start == null)){
|
|
123
|
-
// if autoplay is true and the start time is specified, then the video will start automatically
|
|
124
|
-
// via the play() method, rather than the autoplay attribute, to prevent showing the first frame
|
|
125
|
-
video_html += " autoplay ";
|
|
126
|
-
}
|
|
127
|
-
if(trial.controls){
|
|
128
|
-
video_html +=" controls ";
|
|
129
|
-
}
|
|
130
|
-
if (trial.start !== null) {
|
|
131
|
-
// hide video element when page loads if the start time is specified,
|
|
132
|
-
// to prevent the video element from showing the first frame
|
|
133
|
-
video_html += ' style="visibility: hidden;"';
|
|
134
|
-
}
|
|
135
|
-
video_html +=">";
|
|
136
|
-
|
|
137
|
-
var video_preload_blob = jsPsych.pluginAPI.getVideoBuffer(trial.stimulus[0]);
|
|
138
|
-
if(!video_preload_blob) {
|
|
139
|
-
for(var i=0; i<trial.stimulus.length; i++){
|
|
140
|
-
var file_name = trial.stimulus[i];
|
|
141
|
-
if(file_name.indexOf('?') > -1){
|
|
142
|
-
file_name = file_name.substring(0, file_name.indexOf('?'));
|
|
143
|
-
}
|
|
144
|
-
var type = file_name.substr(file_name.lastIndexOf('.') + 1);
|
|
145
|
-
type = type.toLowerCase();
|
|
146
|
-
if (type == "mov") {
|
|
147
|
-
console.warn('Warning: video-keyboard-response plugin does not reliably support .mov files.')
|
|
148
|
-
}
|
|
149
|
-
video_html+='<source src="' + file_name + '" type="video/'+type+'">';
|
|
150
|
-
}
|
|
151
|
-
}
|
|
152
|
-
video_html += "</video>";
|
|
153
|
-
video_html += "</div>";
|
|
154
|
-
|
|
155
|
-
// add prompt if there is one
|
|
156
|
-
if (trial.prompt !== null) {
|
|
157
|
-
video_html += trial.prompt;
|
|
158
|
-
}
|
|
159
|
-
|
|
160
|
-
display_element.innerHTML = video_html;
|
|
161
|
-
|
|
162
|
-
var video_element = display_element.querySelector('#jspsych-video-keyboard-response-stimulus');
|
|
163
|
-
|
|
164
|
-
if(video_preload_blob){
|
|
165
|
-
video_element.src = video_preload_blob;
|
|
166
|
-
}
|
|
167
|
-
|
|
168
|
-
video_element.onended = function(){
|
|
169
|
-
if(trial.trial_ends_after_video){
|
|
170
|
-
end_trial();
|
|
171
|
-
}
|
|
172
|
-
if ((trial.response_allowed_while_playing == false) & (!trial.trial_ends_after_video)) {
|
|
173
|
-
// start keyboard listener
|
|
174
|
-
var keyboardListener = jsPsych.pluginAPI.getKeyboardResponse({
|
|
175
|
-
callback_function: after_response,
|
|
176
|
-
valid_responses: trial.choices,
|
|
177
|
-
rt_method: 'performance',
|
|
178
|
-
persist: false,
|
|
179
|
-
allow_held_key: false,
|
|
180
|
-
});
|
|
181
|
-
}
|
|
182
|
-
}
|
|
183
|
-
|
|
184
|
-
video_element.playbackRate = trial.rate;
|
|
185
|
-
|
|
186
|
-
// if video start time is specified, hide the video and set the starting time
|
|
187
|
-
// before showing and playing, so that the video doesn't automatically show the first frame
|
|
188
|
-
if(trial.start !== null){
|
|
189
|
-
video_element.pause();
|
|
190
|
-
video_element.currentTime = trial.start;
|
|
191
|
-
video_element.onseeked = function() {
|
|
192
|
-
video_element.style.visibility = "visible";
|
|
193
|
-
if (trial.autoplay) {
|
|
194
|
-
video_element.play();
|
|
195
|
-
}
|
|
196
|
-
}
|
|
197
|
-
}
|
|
198
|
-
|
|
199
|
-
if(trial.stop !== null){
|
|
200
|
-
video_element.addEventListener('timeupdate', function(e){
|
|
201
|
-
var currenttime = video_element.currentTime;
|
|
202
|
-
if(currenttime >= trial.stop){
|
|
203
|
-
video_element.pause();
|
|
204
|
-
}
|
|
205
|
-
})
|
|
206
|
-
}
|
|
207
|
-
|
|
208
|
-
// store response
|
|
209
|
-
var response = {
|
|
210
|
-
rt: null,
|
|
211
|
-
key: null
|
|
212
|
-
};
|
|
213
|
-
|
|
214
|
-
// function to end trial when it is time
|
|
215
|
-
function end_trial() {
|
|
216
|
-
|
|
217
|
-
// kill any remaining setTimeout handlers
|
|
218
|
-
jsPsych.pluginAPI.clearAllTimeouts();
|
|
219
|
-
|
|
220
|
-
// kill keyboard listeners
|
|
221
|
-
jsPsych.pluginAPI.cancelAllKeyboardResponses();
|
|
222
|
-
|
|
223
|
-
// stop the video file if it is playing
|
|
224
|
-
// remove end event listeners if they exist
|
|
225
|
-
display_element.querySelector('#jspsych-video-keyboard-response-stimulus').pause();
|
|
226
|
-
display_element.querySelector('#jspsych-video-keyboard-response-stimulus').onended = function(){ };
|
|
227
|
-
|
|
228
|
-
// gather the data to store for the trial
|
|
229
|
-
var trial_data = {
|
|
230
|
-
"rt": response.rt,
|
|
231
|
-
"stimulus": JSON.stringify(trial.stimulus),
|
|
232
|
-
"key_press": response.key
|
|
233
|
-
};
|
|
234
|
-
|
|
235
|
-
// clear the display
|
|
236
|
-
display_element.innerHTML = '';
|
|
237
|
-
|
|
238
|
-
// move on to the next trial
|
|
239
|
-
jsPsych.finishTrial(trial_data);
|
|
240
|
-
}
|
|
241
|
-
|
|
242
|
-
// function to handle responses by the subject
|
|
243
|
-
var after_response = function(info) {
|
|
244
|
-
|
|
245
|
-
// after a valid response, the stimulus will have the CSS class 'responded'
|
|
246
|
-
// which can be used to provide visual feedback that a response was recorded
|
|
247
|
-
display_element.querySelector('#jspsych-video-keyboard-response-stimulus').className += ' responded';
|
|
248
|
-
|
|
249
|
-
// only record the first response
|
|
250
|
-
if (response.key == null) {
|
|
251
|
-
response = info;
|
|
252
|
-
}
|
|
253
|
-
|
|
254
|
-
if (trial.response_ends_trial) {
|
|
255
|
-
end_trial();
|
|
256
|
-
}
|
|
257
|
-
};
|
|
258
|
-
|
|
259
|
-
// start the response listener
|
|
260
|
-
if ((trial.choices != jsPsych.NO_KEYS) & (trial.response_allowed_while_playing)) {
|
|
261
|
-
var keyboardListener = jsPsych.pluginAPI.getKeyboardResponse({
|
|
262
|
-
callback_function: after_response,
|
|
263
|
-
valid_responses: trial.choices,
|
|
264
|
-
rt_method: 'performance',
|
|
265
|
-
persist: false,
|
|
266
|
-
allow_held_key: false,
|
|
267
|
-
});
|
|
268
|
-
}
|
|
269
|
-
|
|
270
|
-
// end trial if time limit is set
|
|
271
|
-
if (trial.trial_duration !== null) {
|
|
272
|
-
jsPsych.pluginAPI.setTimeout(function() {
|
|
273
|
-
end_trial();
|
|
274
|
-
}, trial.trial_duration);
|
|
275
|
-
}
|
|
276
|
-
};
|
|
277
|
-
|
|
278
|
-
return plugin;
|
|
279
|
-
})();
|
|
@@ -1,351 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* jspsych-video-slider-response
|
|
3
|
-
* Josh de Leeuw
|
|
4
|
-
*
|
|
5
|
-
* plugin for playing a video file and getting a slider response
|
|
6
|
-
*
|
|
7
|
-
* documentation: docs.jspsych.org
|
|
8
|
-
*
|
|
9
|
-
**/
|
|
10
|
-
|
|
11
|
-
jsPsych.plugins["video-slider-response"] = (function() {
|
|
12
|
-
|
|
13
|
-
var plugin = {};
|
|
14
|
-
|
|
15
|
-
jsPsych.pluginAPI.registerPreload('video-slider-response', 'stimulus', 'video');
|
|
16
|
-
|
|
17
|
-
plugin.info = {
|
|
18
|
-
name: 'video-slider-response',
|
|
19
|
-
description: '',
|
|
20
|
-
parameters: {
|
|
21
|
-
stimulus: {
|
|
22
|
-
type: jsPsych.plugins.parameterType.VIDEO,
|
|
23
|
-
pretty_name: 'Video',
|
|
24
|
-
default: undefined,
|
|
25
|
-
description: 'The video file to play.'
|
|
26
|
-
},
|
|
27
|
-
prompt: {
|
|
28
|
-
type: jsPsych.plugins.parameterType.STRING,
|
|
29
|
-
pretty_name: 'Prompt',
|
|
30
|
-
default: null,
|
|
31
|
-
description: 'Any content here will be displayed below the stimulus.'
|
|
32
|
-
},
|
|
33
|
-
width: {
|
|
34
|
-
type: jsPsych.plugins.parameterType.INT,
|
|
35
|
-
pretty_name: 'Width',
|
|
36
|
-
default: '',
|
|
37
|
-
description: 'The width of the video in pixels.'
|
|
38
|
-
},
|
|
39
|
-
height: {
|
|
40
|
-
type: jsPsych.plugins.parameterType.INT,
|
|
41
|
-
pretty_name: 'Height',
|
|
42
|
-
default: '',
|
|
43
|
-
description: 'The height of the video display in pixels.'
|
|
44
|
-
},
|
|
45
|
-
autoplay: {
|
|
46
|
-
type: jsPsych.plugins.parameterType.BOOL,
|
|
47
|
-
pretty_name: 'Autoplay',
|
|
48
|
-
default: true,
|
|
49
|
-
description: 'If true, the video will begin playing as soon as it has loaded.'
|
|
50
|
-
},
|
|
51
|
-
controls: {
|
|
52
|
-
type: jsPsych.plugins.parameterType.BOOL,
|
|
53
|
-
pretty_name: 'Controls',
|
|
54
|
-
default: false,
|
|
55
|
-
description: 'If true, the subject will be able to pause the video or move the playback to any point in the video.'
|
|
56
|
-
},
|
|
57
|
-
start: {
|
|
58
|
-
type: jsPsych.plugins.parameterType.FLOAT,
|
|
59
|
-
pretty_name: 'Start',
|
|
60
|
-
default: null,
|
|
61
|
-
description: 'Time to start the clip.'
|
|
62
|
-
},
|
|
63
|
-
stop: {
|
|
64
|
-
type: jsPsych.plugins.parameterType.FLOAT,
|
|
65
|
-
pretty_name: 'Stop',
|
|
66
|
-
default: null,
|
|
67
|
-
description: 'Time to stop the clip.'
|
|
68
|
-
},
|
|
69
|
-
rate: {
|
|
70
|
-
type: jsPsych.plugins.parameterType.FLOAT,
|
|
71
|
-
pretty_name: 'Rate',
|
|
72
|
-
default: 1,
|
|
73
|
-
description: 'The playback rate of the video. 1 is normal, <1 is slower, >1 is faster.'
|
|
74
|
-
},
|
|
75
|
-
min: {
|
|
76
|
-
type: jsPsych.plugins.parameterType.INT,
|
|
77
|
-
pretty_name: 'Min slider',
|
|
78
|
-
default: 0,
|
|
79
|
-
description: 'Sets the minimum value of the slider.'
|
|
80
|
-
},
|
|
81
|
-
max: {
|
|
82
|
-
type: jsPsych.plugins.parameterType.INT,
|
|
83
|
-
pretty_name: 'Max slider',
|
|
84
|
-
default: 100,
|
|
85
|
-
description: 'Sets the maximum value of the slider',
|
|
86
|
-
},
|
|
87
|
-
slider_start: {
|
|
88
|
-
type: jsPsych.plugins.parameterType.INT,
|
|
89
|
-
pretty_name: 'Slider starting value',
|
|
90
|
-
default: 50,
|
|
91
|
-
description: 'Sets the starting value of the slider',
|
|
92
|
-
},
|
|
93
|
-
step: {
|
|
94
|
-
type: jsPsych.plugins.parameterType.INT,
|
|
95
|
-
pretty_name: 'Step',
|
|
96
|
-
default: 1,
|
|
97
|
-
description: 'Sets the step of the slider'
|
|
98
|
-
},
|
|
99
|
-
labels: {
|
|
100
|
-
type: jsPsych.plugins.parameterType.HTML_STRING,
|
|
101
|
-
pretty_name:'Labels',
|
|
102
|
-
default: [],
|
|
103
|
-
array: true,
|
|
104
|
-
description: 'Labels of the slider.',
|
|
105
|
-
},
|
|
106
|
-
slider_width: {
|
|
107
|
-
type: jsPsych.plugins.parameterType.INT,
|
|
108
|
-
pretty_name:'Slider width',
|
|
109
|
-
default: null,
|
|
110
|
-
description: 'Width of the slider in pixels.'
|
|
111
|
-
},
|
|
112
|
-
button_label: {
|
|
113
|
-
type: jsPsych.plugins.parameterType.STRING,
|
|
114
|
-
pretty_name: 'Button label',
|
|
115
|
-
default: 'Continue',
|
|
116
|
-
array: false,
|
|
117
|
-
description: 'Label of the button to advance.'
|
|
118
|
-
},
|
|
119
|
-
require_movement: {
|
|
120
|
-
type: jsPsych.plugins.parameterType.BOOL,
|
|
121
|
-
pretty_name: 'Require movement',
|
|
122
|
-
default: false,
|
|
123
|
-
description: 'If true, the participant will have to move the slider before continuing.'
|
|
124
|
-
},
|
|
125
|
-
trial_ends_after_video: {
|
|
126
|
-
type: jsPsych.plugins.parameterType.BOOL,
|
|
127
|
-
pretty_name: 'End trial after video finishes',
|
|
128
|
-
default: false,
|
|
129
|
-
description: 'If true, the trial will end immediately after the video finishes playing.'
|
|
130
|
-
},
|
|
131
|
-
trial_duration: {
|
|
132
|
-
type: jsPsych.plugins.parameterType.INT,
|
|
133
|
-
pretty_name: 'Trial duration',
|
|
134
|
-
default: null,
|
|
135
|
-
description: 'How long to show trial before it ends.'
|
|
136
|
-
},
|
|
137
|
-
response_ends_trial: {
|
|
138
|
-
type: jsPsych.plugins.parameterType.BOOL,
|
|
139
|
-
pretty_name: 'Response ends trial',
|
|
140
|
-
default: true,
|
|
141
|
-
description: 'If true, the trial will end when subject makes a response.'
|
|
142
|
-
},
|
|
143
|
-
response_allowed_while_playing: {
|
|
144
|
-
type: jsPsych.plugins.parameterType.BOOL,
|
|
145
|
-
pretty_name: 'Response allowed while playing',
|
|
146
|
-
default: true,
|
|
147
|
-
description: 'If true, then responses are allowed while the video is playing. '+
|
|
148
|
-
'If false, then the video must finish playing before a response is accepted.'
|
|
149
|
-
}
|
|
150
|
-
}
|
|
151
|
-
}
|
|
152
|
-
|
|
153
|
-
plugin.trial = function(display_element, trial) {
|
|
154
|
-
|
|
155
|
-
// half of the thumb width value from jspsych.css, used to adjust the label positions
|
|
156
|
-
var half_thumb_width = 7.5;
|
|
157
|
-
|
|
158
|
-
// setup stimulus
|
|
159
|
-
var video_html = '<video id="jspsych-video-slider-response-stimulus-video"';
|
|
160
|
-
|
|
161
|
-
if(trial.width) {
|
|
162
|
-
video_html += ' width="'+trial.width+'"';
|
|
163
|
-
}
|
|
164
|
-
if(trial.height) {
|
|
165
|
-
video_html += ' height="'+trial.height+'"';
|
|
166
|
-
}
|
|
167
|
-
if(trial.autoplay & (trial.start == null)){
|
|
168
|
-
// if autoplay is true and the start time is specified, then the video will start automatically
|
|
169
|
-
// via the play() method, rather than the autoplay attribute, to prevent showing the first frame
|
|
170
|
-
video_html += " autoplay ";
|
|
171
|
-
}
|
|
172
|
-
if(trial.controls){
|
|
173
|
-
video_html +=" controls ";
|
|
174
|
-
}
|
|
175
|
-
if (trial.start !== null) {
|
|
176
|
-
// hide video element when page loads if the start time is specified,
|
|
177
|
-
// to prevent the video element from showing the first frame
|
|
178
|
-
video_html += ' style="visibility: hidden;"';
|
|
179
|
-
}
|
|
180
|
-
video_html +=">";
|
|
181
|
-
|
|
182
|
-
var video_preload_blob = jsPsych.pluginAPI.getVideoBuffer(trial.stimulus[0]);
|
|
183
|
-
if(!video_preload_blob) {
|
|
184
|
-
for(var i=0; i<trial.stimulus.length; i++){
|
|
185
|
-
var file_name = trial.stimulus[i];
|
|
186
|
-
if(file_name.indexOf('?') > -1){
|
|
187
|
-
file_name = file_name.substring(0, file_name.indexOf('?'));
|
|
188
|
-
}
|
|
189
|
-
var type = file_name.substr(file_name.lastIndexOf('.') + 1);
|
|
190
|
-
type = type.toLowerCase();
|
|
191
|
-
if (type == "mov") {
|
|
192
|
-
console.warn('Warning: video-slider-response plugin does not reliably support .mov files.')
|
|
193
|
-
}
|
|
194
|
-
video_html+='<source src="' + file_name + '" type="video/'+type+'">';
|
|
195
|
-
}
|
|
196
|
-
}
|
|
197
|
-
video_html += "</video>";
|
|
198
|
-
|
|
199
|
-
var html = '<div id="jspsych-video-slider-response-wrapper" style="margin: 100px 0px;">';
|
|
200
|
-
html += '<div id="jspsych-video-slider-response-stimulus">' + video_html + '</div>';
|
|
201
|
-
html += '<div class="jspsych-video-slider-response-container" style="position:relative; margin: 0 auto 3em auto; width:';
|
|
202
|
-
if (trial.slider_width !== null) {
|
|
203
|
-
html += trial.slider_width+'px;'
|
|
204
|
-
} else {
|
|
205
|
-
html += 'auto;'
|
|
206
|
-
}
|
|
207
|
-
html += '">';
|
|
208
|
-
html += '<input type="range" class="jspsych-slider" value="'+trial.slider_start+'" min="'+trial.min+'" max="'+trial.max+'" step="'+trial.step+'" id="jspsych-video-slider-response-response"';
|
|
209
|
-
if (!trial.response_allowed_while_playing) {
|
|
210
|
-
html += ' disabled';
|
|
211
|
-
}
|
|
212
|
-
html += '></input><div>'
|
|
213
|
-
for(var j=0; j < trial.labels.length; j++){
|
|
214
|
-
var label_width_perc = 100/(trial.labels.length-1);
|
|
215
|
-
var percent_of_range = j * (100/(trial.labels.length - 1));
|
|
216
|
-
var percent_dist_from_center = ((percent_of_range-50)/50)*100;
|
|
217
|
-
var offset = (percent_dist_from_center * half_thumb_width)/100;
|
|
218
|
-
html += '<div style="border: 1px solid transparent; display: inline-block; position: absolute; '+
|
|
219
|
-
'left:calc('+percent_of_range+'% - ('+label_width_perc+'% / 2) - '+offset+'px); text-align: center; width: '+label_width_perc+'%;">';
|
|
220
|
-
html += '<span style="text-align: center; font-size: 80%;">'+trial.labels[j]+'</span>';
|
|
221
|
-
html += '</div>'
|
|
222
|
-
}
|
|
223
|
-
html += '</div>';
|
|
224
|
-
html += '</div>';
|
|
225
|
-
html += '</div>';
|
|
226
|
-
|
|
227
|
-
// add prompt if there is one
|
|
228
|
-
if (trial.prompt !== null) {
|
|
229
|
-
html += '<div>'+trial.prompt+'</div>';
|
|
230
|
-
}
|
|
231
|
-
|
|
232
|
-
// add submit button
|
|
233
|
-
var next_disabled_attribute = "";
|
|
234
|
-
if (trial.require_movement | !trial.response_allowed_while_playing) {
|
|
235
|
-
next_disabled_attribute = "disabled";
|
|
236
|
-
}
|
|
237
|
-
html += '<button id="jspsych-video-slider-response-next" class="jspsych-btn" '+ next_disabled_attribute + '>'+trial.button_label+'</button>';
|
|
238
|
-
|
|
239
|
-
display_element.innerHTML = html;
|
|
240
|
-
|
|
241
|
-
var video_element = display_element.querySelector('#jspsych-video-slider-response-stimulus-video');
|
|
242
|
-
|
|
243
|
-
if(video_preload_blob){
|
|
244
|
-
video_element.src = video_preload_blob;
|
|
245
|
-
}
|
|
246
|
-
|
|
247
|
-
video_element.onended = function(){
|
|
248
|
-
if(trial.trial_ends_after_video){
|
|
249
|
-
end_trial();
|
|
250
|
-
} else if (!trial.response_allowed_while_playing) {
|
|
251
|
-
enable_slider();
|
|
252
|
-
}
|
|
253
|
-
}
|
|
254
|
-
|
|
255
|
-
video_element.playbackRate = trial.rate;
|
|
256
|
-
|
|
257
|
-
// if video start time is specified, hide the video and set the starting time
|
|
258
|
-
// before showing and playing, so that the video doesn't automatically show the first frame
|
|
259
|
-
if(trial.start !== null){
|
|
260
|
-
video_element.pause();
|
|
261
|
-
video_element.currentTime = trial.start;
|
|
262
|
-
video_element.onseeked = function() {
|
|
263
|
-
video_element.style.visibility = "visible";
|
|
264
|
-
if (trial.autoplay) {
|
|
265
|
-
video_element.play();
|
|
266
|
-
}
|
|
267
|
-
}
|
|
268
|
-
}
|
|
269
|
-
|
|
270
|
-
if(trial.stop !== null){
|
|
271
|
-
video_element.addEventListener('timeupdate', function(e){
|
|
272
|
-
var currenttime = video_element.currentTime;
|
|
273
|
-
if(currenttime >= trial.stop){
|
|
274
|
-
video_element.pause();
|
|
275
|
-
}
|
|
276
|
-
})
|
|
277
|
-
}
|
|
278
|
-
|
|
279
|
-
if(trial.require_movement){
|
|
280
|
-
display_element.querySelector('#jspsych-video-slider-response-response').addEventListener('click', function(){
|
|
281
|
-
display_element.querySelector('#jspsych-video-slider-response-next').disabled = false;
|
|
282
|
-
});
|
|
283
|
-
}
|
|
284
|
-
|
|
285
|
-
var startTime = performance.now();
|
|
286
|
-
|
|
287
|
-
// store response
|
|
288
|
-
var response = {
|
|
289
|
-
rt: null,
|
|
290
|
-
response: null
|
|
291
|
-
};
|
|
292
|
-
|
|
293
|
-
display_element.querySelector('#jspsych-video-slider-response-next').addEventListener('click', function() {
|
|
294
|
-
// measure response time
|
|
295
|
-
var endTime = performance.now();
|
|
296
|
-
response.rt = endTime - startTime;
|
|
297
|
-
response.response = display_element.querySelector('#jspsych-video-slider-response-response').valueAsNumber;
|
|
298
|
-
|
|
299
|
-
if(trial.response_ends_trial){
|
|
300
|
-
end_trial();
|
|
301
|
-
} else {
|
|
302
|
-
display_element.querySelector('#jspsych-video-slider-response-next').disabled = true;
|
|
303
|
-
}
|
|
304
|
-
|
|
305
|
-
});
|
|
306
|
-
|
|
307
|
-
// function to end trial when it is time
|
|
308
|
-
function end_trial() {
|
|
309
|
-
|
|
310
|
-
// kill any remaining setTimeout handlers
|
|
311
|
-
jsPsych.pluginAPI.clearAllTimeouts();
|
|
312
|
-
|
|
313
|
-
// stop the video file if it is playing
|
|
314
|
-
// remove any remaining end event handlers
|
|
315
|
-
display_element.querySelector('#jspsych-video-slider-response-stimulus-video').pause();
|
|
316
|
-
display_element.querySelector('#jspsych-video-slider-response-stimulus-video').onended = function() {};
|
|
317
|
-
|
|
318
|
-
// gather the data to store for the trial
|
|
319
|
-
var trial_data = {
|
|
320
|
-
"rt": response.rt,
|
|
321
|
-
"stimulus": JSON.stringify(trial.stimulus),
|
|
322
|
-
"start": trial.start,
|
|
323
|
-
"slider_start": trial.slider_start,
|
|
324
|
-
"response": response.response
|
|
325
|
-
};
|
|
326
|
-
|
|
327
|
-
// clear the display
|
|
328
|
-
display_element.innerHTML = '';
|
|
329
|
-
|
|
330
|
-
// move on to the next trial
|
|
331
|
-
jsPsych.finishTrial(trial_data);
|
|
332
|
-
};
|
|
333
|
-
|
|
334
|
-
// function to enable slider after video ends
|
|
335
|
-
function enable_slider() {
|
|
336
|
-
document.querySelector('#jspsych-video-slider-response-response').disabled = false;
|
|
337
|
-
if (!trial.require_movement) {
|
|
338
|
-
document.querySelector('#jspsych-video-slider-response-next').disabled = false;
|
|
339
|
-
}
|
|
340
|
-
}
|
|
341
|
-
|
|
342
|
-
// end trial if time limit is set
|
|
343
|
-
if (trial.trial_duration !== null) {
|
|
344
|
-
jsPsych.pluginAPI.setTimeout(function() {
|
|
345
|
-
end_trial();
|
|
346
|
-
}, trial.trial_duration);
|
|
347
|
-
}
|
|
348
|
-
};
|
|
349
|
-
|
|
350
|
-
return plugin;
|
|
351
|
-
})();
|