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

Feature/swoosh2 #19

Open
wants to merge 36 commits into
base: master
Choose a base branch
from
Open

Feature/swoosh2 #19

wants to merge 36 commits into from

Conversation

TheMaverickProgrammer
Copy link
Owner

@TheMaverickProgrammer TheMaverickProgrammer commented Jan 28, 2024

  1. New programmable render pipeline
  2. Supports multiple render modes to toggle to on-the-fly
  3. Supports emitting events to custom renderer
  4. Supports emitting drawables
  5. Provides Clone(...) in order to copy temporary sprite data in old SFML composite-based projects
  6. Provides Immediate event type to draw to the specified render buffer
  7. Upgraded all segue effects to use new renderer
  8. Added deferred rendering example for 3D effects in 2D games
  9. Swoosh is now multi-threaded friendly
  10. Can pass in any data to return to your next scene when using pop(...) or rewind(...) via the new .take(...) callback handler

TheMaverickProgrammer and others added 30 commits August 31, 2022 02:47
…when they submit they should render. same with bouncing text. TODO: segues crash the new renderer. Both problems can be solved by determining how to handle certain drawable lifetimes...
…irectly to the simple surface renderer to fix the issues the upgrade created and resulted in no more crashes. TODO: check every segue effect to ensure it is using the new code correctly. TODO: embed Immediate class type handler into the class so UDT renderers must implement them. TODO: Revisit pushing/popping screens - maybe create an intermediate object representing the Segue that can be configured instead of overloading long template types. TODO: Can I also use the latter idea to pass data from a pop() intention to inform the next active scene, why we left?
…ginning on deferred render proof of concept for swoosh2
…ODO: tweak lighting shader parameters and add deffered lighting. The shader may need the normal matrix after all (due to sprite rotations)
…toff equations but otherwise very promising. Added ability to switch renderers on the fly too.
…sive pass. TODO: fix light crashes for SimpleRenderer, fix depth pass for emissive sampling, clean, & comment all new code, then release.
…Fixed the way simple renderer should handle submitted graphics to solve crash. TODO: add depth buffer pass to fix emissive fragments. Document. Then submit
… tool will be needed to bake these values into one. also added metallic reflections which is cool.
…wn folder for re-use. Fix the segue bug for the custom renderer. Then we are done. :)
…lations. all is working well. TODO: move deferred shader code out into its own file. It is too specific for swoosh general shaders.
…nction `pendingChanges()` is useful to know from one thread when the stack is undergoing changes. Also added a way to cleanly and safely end all scenes and clear the stack in an expected way.
…l drawables as expected. This allows coders to submit any event data for rendering. Renderer can be returned directly. 2) Thenables (name pending) allow scenes to communicate why they returned. TODO: Rewind conceptually invalidates thenables. Also some scenes expect a response even if the scene they came from rewinds back to them. Should they also handle specific return data? What happens when we might have multiple reasons for returning to a scene?
… returned by pop() or rewind() actions! Well-tested in the demo. Currently dog-fooding.
…ialization. Provided new function to check system compatibility with a renderer to gaurantee it can be constructed safe and soundly. Added a new feature to Contexts and Yieldables that allow previous Activity return data from pop() to be shared via the new Activity's Context object. Added IntroScene to demonstrate this functionality. TODO: find a better name for yield() and retain() as I feel yield() could be a keyword problem and retain() isn't clear. TODO: doll the IntroScene for demo purposes.
…adopt(). pending_raii -> SpinWhileTrue. Cleaned up some other code. Built and tested.
…namespace symbols in the lib. renamed types:: -> ::arg for shorthand. Made sw::segue<T,D> template shorthand visible immediately under the sw:: namespace. PopResults -> PopDataHolder per request.
…roken up into a book or something at this rate. I compeltely glossed over RenderEntries and how the renderer works now.
…iveRenderEntry(). getCurrentRendererName -> just use getActiveRenderEntry() again followed by getName(). Fixed missed PushIn segue effect.
…s the many template forms needed to check the underlining data types. If a context is given a single std::optional<T> type, it will extract the value. If the value is nullopt, nothing happens. If the value is set, then the data is copied. If the user provides multiple values, they are packed into a std::tuple<> object. Similarly if the user tries to fetch the data, template type deduction will return a single type T& or std::tuple<Ts...>& depending on which the user is trying to read. Finally, as<T>() and is<T>() functions have been renamed to read<Ts...> and has<Ts...> respectively.
…Enter(), onResume(), or onStart(), a PopDataHandler will have its context resolved, carried from another via adoption, and then immediately executed. This way, activities can prep for the first lifecycle re-entry. This is not only convenient to reuse these lifecycle callbacks _after_ the PopDataHandler's context has been read, but will also open up new possibilities for programmers who can now change how the first frame is updated/rendered based on the read context data from the previous activity.
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.

1 participant