From d8dc0fbfe1d7a5ee196013824bd322cf70691f49 Mon Sep 17 00:00:00 2001 From: AgustinVallejo Date: Fri, 4 Oct 2024 11:23:04 -0500 Subject: [PATCH] Adding pixel representation to the phetio state, see https://github.com/phetsims/quantum-measurement/issues/42 --- js/coins/view/CoinExperimentMeasurementArea.ts | 4 ++++ js/coins/view/CoinSetPixelRepresentation.ts | 2 ++ 2 files changed, 6 insertions(+) diff --git a/js/coins/view/CoinExperimentMeasurementArea.ts b/js/coins/view/CoinExperimentMeasurementArea.ts index f49c4db..cfdc4d1 100644 --- a/js/coins/view/CoinExperimentMeasurementArea.ts +++ b/js/coins/view/CoinExperimentMeasurementArea.ts @@ -206,6 +206,10 @@ export default class CoinExperimentMeasurementArea extends VBox { } } ); + sceneModel.coinSet.measuredDataChangedEmitter.addListener( () => { + this.measuredCoinsPixelRepresentation.redraw( sceneModel.coinSet.measuredValues ); + } ); + sceneModel.preparingExperimentProperty.link( () => this.measuredCoinsPixelRepresentation.abortAllAnimations( 0 ) ); // Create the node that will be used to cover (aka "mask") the coin so that its state can't be seen. diff --git a/js/coins/view/CoinSetPixelRepresentation.ts b/js/coins/view/CoinSetPixelRepresentation.ts index 1fe5b35..ba98069 100644 --- a/js/coins/view/CoinSetPixelRepresentation.ts +++ b/js/coins/view/CoinSetPixelRepresentation.ts @@ -39,6 +39,8 @@ export default class CoinSetPixelRepresentation extends CanvasNode { const fps = 40; const totalFrames = 4 * MEASUREMENT_PREPARATION_TIME / fps; + + // TODO: Try isSettingPhetioStateProperty.value ? 0 : MEASUREMENT_PREPARATION_TIME, https://github.com/phetsims/quantum-measurement/issues/39 this.populatingAnimation = new Animation( { to: totalFrames, duration: MEASUREMENT_PREPARATION_TIME,