Skip to content

Missed "frame" when going back to UsersListScreen #3

@MaciejCiemiega

Description

@MaciejCiemiega

It's not that visible on the gif, you can only see it when going back from Irene.

When going from UsersListScreen to UserDetailsScreen everything works fine. The sequence is as follows:

  1. startElement from previous screen is gone
  2. endElement calls onElementRegistered and hides itself (by using alpha = 0)
  3. transition is set to SharedElementTransition.WaitingForEndElementPosition and invalidateTransitionsOverlay() is called.
  4. SharedElementTransitionsOverlay reads that transition and draws SharedElementTransitionPlaceholder of startElement for a brief moment until endElement will be positioned and we can launch the real transition.
  5. endElement calls onElementPositioned.
  6. transition is set to SharedElementTransition.InProgress and invalidateTransitionsOverlay() is called.
  7. SharedElementTransitionsOverlay reads and draws the real transition from startElement to endElement

Steps 2, 3 and 4 are done in the same pass (frame?). endElement hides itself, but at the same time we already have a placeholder of startElement drawn by SharedElementTransitionsOverlay.

When going from UserDetailsScreen to UsersListScreen there is one difference though. It looks like AdapterList (that is used on UsersListScreen) never disposes its list items, even when it's gone (#1, https://issuetracker.google.com/issues/150174792). I believe it causes it to be positioned "instantly"(?). The sequence is as follows:

  1. startElement from previous screen is gone
  2. endElement calls onElementRegistered and hides itself (by using alpha = 0)
  3. transition is set to SharedElementTransition.WaitingForEndElementPosition and invalidateTransitionsOverlay() is called.
  4. DIFFERENT: NOT HAPPENING
  5. DIFFERENT: endElement calls onElementPositioned in the same pass as 2 and 3. SharedElementTransitionsOverlay had no chance to refresh, so we have missed frame.
  6. transition is set to SharedElementTransition.InProgress and invalidateTransitionsOverlay() is called.
  7. SharedElementTransitionsOverlay reads and draws the real transition from startElement to endElement

Metadata

Metadata

Assignees

No one assigned

    Labels

    No labels
    No labels

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions