home *** CD-ROM | disk | FTP | other *** search
/ Amiga ISO Collection / AmigaUtilCD1.iso / Emulatoren / FRODO24.LZX / Frodo / Src / FrodoGUI.c < prev    next >
Encoding:
C/C++ Source or Header  |  1996-12-17  |  10.9 KB  |  373 lines

  1. /*
  2.  *  Source machine generated by GadToolsBox V2.0b
  3.  *  which is (c) Copyright 1991-1993 Jaba Development
  4.  *
  5.  *  GUI Designed by : Christian Bauer
  6.  */
  7.  
  8. #include <exec/types.h>
  9. #include <intuition/intuition.h>
  10. #include <intuition/classes.h>
  11. #include <intuition/classusr.h>
  12. #include <intuition/imageclass.h>
  13. #include <intuition/gadgetclass.h>
  14. #include <libraries/gadtools.h>
  15. #include <graphics/displayinfo.h>
  16. #include <graphics/gfxbase.h>
  17. #include <clib/exec_protos.h>
  18. #include <clib/intuition_protos.h>
  19. #include <clib/gadtools_protos.h>
  20. #include <clib/graphics_protos.h>
  21. #include <clib/utility_protos.h>
  22. #include <string.h>
  23. #include "FrodoGUI.h"
  24.  
  25. struct Screen         *Scr = NULL;
  26. UBYTE                 *PubScreenName = "Workbench";
  27. APTR                   VisualInfo = NULL;
  28. struct Window         *PrefsWnd = NULL;
  29. struct Gadget         *PrefsGList = NULL;
  30. struct Menu           *PrefsMenus = NULL;
  31. struct Gadget         *PrefsGadgets[34];
  32. extern Class          *initGet( void );
  33. struct IClass         *getClass = NULL;
  34. struct _Object        *getImage = NULL;
  35. UWORD                  PrefsLeft = 0;
  36. UWORD                  PrefsTop = 11;
  37. UWORD                  PrefsWidth = 632;
  38. UWORD                  PrefsHeight = 209;
  39. UBYTE                 *PrefsWdt = (UBYTE *)" ";
  40. struct TextAttr       *Font, Attr;
  41. UWORD                  FontX, FontY;
  42. UWORD                  OffX, OffY;
  43.  
  44. UBYTE *ScreenType0Labels[] = {
  45.     (UBYTE *)"8 Bit RTG",
  46.     (UBYTE *)"4 Bit c2p4",
  47.     (UBYTE *)"1 Bit Amiga",
  48.     (UBYTE *)"Graffiti",
  49.     NULL };
  50.  
  51. UBYTE *Drv8Type0Labels[] = {
  52.     (UBYTE *)"Dir",
  53.     (UBYTE *)"D64",
  54.     (UBYTE *)"IEC",
  55.     NULL };
  56.  
  57. UBYTE *Drv9Type0Labels[] = {
  58.     (UBYTE *)"Dir",
  59.     (UBYTE *)"D64",
  60.     (UBYTE *)"IEC",
  61.     NULL };
  62.  
  63. UBYTE *Drv11Type0Labels[] = {
  64.     (UBYTE *)"Dir",
  65.     (UBYTE *)"D64",
  66.     (UBYTE *)"IEC",
  67.     NULL };
  68.  
  69. UBYTE *Drv10Type0Labels[] = {
  70.     (UBYTE *)"Dir",
  71.     (UBYTE *)"D64",
  72.     (UBYTE *)"IEC",
  73.     NULL };
  74.  
  75. UBYTE *SIDType0Labels[] = {
  76.     (UBYTE *)"Keine",
  77.     (UBYTE *)"SID-Karte",
  78.     (UBYTE *)"6581sid.library",
  79.     (UBYTE *)"playsid.library",
  80.     NULL };
  81.  
  82. struct NewMenu PrefsNewMenu[] = {
  83.     NM_TITLE, (STRPTR)"Projekt", NULL, 0, NULL, NULL,
  84.     NM_ITEM, (STRPTR)"Öffnen...", (STRPTR)"O", 0, 0L, NULL,
  85.     NM_ITEM, (STRPTR)NM_BARLABEL, NULL, 0, 0L, NULL,
  86.     NM_ITEM, (STRPTR)"Sichern", (STRPTR)"S", 0, 0L, NULL,
  87.     NM_ITEM, (STRPTR)"Sichern als...", (STRPTR)"A", 0, 0L, NULL,
  88.     NM_ITEM, (STRPTR)NM_BARLABEL, NULL, 0, 0L, NULL,
  89.     NM_ITEM, (STRPTR)"Über Frodo...", NULL, 0, 0L, NULL,
  90.     NM_ITEM, (STRPTR)NM_BARLABEL, NULL, 0, 0L, NULL,
  91.     NM_ITEM, (STRPTR)"OK", (STRPTR)"R", 0, 0L, NULL,
  92.     NM_ITEM, (STRPTR)"Abbrechen", (STRPTR)"Q", 0, 0L, NULL,
  93.     NM_END, NULL, NULL, 0, 0L, NULL };
  94.  
  95. UWORD PrefsGTypes[] = {
  96.     BUTTON_KIND,
  97.     BUTTON_KIND,
  98.     BUTTON_KIND,
  99.     CHECKBOX_KIND,
  100.     CHECKBOX_KIND,
  101.     CHECKBOX_KIND,
  102.     BUTTON_KIND,
  103.     TEXT_KIND,
  104.     CYCLE_KIND,
  105.     GENERIC_KIND,
  106.     GENERIC_KIND,
  107.     GENERIC_KIND,
  108.     GENERIC_KIND,
  109.     CHECKBOX_KIND,
  110.     CHECKBOX_KIND,
  111.     CHECKBOX_KIND,
  112.     CHECKBOX_KIND,
  113.     CHECKBOX_KIND,
  114.     CHECKBOX_KIND,
  115.     INTEGER_KIND,
  116.     INTEGER_KIND,
  117.     INTEGER_KIND,
  118.     INTEGER_KIND,
  119.     STRING_KIND,
  120.     STRING_KIND,
  121.     STRING_KIND,
  122.     STRING_KIND,
  123.     CYCLE_KIND,
  124.     CYCLE_KIND,
  125.     CYCLE_KIND,
  126.     CYCLE_KIND,
  127.     CYCLE_KIND,
  128.     CHECKBOX_KIND,
  129.     CHECKBOX_KIND
  130. };
  131.  
  132. struct NewGadget PrefsNGad[] = {
  133.     84, 187, 101, 16, (UBYTE *)"_O", NULL, GD_OK, PLACETEXT_IN, NULL, NULL,
  134.     443, 187, 101, 16, (UBYTE *)"_C", NULL, GD_Cancel, PLACETEXT_IN, NULL, NULL,
  135.     263, 187, 101, 16, (UBYTE *)"_S", NULL, GD_Save, PLACETEXT_IN, NULL, NULL,
  136.     188, 72, 26, 11, (UBYTE *)"Joystick an Port 1", NULL, GD_Joystick1On, PLACETEXT_LEFT, NULL, NULL,
  137.     188, 86, 26, 11, (UBYTE *)"Joystick an Port 2", NULL, GD_Joystick2On, PLACETEXT_LEFT, NULL, NULL,
  138.     188, 100, 26, 11, (UBYTE *)"Joysticks vertauschen", NULL, GD_JoystickSwap, PLACETEXT_LEFT, NULL, NULL,
  139.     425, 6, 193, 14, NULL, NULL, GD_GetDisplayID, 0, NULL, NULL,
  140.     425, 20, 193, 14, (UBYTE *)"Bildschirmmodus", NULL, GD_DisplayID, PLACETEXT_LEFT, NULL, NULL,
  141.     425, 36, 143, 14, (UBYTE *)"Bildschirmtyp", NULL, GD_ScreenType, PLACETEXT_LEFT, NULL, NULL,
  142.     598, 85, 20, 14, NULL, NULL, GD_GetDir8, 0, NULL, NULL,
  143.     598, 101, 20, 14, NULL, NULL, GD_GetDir9, 0, NULL, NULL,
  144.     598, 117, 20, 14, NULL, NULL, GD_GetDir10, 0, NULL, NULL,
  145.     598, 133, 20, 14, NULL, NULL, GD_GetDir11, 0, NULL, NULL,
  146.     592, 151, 26, 11, (UBYTE *)"IEC für andere Geräte verwenden", NULL, GD_OtherIEC, PLACETEXT_LEFT, NULL, NULL,
  147.     188, 114, 26, 11, (UBYTE *)"Amerik. Tastatur", NULL, GD_KeyboardYZ, PLACETEXT_LEFT, NULL, NULL,
  148.     188, 142, 26, 11, (UBYTE *)"Sprite-Kollisionen", NULL, GD_Collisions, PLACETEXT_LEFT, NULL, NULL,
  149.     592, 164, 26, 11, (UBYTE *)"'/' -> '\' in Dateinamen", NULL, GD_MapSlash, PLACETEXT_LEFT, NULL, NULL,
  150.     188, 156, 26, 11, (UBYTE *)"Schneller Reset", NULL, GD_FastReset, PLACETEXT_LEFT, NULL, NULL,
  151.     188, 170, 26, 11, (UBYTE *)"Geschw. begrenzen", NULL, GD_LimitSpeed, PLACETEXT_LEFT, NULL, NULL,
  152.     188, 6, 81, 14, (UBYTE *)"Zyklen/Zeile (CPU)", NULL, GD_NormalCycles, PLACETEXT_LEFT, NULL, NULL,
  153.     188, 22, 81, 14, (UBYTE *)"Zyklen/Bad Line (CPU)", NULL, GD_BadLineCycles, PLACETEXT_LEFT, NULL, NULL,
  154.     188, 38, 81, 14, (UBYTE *)"Zyklen/Zeile (CIA)", NULL, GD_CIACycles, PLACETEXT_LEFT, NULL, NULL,
  155.     188, 54, 81, 14, (UBYTE *)"Jedes (n)te Bild", NULL, GD_SkipLatch, PLACETEXT_LEFT, NULL, NULL,
  156.     405, 85, 193, 14, NULL, NULL, GD_Dir8, 0, NULL, NULL,
  157.     405, 101, 193, 14, NULL, NULL, GD_Dir9, 0, NULL, NULL,
  158.     405, 117, 193, 14, NULL, NULL, GD_Dir10, 0, NULL, NULL,
  159.     405, 133, 193, 14, NULL, NULL, GD_Dir11, 0, NULL, NULL,
  160.     340, 85, 65, 14, (UBYTE *)"Laufwerk 8", NULL, GD_Drv8Type, PLACETEXT_LEFT, NULL, NULL,
  161.     340, 101, 65, 14, (UBYTE *)"Laufwerk 9", NULL, GD_Drv9Type, PLACETEXT_LEFT, NULL, NULL,
  162.     340, 133, 65, 14, (UBYTE *)"Laufwerk 11", NULL, GD_Drv11Type, PLACETEXT_LEFT, NULL, NULL,
  163.     340, 117, 65, 14, (UBYTE *)"Laufwerk 10", NULL, GD_Drv10Type, PLACETEXT_LEFT, NULL, NULL,
  164.     425, 67, 193, 14, (UBYTE *)"SID-Emulation", NULL, GD_SIDType, PLACETEXT_LEFT, NULL, NULL,
  165.     592, 52, 26, 11, (UBYTE *)"Direkter Videozugriff erlaubt", NULL, GD_DirectVideo, PLACETEXT_LEFT, NULL, NULL,
  166.     188, 128, 26, 11, (UBYTE *)"Sprite-Darstellung", NULL, GD_SpritesOn, PLACETEXT_LEFT, NULL, NULL
  167. };
  168.  
  169. ULONG PrefsGTags[] = {
  170.     (GT_Underscore), '_', (TAG_DONE),
  171.     (GT_Underscore), '_', (TAG_DONE),
  172.     (GT_Underscore), '_', (TAG_DONE),
  173.     (TAG_DONE),
  174.     (TAG_DONE),
  175.     (TAG_DONE),
  176.     (TAG_DONE),
  177.     (GTTX_Border), TRUE, (TAG_DONE),
  178.     (GTCY_Labels), (ULONG)&ScreenType0Labels[ 0 ], (TAG_DONE),
  179.     (TAG_DONE),
  180.     (TAG_DONE),
  181.     (TAG_DONE),
  182.     (TAG_DONE),
  183.     (TAG_DONE),
  184.     (TAG_DONE),
  185.     (TAG_DONE),
  186.     (TAG_DONE),
  187.     (TAG_DONE),
  188.     (TAG_DONE),
  189.     (GTIN_Number), 0, (GTIN_MaxChars), 10, (TAG_DONE),
  190.     (GTIN_Number), 0, (GTIN_MaxChars), 10, (TAG_DONE),
  191.     (GTIN_Number), 0, (GTIN_MaxChars), 10, (TAG_DONE),
  192.     (GTIN_Number), 0, (GTIN_MaxChars), 10, (TAG_DONE),
  193.     (GTST_MaxChars), 256, (TAG_DONE),
  194.     (GTST_MaxChars), 256, (TAG_DONE),
  195.     (GTST_MaxChars), 256, (TAG_DONE),
  196.     (GTST_MaxChars), 256, (TAG_DONE),
  197.     (GTCY_Labels), (ULONG)&Drv8Type0Labels[ 0 ], (TAG_DONE),
  198.     (GTCY_Labels), (ULONG)&Drv9Type0Labels[ 0 ], (TAG_DONE),
  199.     (GTCY_Labels), (ULONG)&Drv11Type0Labels[ 0 ], (TAG_DONE),
  200.     (GTCY_Labels), (ULONG)&Drv10Type0Labels[ 0 ], (TAG_DONE),
  201.     (GTCY_Labels), (ULONG)&SIDType0Labels[ 0 ], (TAG_DONE),
  202.     (TAG_DONE),
  203.     (TAG_DONE)
  204. };
  205.  
  206. static UWORD ComputeX( UWORD value )
  207. {
  208.     return(( UWORD )((( FontX * value ) + 4 ) / 8 ));
  209. }
  210.  
  211. static UWORD ComputeY( UWORD value )
  212. {
  213.     return(( UWORD )((( FontY * value ) + 4 ) / 8 ));
  214. }
  215.  
  216. static void ComputeFont( UWORD width, UWORD height )
  217. {
  218.     Font = &Attr;
  219.     Font->ta_Name = (STRPTR)Scr->RastPort.Font->tf_Message.mn_Node.ln_Name;
  220.     Font->ta_YSize = FontY = Scr->RastPort.Font->tf_YSize;
  221.     FontX = Scr->RastPort.Font->tf_XSize;
  222.  
  223.     OffX = Scr->WBorLeft;
  224.     OffY = Scr->RastPort.TxHeight + Scr->WBorTop + 1;
  225.  
  226.     if ( width && height ) {
  227.         if (( ComputeX( width ) + OffX + Scr->WBorRight ) > Scr->Width )
  228.             goto UseTopaz;
  229.         if (( ComputeY( height ) + OffY + Scr->WBorBottom ) > Scr->Height )
  230.             goto UseTopaz;
  231.     }
  232.     return;
  233.  
  234. UseTopaz:
  235.     Font->ta_Name = (STRPTR)"topaz.font";
  236.     FontX = FontY = Font->ta_YSize = 8;
  237. }
  238.  
  239. int SetupScreen( void )
  240. {
  241.     if ( ! ( Scr = LockPubScreen( PubScreenName )))
  242.         return( 1L );
  243.  
  244.     ComputeFont( 0, 0 );
  245.  
  246.     if ( ! ( VisualInfo = GetVisualInfo( Scr, TAG_DONE )))
  247.         return( 2L );
  248.  
  249.     if ( ! ( getClass = initGet()))
  250.         return( 3L );
  251.  
  252.     if ( ! ( getImage = NewObject( getClass, NULL, GT_VisualInfo, VisualInfo, TAG_DONE )))
  253.         return( 4L );
  254.  
  255.     return( 0L );
  256. }
  257.  
  258. void CloseDownScreen( void )
  259. {
  260.     if ( getImage   ) {
  261.         DisposeObject( getImage );
  262.         getImage = NULL;
  263.     }
  264.  
  265.     if ( getClass   ) {
  266.         FreeClass( getClass );
  267.         getClass = NULL;
  268.     }
  269.  
  270.     if ( VisualInfo ) {
  271.         FreeVisualInfo( VisualInfo );
  272.         VisualInfo = NULL;
  273.     }
  274.  
  275.     if ( Scr        ) {
  276.         UnlockPubScreen( NULL, Scr );
  277.         Scr = NULL;
  278.     }
  279. }
  280.  
  281. int OpenPrefsWindow( void )
  282. {
  283.     struct NewGadget    ng;
  284.     struct Gadget    *g;
  285.     UWORD        lc, tc;
  286.     UWORD        wleft = PrefsLeft, wtop = PrefsTop, ww, wh;
  287.  
  288.     ComputeFont( PrefsWidth, PrefsHeight );
  289.  
  290.     ww = ComputeX( PrefsWidth );
  291.     wh = ComputeY( PrefsHeight );
  292.  
  293.     if (( wleft + ww + OffX + Scr->WBorRight ) > Scr->Width ) wleft = Scr->Width - ww;
  294.     if (( wtop + wh + OffY + Scr->WBorBottom ) > Scr->Height ) wtop = Scr->Height - wh;
  295.  
  296.     if ( ! ( g = CreateContext( &PrefsGList )))
  297.         return( 1L );
  298.  
  299.     for( lc = 0, tc = 0; lc < Prefs_CNT; lc++ ) {
  300.  
  301.         CopyMem((char * )&PrefsNGad[ lc ], (char * )&ng, (long)sizeof( struct NewGadget ));
  302.  
  303.         ng.ng_VisualInfo = VisualInfo;
  304.         ng.ng_TextAttr   = Font;
  305.         ng.ng_LeftEdge   = OffX + ComputeX( ng.ng_LeftEdge );
  306.         ng.ng_TopEdge    = OffY + ComputeY( ng.ng_TopEdge );
  307.  
  308.         if ( PrefsGTypes[ lc ] != GENERIC_KIND ) {
  309.             ng.ng_Width      = ComputeX( ng.ng_Width );
  310.             ng.ng_Height     = ComputeY( ng.ng_Height);
  311.         }
  312.  
  313.         PrefsGadgets[ lc ] = g = CreateGadgetA((ULONG)PrefsGTypes[ lc ], g, &ng, ( struct TagItem * )&PrefsGTags[ tc ] );
  314.  
  315.         if ( PrefsGTypes[ lc ] == GENERIC_KIND ) {
  316.             g->Flags             |= GFLG_GADGIMAGE | GFLG_GADGHIMAGE;
  317.             g->Activation        |= GACT_RELVERIFY;
  318.             g->GadgetRender       = (APTR)getImage;
  319.             g->SelectRender       = (APTR)getImage;
  320.         }
  321.  
  322.         while( PrefsGTags[ tc ] ) tc += 2;
  323.         tc++;
  324.  
  325.         if ( NOT g )
  326.             return( 2L );
  327.     }
  328.  
  329.     if ( ! ( PrefsMenus = CreateMenus( PrefsNewMenu, GTMN_FrontPen, 0L, TAG_DONE )))
  330.         return( 3L );
  331.  
  332.     LayoutMenus( PrefsMenus, VisualInfo, GTMN_NewLookMenus, TRUE, TAG_DONE );
  333.  
  334.     if ( ! ( PrefsWnd = OpenWindowTags( NULL,
  335.                 WA_Left,    wleft,
  336.                 WA_Top,        wtop,
  337.                 WA_Width,    ww + OffX + Scr->WBorRight,
  338.                 WA_Height,    wh + OffY + Scr->WBorBottom,
  339.                 WA_IDCMP,    BUTTONIDCMP|CHECKBOXIDCMP|TEXTIDCMP|CYCLEIDCMP|IDCMP_GADGETUP|INTEGERIDCMP|STRINGIDCMP|IDCMP_MENUPICK|IDCMP_VANILLAKEY|IDCMP_REFRESHWINDOW,
  340.                 WA_Flags,    WFLG_DRAGBAR|WFLG_DEPTHGADGET|WFLG_SMART_REFRESH|WFLG_SIMPLE_REFRESH|WFLG_ACTIVATE,
  341.                 WA_Gadgets,    PrefsGList,
  342.                 WA_Title,    PrefsWdt,
  343.                 WA_ScreenTitle,    " ",
  344.                 WA_AutoAdjust,    TRUE,
  345.                 WA_NewLookMenus, TRUE,
  346.                 TAG_DONE )))
  347.     return( 4L );
  348.  
  349.     SetMenuStrip( PrefsWnd, PrefsMenus );
  350.     GT_RefreshWindow( PrefsWnd, NULL );
  351.  
  352.     return( 0L );
  353. }
  354.  
  355. void ClosePrefsWindow( void )
  356. {
  357.     if ( PrefsMenus      ) {
  358.         ClearMenuStrip( PrefsWnd );
  359.         FreeMenus( PrefsMenus );
  360.         PrefsMenus = NULL;    }
  361.  
  362.     if ( PrefsWnd        ) {
  363.         CloseWindow( PrefsWnd );
  364.         PrefsWnd = NULL;
  365.     }
  366.  
  367.     if ( PrefsGList      ) {
  368.         FreeGadgets( PrefsGList );
  369.         PrefsGList = NULL;
  370.     }
  371. }
  372.  
  373.