ViewVC Help
View File | Revision Log | Show Annotations | Revision Graph | Root Listing
root/cebix/BasiliskII/src/AmigaOS/video_amiga.cpp
(Generate patch)

Comparing BasiliskII/src/AmigaOS/video_amiga.cpp (file contents):
Revision 1.8 by cebix, 2000-07-22T18:25:48Z vs.
Revision 1.17 by cebix, 2001-07-01T21:09:27Z

# Line 1 | Line 1
1   /*
2   *  video_amiga.cpp - Video/graphics emulation, AmigaOS specific stuff
3   *
4 < *  Basilisk II (C) 1997-2000 Christian Bauer
4 > *  Basilisk II (C) 1997-2001 Christian Bauer
5   *
6   *  This program is free software; you can redistribute it and/or modify
7   *  it under the terms of the GNU General Public License as published by
# Line 33 | Line 33
33   #include <proto/cybergraphics.h>
34  
35   #include "sysdeps.h"
36 + #include "cpu_emulation.h"
37   #include "main.h"
38   #include "adb.h"
39   #include "prefs.h"
# Line 94 | Line 95 | static void periodic_func(void);
95   *  Initialization
96   */
97  
98 + // Add resolution to list of supported modes and set VideoMonitor
99 + static void set_video_monitor(uint32 width, uint32 height, uint32 bytes_per_row, int depth)
100 + {
101 +        video_mode mode;
102 +
103 +        mode.x = width;
104 +        mode.y = height;
105 +        mode.resolution_id = 0x80;
106 +        mode.bytes_per_row = bytes_per_row;
107 +
108 +        switch (depth) {
109 +                case 1:
110 +                        mode.depth = VDEPTH_1BIT;
111 +                        break;
112 +                case 2:
113 +                        mode.depth = VDEPTH_2BIT;
114 +                        break;
115 +                case 4:
116 +                        mode.depth = VDEPTH_4BIT;
117 +                        break;
118 +                case 8:
119 +                        mode.depth = VDEPTH_8BIT;
120 +                        break;
121 +                case 15:
122 +                case 16:
123 +                        mode.depth = VDEPTH_16BIT;
124 +                        break;
125 +                case 24:
126 +                case 32:
127 +                        mode.depth = VDEPTH_32BIT;
128 +                        break;
129 +        }
130 +
131 +        VideoModes.push_back(mode);
132 +        VideoMonitor.mode = mode;
133 + }
134 +
135   // Open window
136   static bool init_window(int width, int height)
137   {
# Line 116 | Line 154 | static bool init_window(int width, int h
154                  TAG_END
155          );
156          if (the_win == NULL) {
157 <                ErrorAlert(GetString(STR_OPEN_WINDOW_ERR));
157 >                ErrorAlert(STR_OPEN_WINDOW_ERR);
158                  return false;
159          }
160  
161          // Create bitmap ("height + 2" for safety)
162          the_bitmap = AllocBitMap(width, height + 2, 1, BMF_CLEAR, NULL);
163          if (the_bitmap == NULL) {
164 <                ErrorAlert(GetString(STR_NO_MEM_ERR));
164 >                ErrorAlert(STR_NO_MEM_ERR);
165                  return false;
166          }
167  
168 <        // Set VideoMonitor
168 >        // Add resolution and set VideoMonitor
169 >        set_video_monitor(width, height, the_bitmap->BytesPerRow, 1);
170          VideoMonitor.mac_frame_base = (uint32)the_bitmap->Planes[0];
132        VideoMonitor.bytes_per_row = the_bitmap->BytesPerRow;
133        VideoMonitor.x = width;
134        VideoMonitor.y = height;
135        VideoMonitor.mode = VMODE_1BIT;
171  
172          // Set FgPen and BgPen
173          black_pen = ObtainBestPenA(the_win->WScreen->ViewPort.ColorMap, 0, 0, 0, NULL);
# Line 171 | Line 206 | static bool init_pip(int width, int heig
206                  TAG_END
207          );
208          if (the_win == NULL || error) {
209 <                ErrorAlert(GetString(STR_OPEN_WINDOW_ERR));
209 >                ErrorAlert(STR_OPEN_WINDOW_ERR);
210                  return false;
211          }
212  
213          // Find bitmap
214          p96PIP_GetTags(the_win, P96PIP_SourceBitMap, (ULONG)&the_bitmap, TAG_END);
215  
216 <        // Set VideoMonitor
216 >        // Add resolution and set VideoMonitor
217          VideoMonitor.mac_frame_base = p96GetBitMapAttr(the_bitmap, P96BMA_MEMORY);
218 <        VideoMonitor.bytes_per_row = p96GetBitMapAttr(the_bitmap, P96BMA_BYTESPERROW);
184 <        VideoMonitor.x = width;
185 <        VideoMonitor.y = height;
186 <        VideoMonitor.mode = VMODE_16BIT;
218 >        set_video_monitor(width, height, p96GetBitMapAttr(the_bitmap, P96BMA_BYTESPERROW), 16);
219          return true;
220   }
221  
# Line 199 | Line 231 | static bool init_screen_p96(ULONG mode_i
231  
232          switch (depth) {
233                  case 8:
202                        VideoMonitor.mode = VMODE_8BIT;
234                          break;
235                  case 15:
236                  case 16:
237                          if (format != RGBFB_R5G5B5) {
238 <                                ErrorAlert(GetString(STR_WRONG_SCREEN_FORMAT_ERR));
238 >                                ErrorAlert(STR_WRONG_SCREEN_FORMAT_ERR);
239                                  return false;
240                          }
210                        VideoMonitor.mode = VMODE_16BIT;
241                          break;
242                  case 24:
243                  case 32:
244                          if (format != RGBFB_A8R8G8B8) {
245 <                                ErrorAlert(GetString(STR_WRONG_SCREEN_FORMAT_ERR));
245 >                                ErrorAlert(STR_WRONG_SCREEN_FORMAT_ERR);
246                                  return false;
247                          }
218                        VideoMonitor.mode = VMODE_32BIT;
248                          break;
249                  default:
250 <                        ErrorAlert(GetString(STR_WRONG_SCREEN_DEPTH_ERR));
250 >                        ErrorAlert(STR_WRONG_SCREEN_DEPTH_ERR);
251                          return false;
252          }
253  
# Line 226 | Line 255 | static bool init_screen_p96(ULONG mode_i
255          uint32 width = p96GetModeIDAttr(mode_id, P96IDA_WIDTH);
256          uint32 height = p96GetModeIDAttr(mode_id, P96IDA_HEIGHT);
257  
229        VideoMonitor.x = width;
230        VideoMonitor.y = height;
231
258          // Open screen
259          the_screen = p96OpenScreenTags(
260                  P96SA_DisplayID, mode_id,
# Line 240 | Line 266 | static bool init_screen_p96(ULONG mode_i
266                  TAG_END
267          );
268          if (the_screen == NULL) {
269 <                ErrorAlert(GetString(STR_OPEN_SCREEN_ERR));
269 >                ErrorAlert(STR_OPEN_SCREEN_ERR);
270                  return false;
271          }
272  
# Line 257 | Line 283 | static bool init_screen_p96(ULONG mode_i
283                  TAG_END
284          );
285          if (the_win == NULL) {
286 <                ErrorAlert(GetString(STR_OPEN_WINDOW_ERR));
286 >                ErrorAlert(STR_OPEN_WINDOW_ERR);
287                  return false;
288          }
289  
264        // Set VideoMonitor
290          ScreenToFront(the_screen);
291 +
292 +        // Add resolution and set VideoMonitor
293 +        set_video_monitor(width, height, p96GetBitMapAttr(the_screen->RastPort.BitMap, P96BMA_BYTESPERROW), depth);
294          VideoMonitor.mac_frame_base = p96GetBitMapAttr(the_screen->RastPort.BitMap, P96BMA_MEMORY);
267        VideoMonitor.bytes_per_row = p96GetBitMapAttr(the_screen->RastPort.BitMap, P96BMA_BYTESPERROW);
295          return true;
296   }
297  
# Line 280 | Line 307 | static bool init_screen_cgfx(ULONG mode_
307  
308          switch (depth) {
309                  case 8:
283                        VideoMonitor.mode = VMODE_8BIT;
310                          break;
311                  case 15:
312                  case 16:
313 <                        if (format != PIXFMT_RGB16) {
314 <                                ErrorAlert(GetString(STR_WRONG_SCREEN_FORMAT_ERR));
313 >                        // !!! PIXFMT_RGB15 is correct !!!
314 >                        if (format != PIXFMT_RGB15) {
315 >                                ErrorAlert(STR_WRONG_SCREEN_FORMAT_ERR);
316                                  return false;
317                          }
291                        VideoMonitor.mode = VMODE_16BIT;
318                          break;
319                  case 24:
320                  case 32:
321                          if (format != PIXFMT_ARGB32) {
322 <                                ErrorAlert(GetString(STR_WRONG_SCREEN_FORMAT_ERR));
322 >                                ErrorAlert(STR_WRONG_SCREEN_FORMAT_ERR);
323                                  return false;
324                          }
299                        VideoMonitor.mode = VMODE_32BIT;
325                          break;
326                  default:
327 <                        ErrorAlert(GetString(STR_WRONG_SCREEN_DEPTH_ERR));
327 >                        ErrorAlert(STR_WRONG_SCREEN_DEPTH_ERR);
328                          return false;
329          }
330  
# Line 307 | Line 332 | static bool init_screen_cgfx(ULONG mode_
332          uint32 width = GetCyberIDAttr(CYBRIDATTR_WIDTH, mode_id);
333          uint32 height = GetCyberIDAttr(CYBRIDATTR_HEIGHT, mode_id);
334  
310        VideoMonitor.x = width;
311        VideoMonitor.y = height;
312
335          // Open screen
336          the_screen = OpenScreenTags(NULL,
337                  SA_DisplayID, mode_id,
# Line 319 | Line 341 | static bool init_screen_cgfx(ULONG mode_
341                  TAG_END
342          );
343          if (the_screen == NULL) {
344 <                ErrorAlert(GetString(STR_OPEN_SCREEN_ERR));
344 >                ErrorAlert(STR_OPEN_SCREEN_ERR);
345                  return false;
346          }
347  
# Line 336 | Line 358 | static bool init_screen_cgfx(ULONG mode_
358                  TAG_END
359          );
360          if (the_win == NULL) {
361 <                ErrorAlert(GetString(STR_OPEN_WINDOW_ERR));
361 >                ErrorAlert(STR_OPEN_WINDOW_ERR);
362                  return false;
363          }
364  
343        // Set VideoMonitor
365          ScreenToFront(the_screen);
366          static UWORD ptr[] = { 0, 0, 0, 0 };
367          SetPointer(the_win, ptr, 0, 0, 0, 0);   // Hide mouse pointer
368 +
369 +        // Set VideoMonitor
370 +        ULONG frame_base;
371          APTR handle = LockBitMapTags(the_screen->RastPort.BitMap,
372 <                        LBMI_BASEADDRESS, (ULONG)&VideoMonitor.mac_frame_base,
373 <                        TAG_END);
372 >                LBMI_BASEADDRESS, (ULONG)&frame_base,
373 >                TAG_END
374 >        );
375          UnLockBitMap(handle);
376 <        VideoMonitor.bytes_per_row = GetCyberMapAttr(the_screen->RastPort.BitMap, CYBRMATTR_XMOD);
376 >        set_video_monitor(width, height, GetCyberMapAttr(the_screen->RastPort.BitMap, CYBRMATTR_XMOD), depth);
377 >        VideoMonitor.mac_frame_base = frame_base;
378          return true;
379   }
380  
# Line 357 | Line 383 | bool VideoInit(bool classic)
383          // Allocate blank mouse pointer data
384          null_pointer = (UWORD *)AllocMem(12, MEMF_PUBLIC | MEMF_CHIP | MEMF_CLEAR);
385          if (null_pointer == NULL) {
386 <                ErrorAlert(GetString(STR_NO_MEM_ERR));
386 >                ErrorAlert(STR_NO_MEM_ERR);
387                  return false;
388          }
389  
# Line 388 | Line 414 | bool VideoInit(bool classic)
414                          else if (CyberGfxBase && IsCyberModeID(mode_id))
415                                  display_type = DISPLAY_SCREEN_CGFX;
416                          else {
417 <                                ErrorAlert(GetString(STR_NO_P96_MODE_ERR));
417 >                                ErrorAlert(STR_NO_P96_MODE_ERR);
418                                  return false;
419                          }
420                  }
# Line 425 | Line 451 | bool VideoInit(bool classic)
451                  TAG_END
452          );
453          if (periodic_proc == NULL) {
454 <                ErrorAlert(GetString(STR_NO_MEM_ERR));
454 >                ErrorAlert(STR_NO_MEM_ERR);
455                  return false;
456          }
457          return true;
# Line 510 | Line 536 | void VideoExit(void)
536   *  Set palette
537   */
538  
539 < void video_set_palette(uint8 *pal)
539 > void video_set_palette(uint8 *pal, in num)
540   {
541 <        if (display_type == DISPLAY_SCREEN_P96 || display_type == DISPLAY_SCREEN_CGFX) {
541 >        if ((display_type == DISPLAY_SCREEN_P96 || display_type == DISPLAY_SCREEN_CGFX)
542 >         && !IsDirectMode(VideoMonitor.mode)) {
543  
544                  // Convert palette to 32 bits
545                  ULONG table[2 + 256 * 3];
546 <                table[0] = 256 << 16;
547 <                table[256 * 3 + 1] = 0;
548 <                for (int i=0; i<256; i++) {
546 >                table[0] = num << 16;
547 >                table[num * 3 + 1] = 0;
548 >                for (int i=0; i<num; i++) {
549                          table[i*3+1] = pal[i*3] * 0x01010101;
550                          table[i*3+2] = pal[i*3+1] * 0x01010101;
551                          table[i*3+3] = pal[i*3+2] * 0x01010101;
# Line 531 | Line 558 | void video_set_palette(uint8 *pal)
558  
559  
560   /*
561 + *  Switch video mode
562 + */
563 +
564 + void video_switch_to_mode(const video_mode &mode)
565 + {
566 + }
567 +
568 +
569 + /*
570   *  Video message handling (not neccessary under AmigaOS, handled by periodic_func())
571   */
572  
# Line 588 | Line 624 | static __saveds void periodic_func(void)
624  
625                          // Timer tick, update display
626                          BltTemplate(the_bitmap->Planes[0], 0, the_bitmap->BytesPerRow, the_win->RPort,
627 <                                the_win->BorderLeft, the_win->BorderTop, VideoMonitor.x, VideoMonitor.y);
627 >                                the_win->BorderLeft, the_win->BorderTop, VideoMonitor.mode.x, VideoMonitor.mode.y);
628  
629                          // Restart timer
630                          timer_io->tr_node.io_Command = TR_ADDREQUEST;
# Line 619 | Line 655 | static __saveds void periodic_func(void)
655                                                          ADBMouseMoved(mx - the_win->BorderLeft, my - the_win->BorderTop);
656                                                          if (mx < the_win->BorderLeft
657                                                           || my < the_win->BorderTop
658 <                                                         || mx >= the_win->BorderLeft + VideoMonitor.x
659 <                                                         || my >= the_win->BorderTop + VideoMonitor.y) {
658 >                                                         || mx >= the_win->BorderLeft + VideoMonitor.mode.x
659 >                                                         || my >= the_win->BorderTop + VideoMonitor.mode.y) {
660                                                                  if (current_pointer) {
661                                                                          ClearPointer(the_win);
662                                                                          current_pointer = NULL;
# Line 653 | Line 689 | static __saveds void periodic_func(void)
689                                          case IDCMP_RAWKEY:
690                                                  if (qualifier & IEQUALIFIER_REPEAT)     // Keyboard repeat is done by MacOS
691                                                          break;
692 +                                                if ((qualifier & (IEQUALIFIER_LALT | IEQUALIFIER_LSHIFT | IEQUALIFIER_CONTROL)) ==
693 +                                                    (IEQUALIFIER_LALT | IEQUALIFIER_LSHIFT | IEQUALIFIER_CONTROL) && code == 0x5f) {
694 +                                                        SetInterruptFlag(INTFLAG_NMI);
695 +                                                        TriggerInterrupt();
696 +                                                        break;
697 +                                                }
698 +
699                                                  if (code & IECODE_UP_PREFIX)
700                                                          ADBKeyUp(keycode2mac[code & 0x7f]);
701                                                  else

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines