6 #include <hildon/hildon.h>
7 #include "plugin_lib.h"
11 #include "../libpcsxcore/psemu_plugin_defs.h"
12 #include "common/readpng.h"
13 #include "maemo_common.h"
20 static GdkImage *image;
21 static HildonAnimationActor *actor;
22 static GtkWidget *window, *drawing;
24 static int pl_buf_w, pl_buf_h;
25 static int sens, y_def;
26 static int keymap[65536];
28 // map psx4m compatible keymap to PSX keys
29 static const unsigned char keymap2[14] = {
53 window_key_proxy(GtkWidget *widget,
57 int key, psxkey1 = -1, psxkey2 = -1;
59 key = keymap[event->hardware_keycode];
63 if (key < ARRAY_SIZE(keymap2))
64 psxkey1 = keymap2[key];
86 if (event->type == GDK_KEY_PRESS)
88 emu_save_state(state_slot);
90 sprintf (buf,"/opt/maemo/usr/games/screenshots%s.%3.3d",file_name,state_slot);
91 writepng(buf, image->mem, pl_buf_w,pl_buf_h);
95 if (event->type == GDK_KEY_PRESS)
96 emu_load_state(state_slot);
99 if (event->type == GDK_KEY_PRESS)
100 state_slot=(state_slot<9)?state_slot+1:0;
103 if (event->type == GDK_KEY_PRESS)
104 state_slot=(state_slot>0)?state_slot-1:8;
108 if (event->type == GDK_KEY_PRESS) {
110 in_keystate |= 1 << psxkey1;
112 in_keystate |= 1 << psxkey2;
114 else if (event->type == GDK_KEY_RELEASE) {
116 in_keystate &= ~(1 << psxkey1);
118 in_keystate &= ~(1 << psxkey2);
120 emu_set_action(SACTION_NONE);
129 void maemo_init(int *argc, char ***argv)
132 pFile = fopen("/opt/psx4m/keys", "r"); // assume the file exists and has data
135 for (i=0;i<65536;i++)
139 fscanf(pFile, "%i",&ch);
145 pFile = fopen("/opt/psx4m/config", "r");
147 fscanf(pFile, "%d %d",&sens,&y_def);
151 y_def=500; //near 45 degrees =)
154 gtk_init (argc, argv);
156 window = hildon_stackable_window_new ();
157 gtk_widget_realize (window);
158 gtk_window_fullscreen (GTK_WINDOW(window));
159 g_signal_connect (G_OBJECT (window), "key-press-event",
160 G_CALLBACK (window_key_proxy), NULL);
161 g_signal_connect (G_OBJECT (window), "key-release-event",
162 G_CALLBACK (window_key_proxy), NULL);
163 g_signal_connect (G_OBJECT (window), "delete_event",
164 G_CALLBACK (hildon_quit), NULL);
165 gtk_widget_add_events (window,
166 GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK);
168 actor = HILDON_ANIMATION_ACTOR (hildon_animation_actor_new());
169 if (g_maemo_opts & 2)
170 hildon_animation_actor_set_position (actor, 0, 0 );
172 hildon_animation_actor_set_position (actor, (X_RES - D_WIDTH)/2, (Y_RES - D_HEIGHT)/2 );
173 hildon_animation_actor_set_parent (actor, GTK_WINDOW (window));
175 drawing = gtk_image_new ();
177 gtk_container_add (GTK_CONTAINER (actor), drawing);
179 gtk_widget_show_all (GTK_WIDGET (actor));
180 gtk_widget_show_all (GTK_WIDGET (window));
182 g_layer_x = (X_RES - D_WIDTH) / 2;
183 g_layer_y = (Y_RES - D_HEIGHT) / 2;
184 g_layer_w = D_WIDTH, g_layer_h = D_HEIGHT;
186 pl_rearmed_cbs.only_16bpp = 1;
189 void *plat_gvideo_set_mode(int *w_, int *h_, int *bpp_)
191 int w = *w_, h = *h_;
193 if (w <= 0 || h <= 0)
196 if (image) gdk_image_destroy(image);
197 image = gdk_image_new( GDK_IMAGE_FASTEST, gdk_visual_get_system(), w, h );
199 pl_vout_buf = (void *) image->mem;
201 gtk_image_set_from_image (GTK_IMAGE(drawing), image, NULL);
203 gtk_window_resize (GTK_WINDOW (actor), w, h);
204 if (g_maemo_opts & 2)
205 hildon_animation_actor_set_scale (actor,
206 (gdouble)800 / (gdouble)w,
207 (gdouble)480 / (gdouble)h
210 hildon_animation_actor_set_scale (actor,
211 (gdouble)D_WIDTH / (gdouble)w,
212 (gdouble)D_HEIGHT / (gdouble)h
214 pl_buf_w=w;pl_buf_h=h;
218 void *plat_gvideo_flip(void)
220 gtk_widget_queue_draw (drawing);
222 // process accelometer
223 if (g_maemo_opts & 4) {
225 FILE* f = fopen( "/sys/class/i2c-adapter/i2c-3/3-001d/coord", "r" );
226 if( !f ) {printf ("err in accel"); exit(1);}
227 fscanf( f, "%d %d %d", &x, &y, &z );
230 if( x > sens ) in_keystate |= 1 << DKEY_LEFT;
231 else if( x < -sens ) in_keystate |= 1 << DKEY_RIGHT;
232 else {in_keystate &= ~(1 << DKEY_LEFT);in_keystate &= ~(1 << DKEY_RIGHT);}
235 if( y > sens )in_keystate |= 1 << DKEY_UP;
236 else if( y < -sens ) in_keystate |= 1 << DKEY_DOWN;
237 else {in_keystate &= ~(1 << DKEY_DOWN);in_keystate &= ~(1 << DKEY_UP);}
241 /* process GTK+ events */
242 while (gtk_events_pending())
243 gtk_main_iteration();
248 void plat_gvideo_open(void)
252 void plat_gvideo_close(void)
256 void *plat_prepare_screenshot(int *w, int *h, int *bpp)
261 void plat_step_volume(int is_up)
265 void plat_trigger_vibrate(int is_strong)
269 void plat_minimize(void)