Skip to content

Commit

Permalink
update photon appearance based on designer feedback, see #81
Browse files Browse the repository at this point in the history
  • Loading branch information
jbphet committed Jan 17, 2025
1 parent e4a35ed commit ca70571
Show file tree
Hide file tree
Showing 3 changed files with 8 additions and 5 deletions.
Binary file modified images/greenPhoton.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
2 changes: 1 addition & 1 deletion images/greenPhoton_png.ts
Original file line number Diff line number Diff line change
Expand Up @@ -6,5 +6,5 @@ import asyncLoader from '../../phet-core/js/asyncLoader.js';
const image = new Image();
const unlock = asyncLoader.createLock( image );
image.onload = unlock;
image.src = '';
image.src = '';
export default image;
11 changes: 7 additions & 4 deletions js/photons/view/PhotonSprites.ts
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@ import Photon from '../model/Photon.js';
// constants
const TARGET_PHOTON_VIEW_WIDTH = 10; // in screen coords, empirically determined to match the design

export default class PhotonSprites extends Sprites {
class PhotonSprites extends Sprites {

private readonly spriteInstances: SpriteInstance[];
private readonly photons: Photon[];
Expand Down Expand Up @@ -74,7 +74,7 @@ export default class PhotonSprites extends Sprites {
// canvas. That is an asynchronous process, so we need to wait for it to complete before adding the sprites.
const outlineCircle = new Circle( TARGET_PHOTON_VIEW_WIDTH / 2, {
stroke: QuantumMeasurementColors.photonBaseColorProperty.value,
lineWidth: 0.5
lineWidth: 1
} );
outlineCircle.toCanvas( canvas => {
this.photonOutlineSprite = new Sprite( new SpriteImage(
Expand Down Expand Up @@ -138,10 +138,11 @@ export default class PhotonSprites extends Sprites {
interiorSpriteInstance.matrix.setToAffine( scale, 0, xPos, 0, scale, yPos );
interiorSpriteInstance.alpha = photonMotionState.probability; // Probability based opacity

// Update the matrix for the photon outline. The outline is always fully opaque.
// Update the matrix for the photon outline.
const outlineSpriteInstance = this.spriteInstances[ ( numberOfPhotonsDisplayed - 1 ) * 2 + 1 ];
outlineSpriteInstance.sprite = this.photonOutlineSprite;
outlineSpriteInstance.matrix.setToAffine( 1, 0, xPos, 0, 1, yPos );
outlineSpriteInstance.alpha = 1; // Always fully opaque
}
}
}
Expand All @@ -157,4 +158,6 @@ export default class PhotonSprites extends Sprites {
}
}

quantumMeasurement.register( 'PhotonSprites', PhotonSprites );
quantumMeasurement.register( 'PhotonSprites', PhotonSprites );

export default PhotonSprites;

0 comments on commit ca70571

Please sign in to comment.