11const ArgumentType = require ( '../../extension-support/argument-type' ) ;
22const BlockType = require ( '../../extension-support/block-type' ) ;
3- const Clone = require ( '../../util/clone' ) ;
43const MathUtil = require ( '../../util/math-util' ) ;
54const formatMessage = require ( 'format-message' ) ;
65const Video = require ( '../../io/video' ) ;
@@ -25,7 +24,7 @@ const menuIconURI = '
2524const blockIconURI = '' ;
2625
2726/**
28- * Class for the motion-related blocks in Scratch 3.0
27+ * Class for the Face sensing blocks in Scratch 3.0
2928 * @param {Runtime } runtime - the runtime instantiating this block package.
3029 * @constructor
3130 */
@@ -89,9 +88,6 @@ class Scratch3FaceSensingBlocks {
8988 this . _loop ( ) ;
9089 }
9190 } ) ;
92-
93- this . _clearAttachments = this . _clearAttachments . bind ( this ) ;
94- this . runtime . on ( 'PROJECT_STOP_ALL' , this . _clearAttachments ) ;
9591 }
9692
9793 /**
@@ -120,16 +116,6 @@ class Scratch3FaceSensingBlocks {
120116 return 'Scratch.faceSensing' ;
121117 }
122118
123- /**
124- * The default face sensing state, to be used when a target has no existing state.
125- * @type {FaceSensingState }
126- */
127- static get DEFAULT_FACE_SENSING_STATE ( ) {
128- return {
129- attachedToPartNumber : null
130- } ;
131- }
132-
133119 /**
134120 * Maximum length of face detection history
135121 * @type {number }
@@ -191,25 +177,6 @@ class Scratch3FaceSensingBlocks {
191177 // if there's a mix of true and false values, do not change the result
192178 }
193179
194- /**
195- * Retrieve the face-sensing state for a given target.
196- * If no state exists yet, clone the default and set it on the target.
197- *
198- * @param {Target } target - collect face sensing state for this target.
199- * @returns {FaceSensingState } the face sensing state associated with that target.
200- * @private
201- */
202- _getFaceSensingState ( target ) {
203- let faceSensingState = target . getCustomState ( Scratch3FaceSensingBlocks . STATE_KEY ) ;
204-
205- if ( ! faceSensingState ) {
206- faceSensingState = Clone . simple ( Scratch3FaceSensingBlocks . DEFAULT_FACE_SENSING_STATE ) ;
207- target . setCustomState ( Scratch3FaceSensingBlocks . STATE_KEY , faceSensingState ) ;
208- }
209-
210- return faceSensingState ;
211- }
212-
213180 /**
214181 * @returns {object } metadata for this extension and its blocks.
215182 */
@@ -264,6 +231,7 @@ class Scratch3FaceSensingBlocks {
264231 blockType : BlockType . COMMAND ,
265232 filter : [ TargetType . SPRITE ]
266233 } ,
234+ '---' ,
267235 {
268236 opcode : 'whenTilted' ,
269237 text : formatMessage ( {
@@ -306,6 +274,7 @@ class Scratch3FaceSensingBlocks {
306274 } ) ,
307275 blockType : BlockType . HAT
308276 } ,
277+ '---' ,
309278 {
310279 opcode : 'faceIsDetected' ,
311280 text : formatMessage ( {
@@ -547,17 +516,6 @@ class Scratch3FaceSensingBlocks {
547516 const pos = this . _getPartPosition ( args . PART ) ;
548517 util . target . setXY ( pos . x , pos . y ) ;
549518 }
550-
551- /**
552- * Reset any attachments between sprites and facial keypoints.
553- * @private
554- */
555- _clearAttachments ( ) {
556- this . runtime . targets . forEach ( target => {
557- const state = this . _getFaceSensingState ( target ) ;
558- state . attachedToPartNumber = null ;
559- } ) ;
560- }
561519}
562520
563521module . exports = Scratch3FaceSensingBlocks ;
0 commit comments