diff --git a/CMake/macros.cmake b/CMake/macros.cmake index 56ab6ab69..0ab8c8742 100644 --- a/CMake/macros.cmake +++ b/CMake/macros.cmake @@ -168,6 +168,11 @@ macro(CREATE_EXAMPLE NAME SOURCES LIBRARIES) target_link_libraries(${tname} ${X11_Xrender_LIB}) endif(HAVE_XRENDER) + if (OPTION_APPLE_SDL) + target_link_libraries(${tname} ${SDL2_LIBRARY}) + endif(OPTION_APPLE_SDL) + + endmacro(CREATE_EXAMPLE NAME SOURCES LIBRARIES) ####################################################################### diff --git a/CMake/options.cmake b/CMake/options.cmake index cf86c6f2b..c69c9a38e 100644 --- a/CMake/options.cmake +++ b/CMake/options.cmake @@ -69,7 +69,7 @@ if (OPTION_APPLE_SDL) if (SDL2_FOUND) set(USE_SDL 1) set(FL_PORTING 1) - list(APPEND FLTK_LDLIBS SDL2_LIBRARIES) + list(APPEND FLTK_LDLIBS SDL2_LIBRARY) endif(SDL2_FOUND) endif(OPTION_APPLE_SDL) diff --git a/FL/Fl_Device.H b/FL/Fl_Device.H index 3a5e56699..8d847d6c7 100644 --- a/FL/Fl_Device.H +++ b/FL/Fl_Device.H @@ -72,7 +72,7 @@ public: return _surface ? _surface : default_surface(); }; /** \brief The destructor. */ - virtual ~Fl_Surface_Device() {} + virtual ~Fl_Surface_Device(); }; /** diff --git a/FL/Fl_Widget_Surface.H b/FL/Fl_Widget_Surface.H index 6f2df9b1c..95bcd4c4f 100644 --- a/FL/Fl_Widget_Surface.H +++ b/FL/Fl_Widget_Surface.H @@ -41,7 +41,7 @@ public: Each translate() call must be matched by an untranslate() call. Successive translate() calls add up their effects. */ - virtual void translate(int x, int y) {} + virtual void translate(int x, int y); /** Undoes the effect of a previous translate() call. */ diff --git a/FL/porting.H b/FL/porting.H index ec3029049..7b0830189 100644 --- a/FL/porting.H +++ b/FL/porting.H @@ -155,97 +155,6 @@ extern void fl_end_offscreen(); extern int fl_parse_color(const char* p, uchar& r, uchar& g, uchar& b); extern void fl_open_display(); -/* - - The following symbols are not found if we naively compile the core modules and - no specific platform implementations. This list is a hint at all the functions - and methods that probably need to be refactored into the driver system. - - Undefined symbols for architecture x86_64: - "fl_set_spot(int, int, int, int, int, int, Fl_Window*)", referenced from: - Fl_Input_::drawtext(int, int, int, int) in libfltkd.a(Fl_Input_.o) - Fl_Input_::handletext(int, int, int, int, int) in libfltkd.a(Fl_Input_.o) - "fl_reset_spot()", referenced from: - Fl_Input_::handletext(int, int, int, int, int) in libfltkd.a(Fl_Input_.o) - "fl_filename_name(char const*)", referenced from: - Fl_Window::show(int, char**) in libfltkd.a(Fl_arg.o) - "fl_clipboard_notify_change()", referenced from: - Fl::add_clipboard_notify(void (*)(int, void*), void*) in libfltkd.a(Fl.o) - Fl::remove_clipboard_notify(void (*)(int, void*)) in libfltkd.a(Fl.o) - "Fl_Screen_Driver::newScreenDriver()", referenced from: - Fl::screen_driver() in libfltkd.a(Fl.o) - "Fl_Graphics_Driver::newMainGraphicsDriver()", referenced from: - Fl_Display_Device::display_device() in libfltkd.a(Fl_Device.o) - "Fl_Graphics_Driver::global_gc()", referenced from: - Fl_Surface_Device::set_current() in libfltkd.a(Fl_Device.o) - "Fl::dnd()", referenced from: - Fl_Input::handle(int) in libfltkd.a(Fl_Input.o) - "Fl::copy(char const*, int, int, char const*)", referenced from: - Fl::selection(Fl_Widget&, char const*, int) in libfltkd.a(Fl.o) - Fl_Input_::copy(int) in libfltkd.a(Fl_Input_.o) - Fl_Input_::copy_cuts() in libfltkd.a(Fl_Input_.o) - "Fl::paste(Fl_Widget&, int, char const*)", referenced from: - Fl::paste(Fl_Widget&) in libfltkd.a(Fl.o) - Fl_Input::kf_paste() in libfltkd.a(Fl_Input.o) - Fl_Input::handle(int) in libfltkd.a(Fl_Input.o) - "Fl::get_mouse(int&, int&)", referenced from: - Fl_Screen_Driver::screen_xywh(int&, int&, int&, int&) in libfltkd.a(Fl_Screen_Driver.o) - Fl_Screen_Driver::screen_work_area(int&, int&, int&, int&) in libfltkd.a(Fl_Screen_Driver.o) - Fl_Window::hotspot(int, int, int) in libfltkd.a(Fl_Window_hotspot.o) - "Fl::set_color(unsigned int, unsigned int)", referenced from: - Fl::set_color(unsigned int, unsigned char, unsigned char, unsigned char) in libfltkd.a(fl_color.o) - Fl::background2(unsigned char, unsigned char, unsigned char) in libfltkd.a(Fl_get_system_colors.o) - "Fl_X::set_cursor(Fl_Cursor)", referenced from: - Fl_Window::cursor(Fl_Cursor) in libfltkd.a(fl_cursor.o) - "Fl_X::set_cursor(Fl_RGB_Image const*, int, int)", referenced from: - Fl_Window::cursor(Fl_RGB_Image const*, int, int) in libfltkd.a(fl_cursor.o) - "Fl_X::set_default_icons(Fl_RGB_Image const**, int)", referenced from: - Fl_Window::default_icons(Fl_RGB_Image const**, int) in libfltkd.a(Fl_Window.o) - "Fl_X::flush()", referenced from: - Fl::flush() in libfltkd.a(Fl.o) - "Fl_X::set_icons()", referenced from: - Fl_Window::icons(Fl_RGB_Image const**, int) in libfltkd.a(Fl_Window.o) - "Fl_Window::size_range_()", referenced from: - Fl_Window::size_range(int, int, int, int, int, int, int) in libfltkd.a(fl_ask.o) - "Fl_Window::fullscreen_x()", referenced from: - Fl_Window::fullscreen() in libfltkd.a(Fl_Window_fullscreen.o) - Fl_Window::fullscreen_screens(int, int, int, int) in libfltkd.a(Fl_Window_fullscreen.o) - "Fl_Window::make_current()", referenced from: - Fl_Window::flush() in libfltkd.a(Fl.o) - Fl_Double_Window::flush(int) in libfltkd.a(Fl_Double_Window.o) - traverse_to_gl_subwindows(Fl_Group*, unsigned char*, int, int, int, int, int, Fl_RGB_Image*) in libfltkd.a(fl_read_image.o) - Fl_Widget_Surface::print_window_part(Fl_Window*, int, int, int, int, int, int) in libfltkd.a(Fl_Widget_Surface.o) - "Fl_Window::fullscreen_off_x(int, int, int, int)", referenced from: - Fl_Window::fullscreen_off(int, int, int, int) in libfltkd.a(Fl_Window_fullscreen.o) - "Fl_Window::show()", referenced from: - vtable for Fl_Window in libfltkd.a(Fl_Window_shape.o) - Fl_Double_Window::show() in libfltkd.a(Fl_Double_Window.o) - Fl_Single_Window::show() in libfltkd.a(Fl_Single_Window.o) - "Fl_Window::label(char const*, char const*)", referenced from: - Fl_Window::label(char const*) in libfltkd.a(Fl_Window.o) - Fl_Window::copy_label(char const*) in libfltkd.a(Fl_Window.o) - Fl_Window::iconlabel(char const*) in libfltkd.a(Fl_Window.o) - "Fl_Window::resize(int, int, int, int)", referenced from: - vtable for Fl_TooltipBox in libfltkd.a(Fl_Tooltip.o) - vtable for Fl_Window in libfltkd.a(Fl_Window_shape.o) - vtable for Fl_Menu_Window in libfltkd.a(Fl_Menu_Window.o) - Fl_Double_Window::resize(int, int, int, int) in libfltkd.a(Fl_Double_Window.o) - vtable for menutitle in libfltkd.a(Fl_Menu.o) - vtable for menuwindow in libfltkd.a(Fl_Menu.o) - vtable for Fl_Single_Window in libfltkd.a(Fl_Single_Window.o) - ... - "Fl_Window::current_", referenced from: - Fl_Window::current() in libfltkd.a(Fl_Window.o) - "vtable for Fl_Image_Surface", referenced from: - Fl_Image_Surface::Fl_Image_Surface(int, int, int) in libfltkd.a(Fl_Image_Surface.o) - NOTE: a missing vtable usually means the first non-inline virtual member function has no definition. - "_fl_show_iconic", referenced from: - Fl::arg(int, char**, int&) in libfltkd.a(Fl_arg.o) - "_fl_window", referenced from: - fl_read_image(unsigned char*, int, int, int, int, int) in libfltkd.a(fl_read_image.o) - Fl_Image_Surface::set_current() in libfltkd.a(Fl_Image_Surface.o) - Fl_Image_Surface::end_current() in libfltkd.a(Fl_Image_Surface.o) -*/ // // End of "$Id$". diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt index de548cf13..b4a105db0 100644 --- a/src/CMakeLists.txt +++ b/src/CMakeLists.txt @@ -397,7 +397,7 @@ if(USE_X11) endif(USE_X11) if (USE_SDL) - target_link_libraries(fltk ${SDL2_LIBRARIES}) + target_link_libraries(fltk ${SDL2_LIBRARY}) endif(USE_SDL) if(WIN32) @@ -480,7 +480,7 @@ if(USE_X11) endif(USE_X11) if (USE_SDL) - target_link_libraries(fltk ${SDL2_LIBRARIES}) + target_link_libraries(fltk ${SDL2_LIBRARY}) endif(USE_SDL) if(WIN32) diff --git a/src/Fl_Device.cxx b/src/Fl_Device.cxx index 7a2b9bca5..e61d74346 100644 --- a/src/Fl_Device.cxx +++ b/src/Fl_Device.cxx @@ -63,6 +63,11 @@ void Fl_Surface_Device::set_current(void) Fl_Surface_Device* Fl_Surface_Device::_surface; // the current target surface of graphics operations +Fl_Surface_Device::~Fl_Surface_Device() +{ +} + + /** A constructor that sets the graphics driver used by the display */ Fl_Display_Device::Fl_Display_Device(Fl_Graphics_Driver *graphics_driver) : Fl_Surface_Device(graphics_driver) { this->set_current(); diff --git a/src/Fl_Widget_Surface.cxx b/src/Fl_Widget_Surface.cxx index 207205c25..8f792565f 100644 --- a/src/Fl_Widget_Surface.cxx +++ b/src/Fl_Widget_Surface.cxx @@ -107,6 +107,10 @@ void Fl_Widget_Surface::traverse(Fl_Widget *widget) } } +void Fl_Widget_Surface::translate(int x, int y) +{ +} + /** @brief Computes the page coordinates of the current origin of graphics functions. * diff --git a/src/drivers/Pico/Fl_Pico_Screen_Driver.H b/src/drivers/Pico/Fl_Pico_Screen_Driver.H index 8b1378917..5bd177361 100644 --- a/src/drivers/Pico/Fl_Pico_Screen_Driver.H +++ b/src/drivers/Pico/Fl_Pico_Screen_Driver.H @@ -1 +1,65 @@ +// +// "$Id: Fl_Pico_Screen_Driver.H 11017 2016-01-20 21:40:12Z matt $" +// +// Definition of Pico Screen interface +// for the Fast Light Tool Kit (FLTK). +// +// Copyright 2010-2016 by Bill Spitzak and others. +// +// This library is free software. Distribution and use rights are outlined in +// the file "COPYING" which should have been included with this file. If this +// file is missing or damaged, see the license at: +// +// http://www.fltk.org/COPYING.php +// +// Please report all bugs and problems on the following page: +// +// http://www.fltk.org/str.php +// +/** + \file Fl_Pico_Screen_Driver.H + \brief Definition of Pico Screen interface. + */ + +#ifndef FL_PICO_SCREEN_DRIVER_H +#define FL_PICO_SCREEN_DRIVER_H + +#include + + +class FL_EXPORT Fl_Pico_Screen_Driver : public Fl_Screen_Driver +{ +public: + Fl_Pico_Screen_Driver(); + virtual ~Fl_Pico_Screen_Driver(); + virtual void init(); + virtual int x(); + virtual int y(); + virtual int w(); + virtual int h(); + virtual void screen_xywh(int &X, int &Y, int &W, int &H, int n); + virtual void screen_dpi(float &h, float &v, int n=0); + virtual void screen_work_area(int &X, int &Y, int &W, int &H, int n); + // --- audible output + virtual void beep(int type); + // --- global events + virtual void flush(); + virtual int ready(); + virtual void grab(Fl_Window* win); + // --- global colors + virtual int parse_color(const char* p, uchar& r, uchar& g, uchar& b); + virtual void get_system_colors(); + // --- global timers + virtual void add_timeout(double time, Fl_Timeout_Handler cb, void *argp); + virtual void repeat_timeout(double time, Fl_Timeout_Handler cb, void *argp); + virtual int has_timeout(Fl_Timeout_Handler cb, void *argp); + virtual void remove_timeout(Fl_Timeout_Handler cb, void *argp); +}; + + +#endif // FL_PICO_SCREEN_DRIVER_H + +// +// End of "$Id: Fl_Pico_Screen_Driver.H 11017 2016-01-20 21:40:12Z matt $". +// diff --git a/src/drivers/Pico/Fl_Pico_Screen_Driver.cxx b/src/drivers/Pico/Fl_Pico_Screen_Driver.cxx index 8b1378917..463ff688a 100644 --- a/src/drivers/Pico/Fl_Pico_Screen_Driver.cxx +++ b/src/drivers/Pico/Fl_Pico_Screen_Driver.cxx @@ -1 +1,144 @@ +// +// "$Id: Fl_Pico_Screen_Driver.cxx 11253 2016-03-01 00:54:21Z matt $" +// +// Definition of SDL Screen interface based on Pico +// +// Copyright 1998-2016 by Bill Spitzak and others. +// +// This library is free software. Distribution and use rights are outlined in +// the file "COPYING" which should have been included with this file. If this +// file is missing or damaged, see the license at: +// +// http://www.fltk.org/COPYING.php +// +// Please report all bugs and problems on the following page: +// +// http://www.fltk.org/str.php +// + +#include "../../config_lib.h" +#include "Fl_Pico_Screen_Driver.H" + + +Fl_Pico_Screen_Driver::Fl_Pico_Screen_Driver() +{ +} + + +Fl_Pico_Screen_Driver::~Fl_Pico_Screen_Driver() +{ +} + + +void Fl_Pico_Screen_Driver::init() +{ + // nothing to do yet +} + + +int Fl_Pico_Screen_Driver::x() +{ + return 0; +} + + +int Fl_Pico_Screen_Driver::y() +{ + return 0; +} + + +int Fl_Pico_Screen_Driver::w() +{ + return 800; +} + + +int Fl_Pico_Screen_Driver::h() +{ + return 600; +} + + +void Fl_Pico_Screen_Driver::screen_xywh(int &X, int &Y, int &W, int &H, int n) +{ + X = x(); + Y = y(); + W = w(); + H = h(); +} + + +void Fl_Pico_Screen_Driver::screen_dpi(float &h, float &v, int n) +{ + h = 75.0; + v = 75.0; +} + + +void Fl_Pico_Screen_Driver::screen_work_area(int &X, int &Y, int &W, int &H, int n) +{ + X = x(); + Y = y(); + W = w(); + H = h(); +} + + +void Fl_Pico_Screen_Driver::beep(int type) +{ +} + + +void Fl_Pico_Screen_Driver::flush() +{ +} + + +int Fl_Pico_Screen_Driver::ready() +{ + return 1; +} + + +void Fl_Pico_Screen_Driver::grab(Fl_Window* win) +{ +} + + +int Fl_Pico_Screen_Driver::parse_color(const char* p, uchar& r, uchar& g, uchar& b) +{ + return 0; +} + + +void Fl_Pico_Screen_Driver::get_system_colors() +{ +} + + +void Fl_Pico_Screen_Driver::add_timeout(double time, Fl_Timeout_Handler cb, void *argp) +{ +} + + +void Fl_Pico_Screen_Driver::repeat_timeout(double time, Fl_Timeout_Handler cb, void *argp) +{ +} + + +int Fl_Pico_Screen_Driver::has_timeout(Fl_Timeout_Handler cb, void *argp) +{ + return 0; +} + + +void Fl_Pico_Screen_Driver::remove_timeout(Fl_Timeout_Handler cb, void *argp) +{ +} + + +// +// End of "$Id: Fl_Pico_Screen_Driver.cxx 11253 2016-03-01 00:54:21Z matt $". +// \ No newline at end of file diff --git a/src/drivers/Pico/Fl_Pico_Window_Driver.H b/src/drivers/Pico/Fl_Pico_Window_Driver.H index 8b1378917..14cf08b5c 100644 --- a/src/drivers/Pico/Fl_Pico_Window_Driver.H +++ b/src/drivers/Pico/Fl_Pico_Window_Driver.H @@ -1 +1,43 @@ +// +// "$Id: Fl_Pico_Window_Driver.H 11017 2016-01-20 21:40:12Z matt $" +// +// Definition of Pico Window interface +// for the Fast Light Tool Kit (FLTK). +// +// Copyright 2010-2016 by Bill Spitzak and others. +// +// This library is free software. Distribution and use rights are outlined in +// the file "COPYING" which should have been included with this file. If this +// file is missing or damaged, see the license at: +// +// http://www.fltk.org/COPYING.php +// +// Please report all bugs and problems on the following page: +// +// http://www.fltk.org/str.php +// +/** + \file Fl_Pico_Window_Driver.H + \brief Definition of Pico Window interface. + */ + +#ifndef FL_PICO_WINDOW_DRIVER_H +#define FL_PICO_WINDOW_DRIVER_H + +#include + + +class FL_EXPORT Fl_Pico_Window_Driver : public Fl_Window_Driver +{ +public: + Fl_Pico_Window_Driver(Fl_Window *win); + virtual ~Fl_Pico_Window_Driver(); +}; + + +#endif // FL_PICO_WINDOW_DRIVER_H + +// +// End of "$Id: Fl_Pico_Window_Driver.H 11017 2016-01-20 21:40:12Z matt $". +// diff --git a/src/drivers/Pico/Fl_Pico_Window_Driver.cxx b/src/drivers/Pico/Fl_Pico_Window_Driver.cxx index 8b1378917..d729083fa 100644 --- a/src/drivers/Pico/Fl_Pico_Window_Driver.cxx +++ b/src/drivers/Pico/Fl_Pico_Window_Driver.cxx @@ -1 +1,37 @@ +// +// "$Id: Fl_Pico_Window_Driver.cxx 11253 2016-03-01 00:54:21Z matt $" +// +// Definition of SDL Window interface based on Pico +// +// Copyright 1998-2016 by Bill Spitzak and others. +// +// This library is free software. Distribution and use rights are outlined in +// the file "COPYING" which should have been included with this file. If this +// file is missing or damaged, see the license at: +// +// http://www.fltk.org/COPYING.php +// +// Please report all bugs and problems on the following page: +// +// http://www.fltk.org/str.php +// + +#include "../../config_lib.h" +#include "Fl_Pico_Window_Driver.H" + + +Fl_Pico_Window_Driver::Fl_Pico_Window_Driver(Fl_Window *win) +: Fl_Window_Driver(win) +{ +} + + +Fl_Pico_Window_Driver::~Fl_Pico_Window_Driver() +{ +} + + +// +// End of "$Id: Fl_Pico_Window_Driver.cxx 11253 2016-03-01 00:54:21Z matt $". +// \ No newline at end of file diff --git a/src/drivers/SDL/Fl_SDL_Screen_Driver.H b/src/drivers/SDL/Fl_SDL_Screen_Driver.H index 8b1378917..ef2c3b1da 100644 --- a/src/drivers/SDL/Fl_SDL_Screen_Driver.H +++ b/src/drivers/SDL/Fl_SDL_Screen_Driver.H @@ -1 +1,44 @@ +// +// "$Id: Fl_SDL_Screen_Driver.H 11017 2016-01-20 21:40:12Z matt $" +// +// Definition of SDL Screen interface based on Pico +// for the Fast Light Tool Kit (FLTK). +// +// Copyright 2010-2016 by Bill Spitzak and others. +// +// This library is free software. Distribution and use rights are outlined in +// the file "COPYING" which should have been included with this file. If this +// file is missing or damaged, see the license at: +// +// http://www.fltk.org/COPYING.php +// +// Please report all bugs and problems on the following page: +// +// http://www.fltk.org/str.php +// +/** + \file Fl_SDL_Screen_Driver.H + \brief Definition of SDL Screen interface based on Pico. + */ + +#ifndef FL_SDL_SCREEN_DRIVER_H +#define FL_SDL_SCREEN_DRIVER_H + +#include "../Pico/Fl_Pico_Screen_Driver.H" + + +class FL_EXPORT Fl_SDL_Screen_Driver : public Fl_Pico_Screen_Driver +{ +public: + Fl_SDL_Screen_Driver(); + virtual ~Fl_SDL_Screen_Driver(); + virtual double wait(double time_to_wait); +}; + + +#endif // FL_SDL_SCREEN_DRIVER_H + +// +// End of "$Id: quartz.H 11017 2016-01-20 21:40:12Z matt $". +// diff --git a/src/drivers/SDL/Fl_SDL_Screen_Driver.cxx b/src/drivers/SDL/Fl_SDL_Screen_Driver.cxx index 8b1378917..feed9458e 100644 --- a/src/drivers/SDL/Fl_SDL_Screen_Driver.cxx +++ b/src/drivers/SDL/Fl_SDL_Screen_Driver.cxx @@ -1 +1,196 @@ +// +// "$Id: Fl_SDL_Screen_Driver.cxx 11253 2016-03-01 00:54:21Z matt $" +// +// Definition of SDL Screen interface based on Pico +// +// Copyright 1998-2016 by Bill Spitzak and others. +// +// This library is free software. Distribution and use rights are outlined in +// the file "COPYING" which should have been included with this file. If this +// file is missing or damaged, see the license at: +// +// http://www.fltk.org/COPYING.php +// +// Please report all bugs and problems on the following page: +// +// http://www.fltk.org/str.php +// + + +#include "../../config_lib.h" +#include "Fl_SDL_Screen_Driver.H" + +#include + +#define __APPLE__ +#include +#undef __APPLE__ + + +Fl_Screen_Driver* Fl_Screen_Driver::newScreenDriver() +{ + return new Fl_SDL_Screen_Driver(); +} + + +Fl_SDL_Screen_Driver::Fl_SDL_Screen_Driver() +{ +} + +Fl_SDL_Screen_Driver::~Fl_SDL_Screen_Driver() +{ +} + + +double Fl_SDL_Screen_Driver::wait(double time_to_wait) +{ + SDL_Event e; + if (SDL_PollEvent(&e)) { + if (e.type == SDL_QUIT) { + exit(0); + // TODO: do something + } + } + return 0.0; +} + + + +#include +#include +#include +#include +#include + +/* + * The following code should not be here! + * All this must be refactored into the driver system! + */ + +/* + + The following symbols are not found if we naively compile the core modules and + no specific platform implementations. This list is a hint at all the functions + and methods that probably need to be refactored into the driver system. + + Undefined symbols for architecture x86_64: + */ + +void fl_set_spot(int, int, int, int, int, int, Fl_Window*) { } +void fl_reset_spot() { } +const char *fl_filename_name(char const*) { return 0; } +void fl_clipboard_notify_change() { } + +//Fl_Screen_Driver *Fl_Screen_Driver::newScreenDriver() { return 0; } +Fl_Graphics_Driver *Fl_Graphics_Driver::newMainGraphicsDriver() { return 0; } +void Fl_Graphics_Driver::global_gc() { } +int Fl::dnd() { return 0; } +void Fl::copy(char const*, int, int, char const*) { } +void Fl::paste(Fl_Widget&, int, char const*) { } +void Fl::get_mouse(int&, int&) { } +void Fl::set_color(unsigned int, unsigned int) { } +int Fl_X::set_cursor(Fl_Cursor) { return 0; } +int Fl_X::set_cursor(Fl_RGB_Image const*, int, int) { return 0; } +void Fl_X::set_default_icons(Fl_RGB_Image const**, int) { } +void Fl_X::flush() { } +void Fl_X::set_icons() { } +void Fl_Window::size_range_() { } +void Fl_Window::fullscreen_x() { } +void Fl_Window::make_current() { } +void Fl_Window::fullscreen_off_x(int, int, int, int) { } + +Window fl_xid(const Fl_Window* w) +{ + Fl_X *temp = Fl_X::i(w); + return temp ? temp->xid : 0; +} + +void Fl_Window::show() { + if (!shown()) { + Fl_X::make(this); + } +} + +Fl_X* Fl_X::make(Fl_Window *w) +{ + Fl_Group::current(0); + if (w->parent() && !Fl_X::i(w->window())) { + w->set_visible(); + return 0L; + } + Window parent; + if (w->parent()) { + parent = fl_xid(w->window()); + } else { + parent = 0; + } + Fl_Window_Driver *x = Fl_Window_Driver::newWindowDriver(w); + x->other_xid = 0; + x->w = w; + x->region = 0; + if (!w->force_position()) { + x->xid = SDL_CreateWindow(w->label(), w->x(), w->y(), w->w(), w->h(), 0); + } else { + x->xid = SDL_CreateWindow(w->label(), 100, 100, w->w(), w->h(), 0); + } + x->next = Fl_X::first; + Fl_X::first = x; + return x; +} + +void Fl_Window::label(char const*, char const*) { } +void Fl_Window::resize(int, int, int, int) { } +Fl_Window *Fl_Window::current_; +char fl_show_iconic; +Window fl_window; +void Fl_Image_Surface::translate(int x, int y) { } +void Fl_Image_Surface::untranslate() { } + +/* + #define __APPLE__ + #include + #undef __APPLE__ + + SDL_Window *win = NULL; + SDL_Renderer *renderer = NULL; + SDL_Texture *bitmapTex = NULL; + SDL_Surface *bitmapSurface = NULL; + int posX = 100, posY = 100, width = 320, height = 240; + + SDL_Init(SDL_INIT_VIDEO); + + win = SDL_CreateWindow("Hello World", posX, posY, width, height, 0); + + renderer = SDL_CreateRenderer(win, -1, SDL_RENDERER_ACCELERATED); + + bitmapSurface = SDL_LoadBMP("img/hello.bmp"); + bitmapTex = SDL_CreateTextureFromSurface(renderer, bitmapSurface); + SDL_FreeSurface(bitmapSurface); + + while (1) { + SDL_Event e; + if (SDL_PollEvent(&e)) { + if (e.type == SDL_QUIT) { + break; + } + } + + SDL_RenderClear(renderer); + SDL_RenderCopy(renderer, bitmapTex, NULL, NULL); + SDL_RenderPresent(renderer); + } + + SDL_DestroyTexture(bitmapTex); + SDL_DestroyRenderer(renderer); + SDL_DestroyWindow(win); + + SDL_Quit(); + + return 0; +*/ + + +// +// End of "$Id: Fl_SDL_Screen_Driver.cxx 11253 2016-03-01 00:54:21Z matt $". +// diff --git a/src/drivers/SDL/Fl_SDL_Window_Driver.H b/src/drivers/SDL/Fl_SDL_Window_Driver.H index 8b1378917..740616a64 100644 --- a/src/drivers/SDL/Fl_SDL_Window_Driver.H +++ b/src/drivers/SDL/Fl_SDL_Window_Driver.H @@ -1 +1,43 @@ +// +// "$Id: Fl_SDL_Window_Driver.H 11017 2016-01-20 21:40:12Z matt $" +// +// Definition of SDL Window interface +// for the Fast Light Tool Kit (FLTK). +// +// Copyright 2010-2016 by Bill Spitzak and others. +// +// This library is free software. Distribution and use rights are outlined in +// the file "COPYING" which should have been included with this file. If this +// file is missing or damaged, see the license at: +// +// http://www.fltk.org/COPYING.php +// +// Please report all bugs and problems on the following page: +// +// http://www.fltk.org/str.php +// +/** + \file Fl_SDL_Window_Driver.H + \brief Definition of SDL Window interface. + */ + +#ifndef FL_SDL_WINDOW_DRIVER_H +#define FL_SDL_WINDOW_DRIVER_H + +#include "../Pico/Fl_Pico_Window_Driver.H" + + +class FL_EXPORT Fl_SDL_Window_Driver : public Fl_Pico_Window_Driver +{ +public: + Fl_SDL_Window_Driver(Fl_Window *win); + virtual ~Fl_SDL_Window_Driver(); +}; + + +#endif // FL_SDL_WINDOW_DRIVER_H + +// +// End of "$Id: Fl_SDL_Window_Driver.H 11017 2016-01-20 21:40:12Z matt $". +// diff --git a/src/drivers/SDL/Fl_SDL_Window_Driver.cxx b/src/drivers/SDL/Fl_SDL_Window_Driver.cxx index 8b1378917..b251ad2c2 100644 --- a/src/drivers/SDL/Fl_SDL_Window_Driver.cxx +++ b/src/drivers/SDL/Fl_SDL_Window_Driver.cxx @@ -1 +1,43 @@ +// +// "$Id: Fl_SDL_Window_Driver.cxx 11253 2016-03-01 00:54:21Z matt $" +// +// Definition of SDL Window interface based on SDL +// +// Copyright 1998-2016 by Bill Spitzak and others. +// +// This library is free software. Distribution and use rights are outlined in +// the file "COPYING" which should have been included with this file. If this +// file is missing or damaged, see the license at: +// +// http://www.fltk.org/COPYING.php +// +// Please report all bugs and problems on the following page: +// +// http://www.fltk.org/str.php +// + +#include "../../config_lib.h" +#include "Fl_SDL_Window_Driver.H" + + +Fl_Window_Driver *Fl_Window_Driver::newWindowDriver(Fl_Window *win) +{ + return new Fl_SDL_Window_Driver(win); +} + + +Fl_SDL_Window_Driver::Fl_SDL_Window_Driver(Fl_Window *win) +: Fl_Pico_Window_Driver(win) +{ +} + + +Fl_SDL_Window_Driver::~Fl_SDL_Window_Driver() +{ +} + + +// +// End of "$Id: Fl_SDL_Window_Driver.cxx 11253 2016-03-01 00:54:21Z matt $". +// \ No newline at end of file diff --git a/test/hello.cxx b/test/hello.cxx index ac1565996..76d8c2c2c 100644 --- a/test/hello.cxx +++ b/test/hello.cxx @@ -20,7 +20,11 @@ #include #include + +#include + int main(int argc, char **argv) { + Fl_Window *window = new Fl_Window(340,180); Fl_Box *box = new Fl_Box(20,40,300,100,"Hello, World!"); box->box(FL_UP_BOX);