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

offload VQ image processing onto pooled worker threads & loading indicator #139

Closed
rob2d opened this issue Dec 13, 2023 · 0 comments · Fixed by #173
Closed

offload VQ image processing onto pooled worker threads & loading indicator #139

rob2d opened this issue Dec 13, 2023 · 0 comments · Fixed by #173
Labels
enhancement New feature or request optimization ux

Comments

@rob2d
Copy link
Owner

rob2d commented Dec 13, 2023

For specific image textures in MVC2 and CVS2, vector quantization is used to compress and decompress parts of images. compressVqBuffer uses k-clustering and is suboptimal to offload onto the main thread -- can take up to 60 seconds depending on clients PC.

Similar to loading polygon and texture files, compression before export overall should take place in pool-able ClientWorker threads.

In addition to that, state management will be needed. It may be worth considering adding RTK Query to redux toolkit to manage async state. Otherwise, a variable and UI indicator for pending/rejected/success should be managed to show a loading spinner while a user exports these.

For the moment users use it without issue but this is essentially QOL as expanding support to other games will make the issue more noticeable. It will also be easier to parallelize operations for multi file support once this occurs on another thread with a proper dialog.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request optimization ux
Projects
None yet
Development

Successfully merging a pull request may close this issue.

1 participant