6 #include <hildon/hildon.h>
7 #include "plugin_lib.h"
9 #include "../libpcsxcore/psemu_plugin_defs.h"
16 static GdkImage *image;
17 static HildonAnimationActor *actor;
18 static GtkWidget *window, *drawing;
21 int in_type = PSE_PAD_TYPE_STANDARD;
22 int in_keystate, in_a1[2], in_a2[2];
24 static int keymap[65536];
26 // map psx4m compatible keymap to PSX keys
27 static const unsigned char keymap2[14] = {
51 window_key_proxy(GtkWidget *widget,
55 int key, psxkey1 = -1, psxkey2 = -1;
57 key = keymap[event->hardware_keycode];
61 if (key < ARRAY_SIZE(keymap2))
62 psxkey1 = keymap2[key];
84 if (event->type == GDK_KEY_PRESS)
85 emu_set_action(SACTION_SAVE_STATE);
88 if (event->type == GDK_KEY_PRESS)
89 emu_set_action(SACTION_LOAD_STATE);
93 if (event->type == GDK_KEY_PRESS) {
95 in_keystate |= 1 << psxkey1;
97 in_keystate |= 1 << psxkey2;
99 else if (event->type == GDK_KEY_RELEASE) {
101 in_keystate &= ~(1 << psxkey1);
103 in_keystate &= ~(1 << psxkey2);
105 emu_set_action(SACTION_NONE);
114 void maemo_init(int *argc, char ***argv)
117 pFile = fopen("/opt/psx4m/keys", "r"); // assume the file exists and has data
120 for (i=0;i<65536;i++)
124 fscanf(pFile, "%i",&ch);
130 gtk_init (argc, argv);
132 window = hildon_stackable_window_new ();
133 gtk_widget_realize (window);
134 gtk_window_fullscreen (GTK_WINDOW(window));
135 g_signal_connect (G_OBJECT (window), "key-press-event",
136 G_CALLBACK (window_key_proxy), NULL);
137 g_signal_connect (G_OBJECT (window), "key-release-event",
138 G_CALLBACK (window_key_proxy), NULL);
139 g_signal_connect (G_OBJECT (window), "delete_event",
140 G_CALLBACK (hildon_quit), NULL);
141 gtk_widget_add_events (window,
142 GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK);
144 actor = HILDON_ANIMATION_ACTOR (hildon_animation_actor_new());
145 hildon_animation_actor_set_position (actor, (X_RES - D_WIDTH)/2, (Y_RES - D_HEIGHT)/2 );
146 hildon_animation_actor_set_parent (actor, GTK_WINDOW (window));
148 drawing = gtk_image_new ();
150 gtk_container_add (GTK_CONTAINER (actor), drawing);
152 gtk_widget_show_all (GTK_WIDGET (actor));
153 gtk_widget_show_all (GTK_WIDGET (window));
160 void *pl_fbdev_set_mode(int w, int h, int bpp)
162 if (w <= 0 || h <= 0)
165 if (image) gdk_image_destroy(image);
166 image = gdk_image_new( GDK_IMAGE_FASTEST, gdk_visual_get_system(), w, h );
168 pl_fbdev_buf = (void *) image->mem;
170 gtk_image_set_from_image (GTK_IMAGE(drawing), image, NULL);
172 gtk_window_resize (GTK_WINDOW (actor), w, h);
173 hildon_animation_actor_set_scale (actor,
174 (gdouble)D_WIDTH / (gdouble)w,
175 (gdouble)D_HEIGHT / (gdouble)h
181 void *pl_fbdev_flip(void)
183 gtk_widget_queue_draw (drawing);
187 void pl_frame_limit(void)
189 extern void CheckFrameRate(void);
192 /* process GTK+ events */
193 while (gtk_events_pending())
194 gtk_main_iteration();
197 void pl_fbdev_close(void)
201 int pl_fbdev_open(void)
206 static void pl_get_layer_pos(int *x, int *y, int *w, int *h)
214 void *pl_prepare_screenshot(int *w, int *h, int *bpp)
224 extern int UseFrameSkip; // hmh
226 const struct rearmed_cbs pl_rearmed_cbs = {