add SDL frontend for framebuffer port
svn path=/trunk/netsurf/; revision=6415
This commit is contained in:
parent
b3bc3eb896
commit
2b41eceafe
20
Makefile
20
Makefile
|
@ -515,6 +515,26 @@ ifeq ($(TARGET),framebuffer)
|
|||
LDFLAGS += $(shell $(PKG_CONFIG) --libs libxml-2.0 libcurl openssl)
|
||||
SUBTARGET := -dummy
|
||||
endif
|
||||
|
||||
ifeq ($(NETSURF_FB_FRONTEND),sdl)
|
||||
$(eval $(call pkg_config_find_and_add,RSVG,librsvg-2.0,SVG rendering))
|
||||
$(eval $(call pkg_config_find_and_add,ROSPRITE,librosprite,RISC OS sprite rendering))
|
||||
$(eval $(call pkg_config_find_and_add,HUBBUB,libhubbub,Hubbub HTML parser))
|
||||
$(eval $(call pkg_config_find_and_add,BMP,libnsbmp,NetSurf BMP decoder))
|
||||
$(eval $(call pkg_config_find_and_add,GIF,libnsgif,NetSurf GIF decoder))
|
||||
# $(eval $(call pkg_config_find_and_add,SDL,libSDL,SDL Library))
|
||||
|
||||
|
||||
CFLAGS += -std=c99 -g -I. $(WARNFLAGS) \
|
||||
$(shell xml2-config --cflags) \
|
||||
-D_BSD_SOURCE \
|
||||
-D_XOPEN_SOURCE=600 \
|
||||
-D_POSIX_C_SOURCE=200112L
|
||||
|
||||
LDFLAGS += -lxml2 -lz -ljpeg -lcurl -lm -lSDL
|
||||
LDFLAGS += $(shell $(PKG_CONFIG) --libs libxml-2.0 libcurl openssl)
|
||||
SUBTARGET := -sdl
|
||||
endif
|
||||
endif
|
||||
|
||||
# ----------------------------------------------------------------------------
|
||||
|
|
|
@ -213,10 +213,12 @@ ifeq ($(TARGET),framebuffer)
|
|||
NETSURF_FB_RESPATH_linux := /usr/share/netsurf/
|
||||
NETSURF_FB_RESPATH_able := (tftpboot)/
|
||||
NETSURF_FB_RESPATH_dummy := ./
|
||||
NETSURF_FB_RESPATH_sdl := ./
|
||||
|
||||
NETSURF_FB_HOMEPATH_linux := ~/.netsurf/
|
||||
NETSURF_FB_HOMEPATH_able := (tftpboot)/
|
||||
NETSURF_FB_HOMEPATH_dummy := ./
|
||||
NETSURF_FB_HOMEPATH_sdl := ~/.netsurf/
|
||||
|
||||
endif
|
||||
|
||||
|
|
|
@ -111,6 +111,9 @@ endif
|
|||
ifeq ($(NETSURF_FB_FRONTEND),dummy)
|
||||
S_FRAMEBUFFER += fb_frontend_dummy.c
|
||||
endif
|
||||
ifeq ($(NETSURF_FB_FRONTEND),sdl)
|
||||
S_FRAMEBUFFER += fb_frontend_sdl.c
|
||||
endif
|
||||
|
||||
S_FRAMEBUFFER := $(addprefix framebuffer/,$(S_FRAMEBUFFER))
|
||||
|
||||
|
|
|
@ -23,5 +23,6 @@ extern framebuffer_t *fb_os_init(int argc, char** argv);
|
|||
extern void fb_os_quit(framebuffer_t *fb);
|
||||
extern void fb_os_input(struct gui_window *g);
|
||||
extern void fb_os_option_override(void);
|
||||
extern void fb_os_redraw(struct gui_window *g, struct bbox_s *box);
|
||||
|
||||
#endif /* NETSURF_FB_FRONTEND_H */
|
||||
|
|
|
@ -0,0 +1,119 @@
|
|||
/*
|
||||
* Copyright 2008 Vincent Sanders <vince@simtec.co.uk>
|
||||
*
|
||||
* This file is part of NetSurf, http://www.netsurf-browser.org/
|
||||
*
|
||||
* NetSurf is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
* the Free Software Foundation; version 2 of the License.
|
||||
*
|
||||
* NetSurf is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#include <sys/types.h>
|
||||
#include <sys/stat.h>
|
||||
#include <fcntl.h>
|
||||
#include <sys/ioctl.h>
|
||||
#include <unistd.h>
|
||||
#include <string.h>
|
||||
|
||||
#include <SDL/SDL.h>
|
||||
|
||||
#include "css/css.h"
|
||||
#include "desktop/options.h"
|
||||
#include "desktop/gui.h"
|
||||
#include "desktop/options.h"
|
||||
#include "utils/messages.h"
|
||||
|
||||
#include "framebuffer/fb_gui.h"
|
||||
#include "framebuffer/fb_plotters.h"
|
||||
#include "framebuffer/fb_frontend.h"
|
||||
|
||||
#include "utils/log.h"
|
||||
|
||||
#define FILE_PFX "/home/vince/netsurf/netsurf/framebuffer/res/"
|
||||
|
||||
static SDL_Surface *sdl_screen;
|
||||
|
||||
framebuffer_t *fb_os_init(int argc, char** argv)
|
||||
{
|
||||
framebuffer_t *newfb;
|
||||
|
||||
newfb = calloc(1, sizeof(framebuffer_t));
|
||||
if (newfb == NULL)
|
||||
return NULL;
|
||||
|
||||
if ( SDL_Init(SDL_INIT_VIDEO) < 0 ) {
|
||||
fprintf(stderr, "Unable to init SDL: %s\n", SDL_GetError());
|
||||
return NULL;
|
||||
}
|
||||
atexit(SDL_Quit);
|
||||
|
||||
newfb->width = 800;
|
||||
newfb->height = 600;
|
||||
newfb->bpp = 16;
|
||||
|
||||
sdl_screen = SDL_SetVideoMode(newfb->width,
|
||||
newfb->height,
|
||||
newfb->bpp,
|
||||
SDL_SWSURFACE);
|
||||
|
||||
if ( sdl_screen == NULL ) {
|
||||
fprintf(stderr,
|
||||
"Unable to set video: %s\n", SDL_GetError());
|
||||
free(newfb);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
newfb->ptr = sdl_screen->pixels;
|
||||
newfb->linelen = sdl_screen->pitch;
|
||||
|
||||
return newfb;
|
||||
}
|
||||
|
||||
void fb_os_quit(framebuffer_t *fb)
|
||||
{
|
||||
free(fb->ptr);
|
||||
}
|
||||
|
||||
void fb_os_input(struct gui_window *g)
|
||||
{
|
||||
SDL_Event event;
|
||||
|
||||
SDL_PollEvent(&event);//SDL_WaitEvent(&event);
|
||||
|
||||
switch (event.type) {
|
||||
case SDL_KEYDOWN:
|
||||
printf("The %s key was pressed!\n",
|
||||
SDL_GetKeyName(event.key.keysym.sym));
|
||||
break;
|
||||
|
||||
case SDL_QUIT:
|
||||
browser_window_destroy(g->bw);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
void
|
||||
fb_os_option_override(void)
|
||||
{
|
||||
}
|
||||
|
||||
void
|
||||
fb_os_redraw(struct gui_window *g, struct bbox_s *box)
|
||||
{
|
||||
SDL_UpdateRect(sdl_screen, box->x0, box->y0, box->x1, box->y1);
|
||||
}
|
||||
|
||||
/*
|
||||
* Local Variables:
|
||||
* c-basic-offset:8
|
||||
* End:
|
||||
*/
|
||||
|
|
@ -125,6 +125,8 @@ static void fb_redraw(struct gui_window *g)
|
|||
g->redraw_box.x0, g->redraw_box.y0, g->redraw_box.x1, g->redraw_box.y1,
|
||||
g->bw->scale, 0xFFFFFF);
|
||||
|
||||
fb_os_redraw(g, &g->redraw_box);
|
||||
|
||||
g->redraw_required = false;
|
||||
g->redraw_box.y0 = g->redraw_box.x0 = INT_MAX;
|
||||
g->redraw_box.y1 = g->redraw_box.x1 = -(INT_MAX);
|
||||
|
|
Loading…
Reference in New Issue