File:  [RetroPC.NET] / np2 / x11 / gtk2 / window_softkbd.c
Revision 1.5: download - view: text, annotated - select for diffs
Sun Jan 16 03:43:14 2011 JST (14 years, 9 months ago) by monaka
Branches: MAIN
CVS tags: HEAD
remove CVS Id.

#include "compiler.h"

#if defined(SUPPORT_SOFTKBD)

#include "np2.h"

#include "skbdwin.h"

#include "gtk2/xnp2.h"
#include "gtk2/gtk_drawmng.h"
#include "gtk2/gtk_keyboard.h"


/*
 * software keyboard
 */

typedef struct {
	DRAWMNG_HDL	hdl;

	GtkWidget	*window;
} SKBDWIN;

static SKBDWIN skwin;


static void
skpalcnv(CMNPAL *dst, const RGB32 *src, UINT pals, UINT bpp)
{
	UINT i;

	switch (bpp) {
#if defined(SUPPORT_16BPP)
	case 16:
		for (i = 0; i < pals; i++) {
			dst[i].pal16 = drawmng_makepal16(&skwin.hdl->pal16mask, src[i]);
		}
		break;
#endif
#if defined(SUPPORT_24BPP)
	case 24:
#endif
#if defined(SUPPORT_32BPP)
	case 32:
#endif
#if defined(SUPPORT_24BPP) || defined(SUPPORT_32BPP)
		for (i = 0; i < pals; i++) {
			dst[i].pal32.d = src[i].d;
		}
		break;
#endif
	}
}

static void
skbdwin_draw(void)
{
	CMNVRAM *vram;

	vram = drawmng_surflock(skwin.hdl);
	if (vram) {
		softkbd_paint(vram, skpalcnv, TRUE);
		drawmng_surfunlock(skwin.hdl);
		drawmng_blt(skwin.hdl, NULL, NULL);
	}
}

/*
 * signal
 */
static void
skbdwin_window_destroy(GtkWidget *w, gpointer p)
{

	if (skwin.window)
		skwin.window = NULL;
	drawmng_release(skwin.hdl);
	skwin.hdl = NULL;
}

static gboolean
skbdwin_expose(GtkWidget *w, GdkEventExpose *ev)
{

	if (ev->type == GDK_EXPOSE) {
		if (ev->count == 0) {
			skbdwin_draw();
			return TRUE;
		}
	}
	return FALSE;
}

static gboolean
skbdwin_key_press(GtkWidget *w, GdkEventKey *ev, gpointer p)
{

	if (ev->type == GDK_KEY_PRESS) {
		if ((ev->keyval != GDK_F12) || (np2oscfg.F12KEY != 0))
			gtkkbd_keydown(ev->keyval);
		return TRUE;
	}
	return FALSE;
}
static gboolean
skbdwin_key_release(GtkWidget *w, GdkEventKey *ev, gpointer p)
{

	if (ev->type == GDK_KEY_RELEASE) {
		if ((ev->keyval != GDK_F12) || (np2oscfg.F12KEY != 0))
			gtkkbd_keyup(ev->keyval);
		return TRUE;
	}
	return FALSE;
}

static gboolean
skbdwin_button_press(GtkWidget *w, GdkEventButton *ev, gpointer p)
{

	if (ev->type == GDK_BUTTON_PRESS) {
		switch (ev->button) {
		case 1:
			softkbd_down((int)ev->x, (int)ev->y);
			break;
		}
		return TRUE;
	}
	return FALSE;
}

static gboolean
skbdwin_button_release(GtkWidget *w, GdkEventButton *ev, gpointer p)
{

	if (ev->type == GDK_BUTTON_RELEASE) {
		switch (ev->button) {
		case 1:
			softkbd_up();
			break;
		}
		return TRUE;
	}
	return FALSE;
}

/*
 * software keyboard interface
 */
#define	EVENT_MASK \
			 ( GDK_KEY_PRESS_MASK		\
			 | GDK_KEY_RELEASE_MASK		\
			 | GDK_BUTTON_PRESS_MASK	\
			 | GDK_BUTTON_RELEASE_MASK	\
			 | GDK_EXPOSURE_MASK)

void
skbdwin_create(void)
{
	GtkWidget *main_widget;
	GtkWidget *da;
	int width, height;

	if (skwin.window)
		return;

	if (softkbd_getsize(&width, &height) != SUCCESS)
		return;

	skwin.window = gtk_window_new(GTK_WINDOW_TOPLEVEL);
	gtk_window_set_title(GTK_WINDOW(skwin.window), "Software Keyboard");
	gtk_window_set_resizable(GTK_WINDOW(skwin.window), FALSE);
	gtk_widget_add_events(skwin.window, EVENT_MASK);
	g_signal_connect(GTK_OBJECT(skwin.window), "destroy",
	    G_CALLBACK(skbdwin_window_destroy), NULL);
	gtk_widget_realize(skwin.window);

	main_widget = gtk_vbox_new(FALSE, 2);
	gtk_widget_show(main_widget);
	gtk_container_add(GTK_CONTAINER(skwin.window), main_widget);

	skwin.hdl = drawmng_create(skwin.window, width, height);
	if (skwin.hdl == NULL) {
		goto destroy;
	}

	da = GTK_WIDGET(drawmng_get_widget_handle(skwin.hdl));
	gtk_box_pack_start(GTK_BOX(main_widget), da, FALSE, TRUE, 0);
	gtk_widget_show(da);

	g_signal_connect(GTK_OBJECT(skwin.window), "key_press_event",
	    G_CALLBACK(skbdwin_key_press), NULL);
	g_signal_connect(GTK_OBJECT(skwin.window), "key_release_event",
	    G_CALLBACK(skbdwin_key_release), NULL);
	g_signal_connect(GTK_OBJECT(skwin.window), "button_press_event",
	    G_CALLBACK(skbdwin_button_press), NULL);
	g_signal_connect(GTK_OBJECT(skwin.window), "button_release_event",
	    G_CALLBACK(skbdwin_button_release), NULL);

	g_signal_connect(GTK_OBJECT(da), "expose_event",
	    G_CALLBACK(skbdwin_expose), NULL);

	gtk_widget_show_all(skwin.window);

	drawmng_set_size(skwin.hdl, width, height);
	drawmng_invalidate(skwin.hdl, NULL);
	return;

destroy:
	gtk_widget_destroy(skwin.window);
	skwin.window = NULL;
}

void
skbdwin_destroy(void)
{

	if (skwin.window) {
		gtk_widget_destroy(skwin.window);
		skwin.window = NULL;
	}
}

void
skbdwin_process(void)
{

	if (skwin.window && softkbd_process()) {
		drawmng_invalidate(skwin.hdl, NULL);
	}
}
#endif	/* SUPPORT_SOFTKBD */

RetroPC.NET-CVS <cvs@retropc.net>