Rework layer visibilty handling to be something sane, in the process fix subscreen layers that were not working. OBJs are still not handled.

This commit is contained in:
riccardom 2009-01-05 10:29:56 +00:00
parent 47905bafea
commit 985cd76a5f
1 changed files with 40 additions and 25 deletions

View File

@ -72,6 +72,18 @@ static const char *bad_glob_cflash_disk_image_file;
static SDL_sem *fps_limiter_semaphore; static SDL_sem *fps_limiter_semaphore;
static int gtk_fps_limiter_disabled; static int gtk_fps_limiter_disabled;
enum {
MAIN_BG_0 = 0,
MAIN_BG_1,
MAIN_BG_2,
MAIN_BG_3,
MAIN_OBJ,
SUB_BG_0,
SUB_BG_1,
SUB_BG_2,
SUB_BG_3,
SUB_OBJ
};
/************************ CONFIG FILE *****************************/ /************************ CONFIG FILE *****************************/
@ -1060,35 +1072,38 @@ static void Modify_ScreenCoeff(GtkWidget* widget, gpointer data)
static void Modify_Layer(GtkWidget* widget, gpointer data) static void Modify_Layer(GtkWidget* widget, gpointer data)
{ {
int i; int Layer = GPOINTER_TO_INT(data);
gchar *Layer = (gchar*)data;
if(!desmume_running()) { if (!desmume_running())
return; return;
}
if(memcmp(Layer, "Sub", 3) == 0) { switch (Layer) {
if(memcmp(Layer, "Sub BG", 6) == 0) { case MAIN_BG_0:
i = atoi(Layer + strlen("Sub BG ")); case MAIN_BG_1:
if(gtk_check_menu_item_get_active(GTK_CHECK_MENU_ITEM(widget)) == TRUE) { case MAIN_BG_2:
if(!SubScreen.gpu->dispBG[i]) GPU_addBack(SubScreen.gpu, i); case MAIN_BG_3:
} else { if(gtk_check_menu_item_get_active(GTK_CHECK_MENU_ITEM(widget)) == TRUE) {
if(SubScreen.gpu->dispBG[i]) GPU_remove(SubScreen.gpu, i); if(!MainScreen.gpu->dispBG[Layer]) GPU_addBack(MainScreen.gpu, Layer);
}
} else { } else {
/* TODO: Disable sprites */ if(MainScreen.gpu->dispBG[Layer]) GPU_remove(MainScreen.gpu, Layer);
} }
} else { break;
if(memcmp(Layer, "Main BG", 7) == 0) { case SUB_BG_0:
i = atoi(Layer + strlen("Main BG ")); case SUB_BG_1:
if(gtk_check_menu_item_get_active(GTK_CHECK_MENU_ITEM(widget)) == TRUE) { case SUB_BG_2:
if(!MainScreen.gpu->dispBG[i]) GPU_addBack(MainScreen.gpu, i); case SUB_BG_3:
} else { if(gtk_check_menu_item_get_active(GTK_CHECK_MENU_ITEM(widget)) == TRUE) {
if(MainScreen.gpu->dispBG[i]) GPU_remove(MainScreen.gpu, i); if(!SubScreen.gpu->dispBG[Layer-SUB_BG_0]) GPU_addBack(SubScreen.gpu, Layer-SUB_BG_0);
}
} else { } else {
/* TODO: Disable sprites */ if(SubScreen.gpu->dispBG[Layer-SUB_BG_0]) GPU_remove(SubScreen.gpu, Layer-SUB_BG_0);
} }
break;
case SUB_OBJ:
case MAIN_OBJ:
/* TODO: Disable sprites */
break;
default:
break;
} }
LOG ("Changed %s to %d\n",Layer,gtk_check_menu_item_get_active(GTK_CHECK_MENU_ITEM(widget))); LOG ("Changed %s to %d\n",Layer,gtk_check_menu_item_get_active(GTK_CHECK_MENU_ITEM(widget)));
} }
@ -1483,7 +1498,7 @@ static void desmume_gtk_menu_emulation_graphics (GtkWidget *pMenu, gboolean open
for(i = 0; i < 10; i++) { for(i = 0; i < 10; i++) {
mLayers_Radio[i] = gtk_check_menu_item_new_with_label(Layers_Menu[i]); mLayers_Radio[i] = gtk_check_menu_item_new_with_label(Layers_Menu[i]);
g_signal_connect(G_OBJECT(mLayers_Radio[i]), "activate", G_CALLBACK(Modify_Layer), (void*)Layers_Menu[i]); g_signal_connect(G_OBJECT(mLayers_Radio[i]), "activate", G_CALLBACK(Modify_Layer), (void *)i);
gtk_menu_shell_append(GTK_MENU_SHELL(pSubmenu), mLayers_Radio[i]); gtk_menu_shell_append(GTK_MENU_SHELL(pSubmenu), mLayers_Radio[i]);
gtk_check_menu_item_set_active(GTK_CHECK_MENU_ITEM(mLayers_Radio[i]), TRUE); gtk_check_menu_item_set_active(GTK_CHECK_MENU_ITEM(mLayers_Radio[i]), TRUE);
} }