Skip to content
New issue

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

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

Already on GitHub? # to your account

Molecule rotation and scaling enhancements #848

Closed
garyo opened this issue Mar 2, 2021 · 3 comments
Closed

Molecule rotation and scaling enhancements #848

garyo opened this issue Mar 2, 2021 · 3 comments
Assignees

Comments

@garyo
Copy link
Collaborator

garyo commented Mar 2, 2021

Right now, rotating individual components in NGL (ctrl+shift+left-drag) rotates around their center, which is defined as the center of mass of the structure (or assembly). This can be confusing; try rotating the default view of 2c8n for example. The center is outside the visible structure altogether. I plan to add a pivot Vector3 field to Component, and account for that in rotation and scaling, so by setting the pivot we can set the center of rotation to be anywhere -- the visible center when there's a selection, for instance.
Once that's in we can discuss auto-setting the pivot point based on assembly or selection etc.
Thoughts? Seem like a good idea? Alternative proposals?

@fredludlow
Copy link
Collaborator

I think it's a good idea - it sounds similar to what we settled on as an answer to #777?

@garyo
Copy link
Collaborator Author

garyo commented Mar 3, 2021

Yes, very similar. Actually while investigating this I came across what I think is a bug: in component.ts:updateMatrix() it passes a temp vector to getCenterUntransformed(). That's the function that returns the center of the given component. That function takes any, but no derived class expects a vector there. Instead, structure-component.ts expects an optional selection string there, and if one is passed in, it returns the center of that selection (otherwise the center of the structure). No other derived classes expect any arg there.

So one way to do at least part of this is just to pass the selection through; it's a bit complicated because of the base/derived relation, but I have it working. This alone does allow for rotating around the center of the selection (a huge improvement already, for me at least) -- which shows that the math referred to in #777 is pretty much already there. It doesn't address the symmetry/assembly issue though. But it doesn't seem that hard to extend, so I'll keep working on it.

@garyo garyo self-assigned this Mar 3, 2021
@fredludlow
Copy link
Collaborator

Closing as now tracked in #909? (Please reopen if this is a mistake!)

# for free to join this conversation on GitHub. Already have an account? # to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants