home *** CD-ROM | disk | FTP | other *** search
/ Gold Fish 2 / goldfish_vol2_cd1.bin / files / util / blank / gblanker / source / blankers / clock / clock.c < prev    next >
C/C++ Source or Header  |  1994-03-06  |  7KB  |  268 lines

  1. /*
  2.  *  Source machine generated by GadToolsBox V2.0b
  3.  *  which is (c) Copyright 1991-1993 Jaba Development
  4.  *
  5.  *  GUI Designed by : Michael D. Bayne
  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 <clib/diskfont_protos.h>
  24.  
  25. #include "Clock.h"
  26.  
  27. struct Screen         *Scr = NULL;
  28. UBYTE                 *PubScreenName = "Workbench";
  29. APTR                   VisualInfo = NULL;
  30. struct Window         *ClockWnd = NULL;
  31. struct Gadget         *ClockGList = NULL;
  32. struct IntuiMessage    ClockMsg;
  33. struct Gadget         *ClockGadgets[9];
  34. UWORD                  ClockLeft = 0;
  35. UWORD                  ClockTop = 12;
  36. UWORD                  ClockWidth = 259;
  37. UWORD                  ClockHeight = 58;
  38. UBYTE                 *ClockWdt = (UBYTE *)"Clock Prefs";
  39. struct TextAttr       *Font, Attr;
  40. UWORD                  FontX, FontY;
  41. UWORD                  OffX, OffY;
  42. struct TextFont       *ClockFont = NULL;
  43.  
  44. UBYTE *CY_MIL0Labels[] = {
  45.     (UBYTE *)"12 Hour",
  46.     (UBYTE *)"24 Hour",
  47.     NULL };
  48.  
  49. UBYTE *CY_SECS0Labels[] = {
  50.     (UBYTE *)"Hr:Mn",
  51.     (UBYTE *)"Hr:Mn:Sc",
  52.     NULL };
  53.  
  54. UBYTE *CY_CYCLE0Labels[] = {
  55.     (UBYTE *)"Cycle",
  56.     (UBYTE *)"Random",
  57.     (UBYTE *)"White",
  58.     (UBYTE *)"Copper",
  59.     NULL };
  60.  
  61. UWORD ClockGTypes[] = {
  62.     BUTTON_KIND,
  63.     BUTTON_KIND,
  64.     BUTTON_KIND,
  65.     SLIDER_KIND,
  66.     CYCLE_KIND,
  67.     CYCLE_KIND,
  68.     CYCLE_KIND,
  69.     BUTTON_KIND,
  70.     BUTTON_KIND
  71. };
  72.  
  73. struct NewGadget ClockNGad[] = {
  74.     5, 22, 60, 14, (UBYTE *)"_Font...", NULL, GD_BT_FONT, PLACETEXT_IN, NULL, (APTR)BT_FONTClicked,
  75.     4, 40, 60, 14, (UBYTE *)"_Save", NULL, GD_BT_SAVE, PLACETEXT_IN, NULL, (APTR)BT_SAVEClicked,
  76.     196, 40, 60, 14, (UBYTE *)"_Cancel", NULL, GD_BT_CANCEL, PLACETEXT_IN, NULL, (APTR)BT_CANCELClicked,
  77.     110, 22, 117, 14, (UBYTE *)"De_lay", NULL, GD_SL_DELAY, PLACETEXT_LEFT, NULL, (APTR)SL_DELAYClicked,
  78.     4, 4, 81, 14, NULL, NULL, GD_CY_MIL, 0, NULL, (APTR)CY_MILClicked,
  79.     89, 4, 81, 14, NULL, NULL, GD_CY_SECS, 0, NULL, (APTR)CY_SECSClicked,
  80.     175, 4, 81, 14, NULL, NULL, GD_CY_CYCLE, 0, NULL, (APTR)CY_CYCLEClicked,
  81.     68, 40, 60, 14, (UBYTE *)"_Test", NULL, GD_BT_TEST, PLACETEXT_IN, NULL, (APTR)BT_TESTClicked,
  82.     132, 40, 60, 14, (UBYTE *)"_Display", NULL, GD_BT_SCREEN, PLACETEXT_IN, NULL, (APTR)BT_SCREENClicked
  83. };
  84.  
  85. ULONG ClockGTags[] = {
  86.     (GT_Underscore), '_', (TAG_DONE),
  87.     (GT_Underscore), '_', (TAG_DONE),
  88.     (GT_Underscore), '_', (TAG_DONE),
  89.     (GTSL_Max), 120, (GTSL_Level), 60, (GTSL_MaxLevelLen), 4, (GTSL_LevelFormat), (ULONG)"%3ld", (GTSL_LevelPlace), (PLACETEXT_RIGHT), (PGA_Freedom), LORIENT_HORIZ, (GA_RelVerify), TRUE, (GT_Underscore), '_', (TAG_DONE),
  90.     (GTCY_Labels), (ULONG)&CY_MIL0Labels[ 0 ], (TAG_DONE),
  91.     (GTCY_Labels), (ULONG)&CY_SECS0Labels[ 0 ], (GTCY_Active), 1, (TAG_DONE),
  92.     (GTCY_Labels), (ULONG)&CY_CYCLE0Labels[ 0 ], (TAG_DONE),
  93.     (GT_Underscore), '_', (TAG_DONE),
  94.     (GT_Underscore), '_', (TAG_DONE)
  95. };
  96.  
  97. static UWORD ComputeX( UWORD value )
  98. {
  99.     return(( UWORD )((( FontX * value ) + 3 ) / 6 ));
  100. }
  101.  
  102. static UWORD ComputeY( UWORD value )
  103. {
  104.     return(( UWORD )((( FontY * value ) + 4 ) / 9 ));
  105. }
  106.  
  107. static void ComputeFont( UWORD width, UWORD height )
  108. {
  109.     Forbid();
  110.     Font = &Attr;
  111.     Font->ta_Name = (STRPTR)GfxBase->DefaultFont->tf_Message.mn_Node.ln_Name;
  112.     Font->ta_YSize = FontY = GfxBase->DefaultFont->tf_YSize;
  113.     FontX = GfxBase->DefaultFont->tf_XSize;
  114.     Permit();
  115.  
  116.     OffX = Scr->WBorLeft;
  117.     OffY = Scr->RastPort.TxHeight + Scr->WBorTop + 1;
  118.  
  119.     if ( width && height ) {
  120.         if (( ComputeX( width ) + OffX + Scr->WBorRight ) > Scr->Width )
  121.             goto UseTopaz;
  122.         if (( ComputeY( height ) + OffY + Scr->WBorBottom ) > Scr->Height )
  123.             goto UseTopaz;
  124.     }
  125.     return;
  126.  
  127. UseTopaz:
  128.     Font->ta_Name = (STRPTR)"topaz.font";
  129.     FontX = FontY = Font->ta_YSize = 8;
  130. }
  131.  
  132. int SetupScreen( void )
  133. {
  134.     if ( ! ( Scr = LockPubScreen( PubScreenName )))
  135.         return( 1L );
  136.  
  137.     ComputeFont( 0, 0 );
  138.  
  139.     if ( ! ( VisualInfo = GetVisualInfo( Scr, TAG_DONE )))
  140.         return( 2L );
  141.  
  142.     return( 0L );
  143. }
  144.  
  145. void CloseDownScreen( void )
  146. {
  147.     if ( VisualInfo ) {
  148.         FreeVisualInfo( VisualInfo );
  149.         VisualInfo = NULL;
  150.     }
  151.  
  152.     if ( Scr        ) {
  153.         UnlockPubScreen( NULL, Scr );
  154.         Scr = NULL;
  155.     }
  156. }
  157.  
  158. int HandleClockIDCMP( void )
  159. {
  160.     struct IntuiMessage    *m;
  161.     int            (*func)();
  162.     BOOL            running = TRUE;
  163.  
  164.     while( m = GT_GetIMsg( ClockWnd->UserPort )) {
  165.  
  166.         CopyMem(( char * )m, ( char * )&ClockMsg, (long)sizeof( struct IntuiMessage ));
  167.  
  168.         GT_ReplyIMsg( m );
  169.  
  170.         switch ( ClockMsg.Class ) {
  171.  
  172.             case    IDCMP_REFRESHWINDOW:
  173.                 GT_BeginRefresh( ClockWnd );
  174.                 GT_EndRefresh( ClockWnd, TRUE );
  175.                 break;
  176.  
  177.             case    IDCMP_VANILLAKEY:
  178.                 running = ClockVanillaKey();
  179.                 break;
  180.  
  181.             case    IDCMP_GADGETUP:
  182.             case    IDCMP_GADGETDOWN:
  183.                 func = ( void * )(( struct Gadget * )ClockMsg.IAddress )->UserData;
  184.                 running = func();
  185.                 break;
  186.         }
  187.     }
  188.     return( running );
  189. }
  190.  
  191. int OpenClockWindow( void )
  192. {
  193.     struct NewGadget    ng;
  194.     struct Gadget    *g;
  195.     UWORD        lc, tc;
  196.     UWORD        wleft = ClockLeft, wtop = ClockTop, ww, wh;
  197.  
  198.     ComputeFont( ClockWidth, ClockHeight );
  199.  
  200.     ww = ComputeX( ClockWidth );
  201.     wh = ComputeY( ClockHeight );
  202.  
  203.     if (( wleft + ww + OffX + Scr->WBorRight ) > Scr->Width ) wleft = Scr->Width - ww;
  204.     if (( wtop + wh + OffY + Scr->WBorBottom ) > Scr->Height ) wtop = Scr->Height - wh;
  205.  
  206.     if ( ! ( ClockFont = OpenDiskFont( Font )))
  207.         return( 5L );
  208.  
  209.     if ( ! ( g = CreateContext( &ClockGList )))
  210.         return( 1L );
  211.  
  212.     for( lc = 0, tc = 0; lc < Clock_CNT; lc++ ) {
  213.  
  214.         CopyMem((char * )&ClockNGad[ lc ], (char * )&ng, (long)sizeof( struct NewGadget ));
  215.  
  216.         ng.ng_VisualInfo = VisualInfo;
  217.         ng.ng_TextAttr   = Font;
  218.         ng.ng_LeftEdge   = OffX + ComputeX( ng.ng_LeftEdge );
  219.         ng.ng_TopEdge    = OffY + ComputeY( ng.ng_TopEdge );
  220.         ng.ng_Width      = ComputeX( ng.ng_Width );
  221.         ng.ng_Height     = ComputeY( ng.ng_Height);
  222.  
  223.         ClockGadgets[ lc ] = g = CreateGadgetA((ULONG)ClockGTypes[ lc ], g, &ng, ( struct TagItem * )&ClockGTags[ tc ] );
  224.  
  225.         while( ClockGTags[ tc ] ) tc += 2;
  226.         tc++;
  227.  
  228.         if ( NOT g )
  229.             return( 2L );
  230.     }
  231.  
  232.     if ( ! ( ClockWnd = OpenWindowTags( NULL,
  233.                 WA_Left,    wleft,
  234.                 WA_Top,        wtop,
  235.                 WA_Width,    ww + OffX + Scr->WBorRight,
  236.                 WA_Height,    wh + OffY + Scr->WBorBottom,
  237.                 WA_IDCMP,    BUTTONIDCMP|SLIDERIDCMP|CYCLEIDCMP|IDCMP_VANILLAKEY|IDCMP_REFRESHWINDOW,
  238.                 WA_Flags,    WFLG_DRAGBAR|WFLG_DEPTHGADGET|WFLG_SMART_REFRESH|WFLG_ACTIVATE|WFLG_RMBTRAP,
  239.                 WA_Gadgets,    ClockGList,
  240.                 WA_Title,    ClockWdt,
  241.                 WA_ScreenTitle,    "Clock Prefs",
  242.                 TAG_DONE )))
  243.     return( 4L );
  244.  
  245.     GT_RefreshWindow( ClockWnd, NULL );
  246.  
  247.     return( 0L );
  248. }
  249.  
  250. void CloseClockWindow( void )
  251. {
  252.     if ( ClockWnd        ) {
  253.         CloseWindow( ClockWnd );
  254.         ClockWnd = NULL;
  255.     }
  256.  
  257.     if ( ClockGList      ) {
  258.         FreeGadgets( ClockGList );
  259.         ClockGList = NULL;
  260.     }
  261.  
  262.     if ( ClockFont ) {
  263.         CloseFont( ClockFont );
  264.         ClockFont = NULL;
  265.     }
  266. }
  267.  
  268.