mirror of
https://git.planet-casio.com/Lephenixnoir/fxsdk.git
synced 2025-01-01 14:33:35 +01:00
9d30377d90
This commit rewrites the entire device management layer of fxlink on the libusb side, providing new abstractions that support live/async device management, including communication. This system is put to use in a new TUI interactive mode (fxlink -t) which can run in the background, connects to calculators automatically without interfering with file transfer tools, and is much more detailed in its interface than the previous interactive mode (fxlink -i). The TUI mode will also soon be extended to support sending data.
98 lines
2.5 KiB
C
98 lines
2.5 KiB
C
//---------------------------------------------------------------------------//
|
|
// ==>/[_]\ fxlink: A community communication tool for CASIO calculators. //
|
|
// |:::| Made by Lephe' as part of the fxSDK. //
|
|
// \___/ License: MIT <https://opensource.org/licenses/MIT> //
|
|
//---------------------------------------------------------------------------//
|
|
|
|
#include <fxlink/tooling/sdl2.h>
|
|
#include <fxlink/logging.h>
|
|
|
|
#ifdef FXLINK_DISABLE_SDL2
|
|
|
|
void fxlink_sdl2_display_raw(struct fxlink_message_image_raw const *raw)
|
|
{
|
|
log_("SDL2 disabled at compiled-time, skipping frame");
|
|
}
|
|
|
|
void fxlink_sdl2_handle_events(void)
|
|
{
|
|
}
|
|
|
|
#else /* FXLINK_DISABLE_SDL2 */
|
|
|
|
static SDL_Window *window = NULL;
|
|
|
|
static int init(size_t width, size_t height)
|
|
{
|
|
if(!SDL_WasInit(SDL_INIT_VIDEO)) {
|
|
int rc = SDL_Init(SDL_INIT_VIDEO);
|
|
if(rc < 0)
|
|
return elog("cannot initialize SDL: %s\n", SDL_GetError());
|
|
}
|
|
|
|
window = SDL_CreateWindow("fxlink", SDL_WINDOWPOS_CENTERED,
|
|
SDL_WINDOWPOS_CENTERED, width, height, 0);
|
|
return 0;
|
|
}
|
|
|
|
__attribute__((destructor))
|
|
static void quit(void)
|
|
{
|
|
if(!window)
|
|
return;
|
|
SDL_DestroyWindow(window);
|
|
window = NULL;
|
|
}
|
|
|
|
/* Generate an RGB888 surface from image data. */
|
|
static SDL_Surface *surface_for_image(uint8_t **RGB888_rows, int width,
|
|
int height)
|
|
{
|
|
/* Little endian setup for RGB */
|
|
SDL_Surface *s = SDL_CreateRGBSurface(0, width, height, 24,
|
|
0x000000ff, 0x0000ff00, 0x0000ff00, 0);
|
|
if(!s) {
|
|
elog("cannot create surface for image\n");
|
|
return NULL;
|
|
}
|
|
|
|
for(int i = 0; i < height; i++)
|
|
memcpy(s->pixels + i * s->pitch, RGB888_rows[i], width * 3);
|
|
|
|
return s;
|
|
}
|
|
|
|
void fxlink_sdl2_display_raw(struct fxlink_message_image_raw const *raw)
|
|
{
|
|
if(!window && init(raw->width, raw->height))
|
|
return;
|
|
|
|
int current_w, current_h;
|
|
SDL_GetWindowSize(window, ¤t_w, ¤t_h);
|
|
if(current_w != raw->width || current_h != raw->height)
|
|
SDL_SetWindowSize(window, raw->width, raw->height);
|
|
|
|
SDL_Surface *src = surface_for_image(raw->data, raw->width, raw->height);
|
|
if(!src)
|
|
return;
|
|
|
|
SDL_Surface *dst = SDL_GetWindowSurface(window);
|
|
SDL_BlitSurface(src, NULL, dst, NULL);
|
|
SDL_FreeSurface(src);
|
|
|
|
SDL_UpdateWindowSurface(window);
|
|
}
|
|
|
|
void fxlink_sdl2_handle_events(void)
|
|
{
|
|
if(!window)
|
|
return;
|
|
|
|
SDL_Event e;
|
|
while(SDL_PollEvent(&e)) {
|
|
if(e.type == SDL_QUIT)
|
|
quit();
|
|
}
|
|
}
|
|
|
|
#endif /* FXLINK_DISABLE_SDL2 */
|