Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

TransitionTimeMs is not inherited from one callback invocation to the next #76

Open
jimbojw opened this issue Oct 11, 2022 · 0 comments
Labels
bug Something isn't working
Milestone

Comments

@jimbojw
Copy link
Collaborator

jimbojw commented Oct 11, 2022

Inside of a Sprite callback, the API user can set TransitionTimeMs to specify how long the transition should take to complete. However, unlike other sprite attributes, TransitionTimeMs is not inherited from the previous phase and must be set in each phase callback.

Example using Sprite API (see comments):

const scene = new Scene({
  defaultTransitionTimeMs: 400,  // Default transition time is 400.
});

const sprite = scene.createSprite();

sprite
  .enter((s: SpriteView) => {
    s.TransitionTimeMs = 1000;  // Explicitly set time to 1000 (1 sec).
    s.SizeWorld = 1;
    s.FillOpacity = 0;
  })
  .update((s: SpriteView) => {
    // CURRENTLY: s.TransitionTimeMs implicitly set to the default (400).
    // DESIRED: s.TransitionTimeMs should persist the 1000 from enter().

    // s.SizeWorld is correctly inherited from previous state (1).

    s.FillOpacity = 1;
  });

Example using the Selection API (see comments):

const scene = new Scene({
  defaultTransitionTimeMs: 500,  // Default transition time is 500.
});

const selection = scene.createSelection();

selection
  .onInit((s: SpriteView) => {
    // CURRENTLY: Ignored for rendering and not persisted.
    // DESIRED: Still ignore for rendering, but persist value.
    s.TransitionTimeMs = 1000;  

    s.SizeWorld = 1;
    s.FillOpacity = 0;
  })
  .onEnter((s: SpriteView) => {
    // CURRENTLY: s.TransitionTimeMs implicitly set to the default (500).
    // DESIRED: s.TransitionTimeMs should persist 1000 from onInit().

    s.TransitionTimeMs = 2000;  // Explicitly set to 2000.

    // s.SizeWorld is inherited from previous state (1).
    s.FillOpacity = 1;
  })
  .onUpdate((s: SpriteView) => {
    // CURRENTLY: s.TransitionTimeMs implicitly set to the default (500).
    // DESIRED: s.TransitionTimeMs should persist 2000 from onEnter().

    // s.SizeWorld is inherited from previous state (1).
    s.FillOpacity = 1;
  });

Ideally, TransitionTimeMs should persist between callback invocations. The Scene's defaultTransitionTimeMs should only be used until the first time a transition time is needed, and then after that the previous value should be used again. This would make it consistent with other sprite attributes.

Note: The fact that the transition time is ignored for Selection onInit() is intentional. The attributes set for onInit() should be applied before the first frame in which the Sprite is rendered. However, the TransitionTimeMs set during onInit() should be used for callback invocations. Ignoring this value and not persisting it is counterintuitive.

@jimbojw jimbojw added this to the V0.2.0 milestone Mar 14, 2023
@jimbojw jimbojw added the bug Something isn't working label Mar 14, 2023
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working
Projects
None yet
Development

No branches or pull requests

1 participant