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

Paint tool on startup fixes #507

Merged
merged 2 commits into from
Nov 20, 2023
Merged

Paint tool on startup fixes #507

merged 2 commits into from
Nov 20, 2023

Conversation

PaulHax
Copy link
Collaborator

@PaulHax PaulHax commented Nov 15, 2023

Small paint tool fixes:

  • If session.volview.zip is loaded with the paint tool initially selected, clicking on the image did not paint.
  • If paint tool is activated when mouse is within a view, the stencil shape would not be correct.

Copy link

netlify bot commented Nov 15, 2023

Deploy Preview for volview-dev ready!

Built without sensitive environment variables

Name Link
🔨 Latest commit 155da25
🔍 Latest deploy log https://app.netlify.com/sites/volview-dev/deploys/65554a7c844b2b0008e7f526
😎 Deploy Preview https://deploy-preview-507--volview-dev.netlify.app/
📱 Preview on mobile
Toggle QR Code...

QR Code

Use your smartphone camera to open QR code link.

To edit notification comments on pull requests, go to your Netlify site configuration.

if (!(segValue in segments.byValue))
throw new Error('Segment is not available for the active labelmap');
}

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Can you explain how this block of code affected the paint tool not loading properly through a session file?

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yes. usePaintStore.deserialize calls setActiveSegment before activeSegmentGroupID is set. Later, activeSegmentGroupID will be set by useToolStore.setCurrentTool -> usePaintStore.activateTool -> setActiveLabelmapFromImage

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think then that we can solve this by calling setActiveLabelmap(segmentGroupIDMap[paint.activeSegmentGroupID]) before setActiveSegment in deserialize. I think keeping the code in setActiveSegment is good to ensure we are getting a valid segment value. Thoughts?

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Would be nice to keep the checks. I rebased a fix. Turns out segmentIDMap was not getting passed down to paint.deserialize. Also, can't setActiveSegment without a segmentGroup, so only calling setActiveSegment if one is deserialized.

@floryst
Copy link
Collaborator

floryst commented Nov 15, 2023

Overall LGTM! My quick functional test didn't reveal any issues. I just had one clarifying question.

If session.volview.zip is loaded with the paint tool initially selected,
clicking on the image did not paint.

Fix is to pass correct idMap to paint tool and only `setActiveSegment`
when a segmentGroup is selected.
If paint tool is activated when mouse is within a view, the stencil
shape would not be correct.  So call setSliceAxis at widget startup.
@floryst floryst added this pull request to the merge queue Nov 20, 2023
Merged via the queue into Kitware:main with commit a759d82 Nov 20, 2023
6 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants