mirror of
https://github.com/TomHarte/CLK.git
synced 2025-01-11 08:30:55 +00:00
Simplified further: eliminated delegate. Which means I can go frame-free internally to the CRT at some point, if I want.
This commit is contained in:
parent
19393390ac
commit
09e11469c3
@ -137,38 +137,11 @@ class CRT {
|
||||
uint8_t *get_write_target_for_buffer(int buffer);
|
||||
|
||||
// MARK: Binding
|
||||
class Delegate {
|
||||
public:
|
||||
/*! Notifies the delegate that a new frame is complete, providing an ID for it.
|
||||
|
||||
The delegate then owns that frame. It can draw it by issuing an @c draw_frame
|
||||
call to the CRT. It should call @c return_frame to return the oldest frame it
|
||||
is currently holding.
|
||||
|
||||
@param crt The CRT that produced the new frame.
|
||||
@param frame_id An identifier for the finished frame, used for calls to @c draw_frame.
|
||||
@param did_detect_vsync @c true if this frame ended due to a vsync signal detected in
|
||||
the incoming signal; @c false otherwise.
|
||||
/*! Causes appropriate OpenGL or OpenGL ES calls to be issued in order to draw the current CRT state.
|
||||
The caller is responsible for ensuring that a valid OpenGL context exists for the duration of this call.
|
||||
*/
|
||||
virtual void crt_did_end_frame(CRT *crt, int frame_id, bool did_detect_vsync) = 0;
|
||||
};
|
||||
|
||||
/*! Sets the CRT frame delegate. The delegate will be notified as frames are completed; it is
|
||||
responsible for requesting that they be drawn and returning them when they are no longer needed.
|
||||
|
||||
@param delegate The delegate.
|
||||
*/
|
||||
void set_delegate(std::weak_ptr<Delegate> delegate);
|
||||
|
||||
/*! Causes appropriate OpenGL or OpenGL ES calls to be made in order to draw a frame. The caller
|
||||
is responsible for ensuring that a valid OpenGL context exists for the duration of this call.
|
||||
|
||||
@param frame_id The frame to draw.
|
||||
*/
|
||||
void draw_frame(int frame_id);
|
||||
|
||||
/*! Indicates that the delegate has no further interest in the oldest frame posted to it. */
|
||||
void return_frame();
|
||||
void draw_frame();
|
||||
|
||||
/*! Tells the CRT that the next call to draw_frame will occur on a different OpenGL context than
|
||||
the previous.
|
||||
|
Loading…
x
Reference in New Issue
Block a user