add PIXEL_MODE_TMS9918G2 (MSX, ColecoVision, etc.)
This commit is contained in:
		
							parent
							
								
									6feb08649f
								
							
						
					
					
						commit
						cad8658225
					
				@ -189,6 +189,7 @@ static int Check_block_constraints(enum IMAGE_MODES mode)
 | 
			
		||||
 | 
			
		||||
  switch (mode)
 | 
			
		||||
  {
 | 
			
		||||
    case IMAGE_MODE_TMS9918G2:
 | 
			
		||||
    case IMAGE_MODE_THOMSON:
 | 
			
		||||
      block_height = 1;
 | 
			
		||||
      break;
 | 
			
		||||
@ -278,6 +279,12 @@ static int Check_block_constraints(enum IMAGE_MODES mode)
 | 
			
		||||
              GFX2_Log(GFX2_INFO, "Check_block_constraints() constraint error at (%d,%d)\n", x+x2, y+y2);
 | 
			
		||||
              if (Main.backups->Pages->Nb_layers < 2)
 | 
			
		||||
                Add_layer(Main.backups, 1);
 | 
			
		||||
              if (mode == IMAGE_MODE_TMS9918G2)
 | 
			
		||||
              {
 | 
			
		||||
                Pixel_in_layer(1, x+x2, y+y2, col); // put color in sprite layer
 | 
			
		||||
                Pixel_in_layer(0, x+x2, y+y2, c[0]); // put other color in picture layer
 | 
			
		||||
              }
 | 
			
		||||
              else
 | 
			
		||||
                Pixel_in_layer(1, x+x2, y+y2, errcol);
 | 
			
		||||
              error_count++;
 | 
			
		||||
            }
 | 
			
		||||
@ -548,6 +555,13 @@ void Button_Constraint_mode(void)
 | 
			
		||||
    else
 | 
			
		||||
      Convert_to_dhgr();
 | 
			
		||||
    break;
 | 
			
		||||
  case IMAGE_MODE_TMS9918G2:
 | 
			
		||||
    // switch to layer mode if needed
 | 
			
		||||
    if (Main.backups->Pages->Image_mode != IMAGE_MODE_LAYERED)
 | 
			
		||||
      Switch_layer_mode(IMAGE_MODE_LAYERED);
 | 
			
		||||
    Main.backups->Pages->Transparent_color = 0;
 | 
			
		||||
    Check_block_constraints(Selected_Constraint_Mode);
 | 
			
		||||
    break;
 | 
			
		||||
  default:
 | 
			
		||||
    Check_block_constraints(Selected_Constraint_Mode);
 | 
			
		||||
  }
 | 
			
		||||
@ -587,6 +601,7 @@ void Button_Constraint_menu(void)
 | 
			
		||||
    {IMAGE_MODE_C64FLI,  "C64 FLI",       "improved multicolor   ", 1}, // 160x200
 | 
			
		||||
    {IMAGE_MODE_HGR,     "Apple II HGR",  "6 colors              ", 1},  // 280x192
 | 
			
		||||
    {IMAGE_MODE_DHGR,    "Apple II DHGR", "\"Le Chat Mauve\" mode3 ", 1},  // 560x192
 | 
			
		||||
    {IMAGE_MODE_TMS9918G2,"TMS9918 Mode 2","MSX Screen2, etc.    ", 1},  // 256x192
 | 
			
		||||
  };
 | 
			
		||||
 | 
			
		||||
  Open_window(194,95+36,"8-bit constraints");
 | 
			
		||||
@ -711,6 +726,10 @@ void Button_Constraint_menu(void)
 | 
			
		||||
            End_of_modification();
 | 
			
		||||
            /// @todo enable TALL pixels when switching to 560x192
 | 
			
		||||
            break;
 | 
			
		||||
          case IMAGE_MODE_TMS9918G2:
 | 
			
		||||
            Resize_image(256, 192);
 | 
			
		||||
            End_of_modification();
 | 
			
		||||
            break;
 | 
			
		||||
          default:
 | 
			
		||||
            break;
 | 
			
		||||
        }
 | 
			
		||||
