diff options
author | Jed Barber <jjbarber@y7mail.com> | 2018-03-01 19:45:21 +1100 |
---|---|---|
committer | Jed Barber <jjbarber@y7mail.com> | 2018-03-01 19:45:21 +1100 |
commit | 3bbd2259291b16ee5970865959d80960d70575ff (patch) | |
tree | d66d1684a07dbc52471d154a1d9a90cecdf4a898 /src/c_fl_clock.cpp | |
parent | 38e5d2200b48b86772d6921e1553bf76408e5809 (diff) |
Added FLTK.Widgets.Clocks.Updated
Diffstat (limited to 'src/c_fl_clock.cpp')
-rw-r--r-- | src/c_fl_clock.cpp | 70 |
1 files changed, 70 insertions, 0 deletions
diff --git a/src/c_fl_clock.cpp b/src/c_fl_clock.cpp new file mode 100644 index 0000000..89b19bc --- /dev/null +++ b/src/c_fl_clock.cpp @@ -0,0 +1,70 @@ + + +#include <FL/Fl_Clock.H> +#include "c_fl_clock.h" +#include "c_fl_type.h" + + + + +class My_Clock : public Fl_Clock { + public: + using Fl_Clock::Fl_Clock; + friend void clock_set_draw_hook(CLOCK c, void * d); + friend void fl_clock_draw(CLOCK c); + friend void clock_set_handle_hook(CLOCK c, void * h); + friend int fl_clock_handle(CLOCK c, int e); + protected: + void draw(); + void real_draw(); + int handle(int e); + int real_handle(int e); + d_hook_p draw_hook; + h_hook_p handle_hook; +}; + +void My_Clock::draw() { + (*draw_hook)(this->user_data()); +} + +void My_Clock::real_draw() { + Fl_Clock::draw(); +} + +int My_Clock::handle(int e) { + return (*handle_hook)(this->user_data(), e); +} + +int My_Clock::real_handle(int e) { + return Fl_Clock::handle(e); +} + +void clock_set_draw_hook(CLOCK c, void * d) { + reinterpret_cast<My_Clock*>(c)->draw_hook = reinterpret_cast<d_hook_p>(d); +} + +void fl_clock_draw(CLOCK c) { + reinterpret_cast<My_Clock*>(c)->real_draw(); +} + +void clock_set_handle_hook(CLOCK c, void * h) { + reinterpret_cast<My_Clock*>(c)->handle_hook = reinterpret_cast<h_hook_p>(h); +} + +int fl_clock_handle(CLOCK c, int e) { + return reinterpret_cast<My_Clock*>(c)->real_handle(e); +} + + + + +CLOCK new_fl_clock(int x, int y, int w, int h, char* label) { + My_Clock *c = new My_Clock(x, y, w, h, label); + return c; +} + +void free_fl_clock(CLOCK c) { + delete reinterpret_cast<My_Clock*>(c); +} + + |