Skip to content

Commit

Permalink
Making photon outline its own image to prevent over-rasterization, see
Browse files Browse the repository at this point in the history
  • Loading branch information
AgustinVallejo committed Jan 28, 2025
1 parent 3cc8ebd commit dfd06b8
Show file tree
Hide file tree
Showing 4 changed files with 34 additions and 24 deletions.
Binary file added images/greenPhotonOutline.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
10 changes: 10 additions & 0 deletions images/greenPhotonOutline_png.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
/* eslint-disable */
/* @formatter:off */

import asyncLoader from '../../phet-core/js/asyncLoader.js';

const image = new Image();
const unlock = asyncLoader.createLock( image );
image.onload = unlock;
image.src = '';
export default image;
8 changes: 8 additions & 0 deletions images/license.json
Original file line number Diff line number Diff line change
Expand Up @@ -14,5 +14,13 @@
"projectURL": "https://phet.colorado.edu",
"license": "contact [email protected]",
"notes": "created by John Blanco"
},
"greenPhotonOutline.png": {
"text": [
"Copyright 2023 University of Colorado Boulder"
],
"projectURL": "https://phet.colorado.edu",
"license": "contact [email protected]",
"notes": "created by Agustín Vallejo"
}
}
40 changes: 16 additions & 24 deletions js/photons/view/PhotonSprites.ts
Original file line number Diff line number Diff line change
Expand Up @@ -19,9 +19,9 @@
import Bounds2 from '../../../../dot/js/Bounds2.js';
import Vector2 from '../../../../dot/js/Vector2.js';
import ModelViewTransform2 from '../../../../phetcommon/js/view/ModelViewTransform2.js';
import { Circle, Sprite, SpriteImage, SpriteInstance, SpriteInstanceTransformType, Sprites } from '../../../../scenery/js/imports.js';
import { Sprite, SpriteImage, SpriteInstance, SpriteInstanceTransformType, Sprites } from '../../../../scenery/js/imports.js';
import greenPhoton_png from '../../../images/greenPhoton_png.js';
import QuantumMeasurementColors from '../../common/QuantumMeasurementColors.js';
import greenPhotonOutline_png from '../../../images/greenPhotonOutline_png.js';
import quantumMeasurement from '../../quantumMeasurement.js';
import Photon from '../model/Photon.js';

Expand All @@ -34,8 +34,8 @@ class PhotonSprites extends Sprites {
private readonly photons: Photon[];
private readonly modelViewTransform: ModelViewTransform2;

// The scale value used to render the photon interior.
private readonly photonInteriorScale: number;
// The scale value used to render the photon.
private readonly photonScale: number;

// The sprites used to render the photons.
private readonly photonInteriorSprite: Sprite | null = null;
Expand All @@ -62,29 +62,21 @@ class PhotonSprites extends Sprites {
new Vector2( greenPhoton_png.width / 2, greenPhoton_png.height / 2 ),
{ pickable: false }
) );
this.photonOutlineSprite = new Sprite( new SpriteImage(
greenPhotonOutline_png,
new Vector2( greenPhotonOutline_png.width / 2, greenPhotonOutline_png.height / 2 ),
{ pickable: false }
) );
this.mutate( { sprites: [ this.photonInteriorSprite, this.photonOutlineSprite ] } );

// Calculate the scale that will be used to render the photon interior.
this.photonInteriorScale = TARGET_PHOTON_VIEW_WIDTH / greenPhoton_png.width;
this.photonScale = TARGET_PHOTON_VIEW_WIDTH / greenPhoton_png.width;

assert && assert(
this.photonInteriorScale > 0 && this.photonInteriorScale < 100,
`photon scale factor not reasonable: ${this.photonInteriorScale}`
this.photonScale > 0 && this.photonScale < 100,
`photon scale factor not reasonable: ${this.photonScale}`
);

// Create the sprite for the outline of the photons. This is done be creating a circle and rendering it to a
// 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: 1
} );
outlineCircle.toCanvas( canvas => {
this.photonOutlineSprite = new Sprite( new SpriteImage(
canvas,
new Vector2( canvas.width / 2, canvas.height / 2 ),
{ pickable: false }
) );
this.mutate( { sprites: [ this.photonInteriorSprite!, this.photonOutlineSprite ] } );
} );

// local variables needed for the methods
this.spriteInstances = spriteInstances;
this.photons = photons;
Expand Down Expand Up @@ -130,7 +122,7 @@ class PhotonSprites extends Sprites {

const xPos = this.modelViewTransform.modelToViewX( photonStatePosition.x );
const yPos = this.modelViewTransform.modelToViewY( photonStatePosition.y );
const scale = this.photonInteriorScale;
const scale = this.photonScale;

// Update the matrix and opacity for the photon interior.
const interiorSpriteInstance = this.spriteInstances[ ( numberOfPhotonsDisplayed - 1 ) * 2 ];
Expand All @@ -141,7 +133,7 @@ class PhotonSprites extends Sprites {
// 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.matrix.setToAffine( scale, 0, xPos, 0, scale, yPos );
outlineSpriteInstance.alpha = 1; // Always fully opaque
}
}
Expand Down

0 comments on commit dfd06b8

Please sign in to comment.