@ -736,6 +755,7 @@ void Button_Constraint_menu(void)
 | 
			
		||||
            break;
 | 
			
		||||
          case IMAGE_MODE_RASTER:
 | 
			
		||||
          case IMAGE_MODE_THOMSON:
 | 
			
		||||
          case IMAGE_MODE_TMS9918G2:
 | 
			
		||||
            Snap_width = 8;
 | 
			
		||||
            Snap_height = 999;  // maximum value (3 digits)
 | 
			
		||||
            break;
 | 
			
		||||
@ -871,6 +891,13 @@ void Button_Constraint_menu(void)
 | 
			
		||||
            Fore_color = 15;
 | 
			
		||||
            Back_color = 0;
 | 
			
		||||
            break;
 | 
			
		||||
          case IMAGE_MODE_TMS9918G2:
 | 
			
		||||
            memset(Main.palette, 0, sizeof(T_Palette));
 | 
			
		||||
            MSX_set_palette(Main.palette);
 | 
			
		||||
            First_color_in_palette = 0;
 | 
			
		||||
            Fore_color = 15;  // White
 | 
			
		||||
            Back_color = 1;   // Black
 | 
			
		||||
            break;
 | 
			
		||||
          default:
 | 
			
		||||
            break;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
@ -637,6 +637,7 @@ enum IMAGE_MODES
 | 
			
		||||
  IMAGE_MODE_HGR,       ///< Apple 2 HGR
 | 
			
		||||
  IMAGE_MODE_DHGR,      ///< Apple 2 DHGR
 | 
			
		||||
  IMAGE_MODE_MEGADRIVE, ///< Sega Mega Drive / Genesis
 | 
			
		||||
  IMAGE_MODE_TMS9918G2, ///< TMS9918 Mode 2 (MSX, ColecoVision, SC-3000, etc.)
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
/// Circle / Ellipse Modes
 | 
			
		||||
 | 
			
		||||
@ -3308,6 +3308,7 @@ static void Pixel_in_screen_egx_with_opt_preview(word x,word y,byte color,int pr
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/// Paint a pixel in 40col Thomson MO/TO mode
 | 
			
		||||
/// or TMS9918 Graphics 2
 | 
			
		||||
///
 | 
			
		||||
/// Only 2 colors in a 8x1 pixel block
 | 
			
		||||
static void Pixel_in_screen_thomson_with_opt_preview(word x,word y,byte color,int preview)
 | 
			
		||||
@ -3918,6 +3919,7 @@ void Update_pixel_renderer(void)
 | 
			
		||||
    Pixel_in_current_screen_with_opt_preview = Pixel_in_screen_egx_with_opt_preview;
 | 
			
		||||
    break;
 | 
			
		||||
  case IMAGE_MODE_THOMSON:
 | 
			
		||||
  case IMAGE_MODE_TMS9918G2:
 | 
			
		||||
    Pixel_in_current_screen_with_opt_preview = Pixel_in_screen_thomson_with_opt_preview;
 | 
			
		||||
    break;
 | 
			
		||||
  case IMAGE_MODE_GBC:
 | 
			
		||||
 | 
			
		||||
@ -69,6 +69,7 @@ static const struct {
 | 
			
		||||
  { IMAGE_MODE_HGR,       "APPLE2_HGR" },
 | 
			
		||||
  { IMAGE_MODE_DHGR,      "APPLE2_DHGR" },
 | 
			
		||||
  { IMAGE_MODE_MEGADRIVE, "SEGAMEGADRIVE" },
 | 
			
		||||
  { IMAGE_MODE_TMS9918G2, "TMS9918_G2" },
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
const char * Constraint_mode_label(enum IMAGE_MODES mode)
 | 
			
		||||
 | 
			
		||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user