home *** CD-ROM | disk | FTP | other *** search
/ BCI NET / BCI NET Dec 94.iso / archives / programming / source / gblanker3.5.src.lha / GSource / Blankers / Text / Text.c < prev    next >
Encoding:
C/C++ Source or Header  |  1994-03-13  |  6.5 KB  |  256 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 "Text.h"
  26.  
  27. struct Screen         *Scr = NULL;
  28. UBYTE                 *PubScreenName = NULL;
  29. APTR                   VisualInfo = NULL;
  30. struct Window         *TextWnd = NULL;
  31. struct Gadget         *TextGList = NULL;
  32. struct IntuiMessage    TextMsg;
  33. struct Gadget         *TextGadgets[8];
  34. UWORD                  TextLeft = 0;
  35. UWORD                  TextTop = 12;
  36. UWORD                  TextWidth = 325;
  37. UWORD                  TextHeight = 62;
  38. UBYTE                 *TextWdt = (UBYTE *)"Text Prefs";
  39. struct TextAttr       *Font, Attr;
  40. UWORD                  FontX, FontY;
  41. UWORD                  OffX, OffY;
  42. struct TextFont       *TextFont = NULL;
  43.  
  44. UBYTE *CY_CYCLE0Labels[] = {
  45.     (UBYTE *)"Cycle",
  46.     (UBYTE *)"Random",
  47.     (UBYTE *)"White",
  48.     (UBYTE *)"Copper",
  49.     NULL };
  50.  
  51. UWORD TextGTypes[] = {
  52.     STRING_KIND,
  53.     BUTTON_KIND,
  54.     BUTTON_KIND,
  55.     BUTTON_KIND,
  56.     SLIDER_KIND,
  57.     CYCLE_KIND,
  58.     BUTTON_KIND,
  59.     BUTTON_KIND
  60. };
  61.  
  62. struct NewGadget TextNGad[] = {
  63.     53, 4, 267, 16, (UBYTE *)"St_ring", NULL, GD_ST_TXT, PLACETEXT_LEFT, NULL, (APTR)ST_TXTClicked,
  64.     4, 24, 76, 15, (UBYTE *)"_Font...", NULL, GD_BT_FONT, PLACETEXT_IN, NULL, (APTR)BT_FONTClicked,
  65.     4, 43, 76, 15, (UBYTE *)"_Save", NULL, GD_BT_SAVE, PLACETEXT_IN, NULL, (APTR)BT_SAVEClicked,
  66.     84, 43, 76, 15, (UBYTE *)"_Test", NULL, GD_BT_TEST, PLACETEXT_IN, NULL, (APTR)BT_TESTClicked,
  67.     203, 24, 91, 15, (UBYTE *)"De_lay", NULL, GD_SL_DELAY, PLACETEXT_LEFT, NULL, (APTR)SL_DELAYClicked,
  68.     84, 24, 76, 15, NULL, NULL, GD_CY_CYCLE, 0, NULL, (APTR)CY_CYCLEClicked,
  69.     244, 43, 76, 15, (UBYTE *)"_Cancel", NULL, GD_BT_CANCEL, PLACETEXT_IN, NULL, (APTR)BT_CANCELClicked,
  70.     164, 43, 76, 15, (UBYTE *)"_Display", NULL, GD_BT_SCREEN, PLACETEXT_IN, NULL, (APTR)BT_SCREENClicked
  71. };
  72.  
  73. ULONG TextGTags[] = {
  74.     (GTST_MaxChars), 128, (GT_Underscore), '_', (TAG_DONE),
  75.     (GT_Underscore), '_', (TAG_DONE),
  76.     (GT_Underscore), '_', (TAG_DONE),
  77.     (GT_Underscore), '_', (TAG_DONE),
  78.     (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),
  79.     (GTCY_Labels), (ULONG)&CY_CYCLE0Labels[ 0 ], (TAG_DONE),
  80.     (GT_Underscore), '_', (TAG_DONE),
  81.     (GT_Underscore), '_', (TAG_DONE)
  82. };
  83.  
  84. static UWORD ComputeX( UWORD value )
  85. {
  86.     return(( UWORD )((( FontX * value ) + 3 ) / 6 ));
  87. }
  88.  
  89. static UWORD ComputeY( UWORD value )
  90. {
  91.     return(( UWORD )((( FontY * value ) + 4 ) / 9 ));
  92. }
  93.  
  94. static void ComputeFont( UWORD width, UWORD height )
  95. {
  96.     Forbid();
  97.     Font = &Attr;
  98.     Font->ta_Name = (STRPTR)GfxBase->DefaultFont->tf_Message.mn_Node.ln_Name;
  99.     Font->ta_YSize = FontY = GfxBase->DefaultFont->tf_YSize;
  100.     FontX = GfxBase->DefaultFont->tf_XSize;
  101.     Permit();
  102.  
  103.     OffX = Scr->WBorLeft;
  104.     OffY = Scr->RastPort.TxHeight + Scr->WBorTop + 1;
  105.  
  106.     if ( width && height ) {
  107.         if (( ComputeX( width ) + OffX + Scr->WBorRight ) > Scr->Width )
  108.             goto UseTopaz;
  109.         if (( ComputeY( height ) + OffY + Scr->WBorBottom ) > Scr->Height )
  110.             goto UseTopaz;
  111.     }
  112.     return;
  113.  
  114. UseTopaz:
  115.     Font->ta_Name = (STRPTR)"topaz.font";
  116.     FontX = FontY = Font->ta_YSize = 8;
  117. }
  118.  
  119. int SetupScreen( void )
  120. {
  121.     if ( ! ( Scr = LockPubScreen( PubScreenName )))
  122.         return( 1L );
  123.  
  124.     ComputeFont( 0, 0 );
  125.  
  126.     if ( ! ( VisualInfo = GetVisualInfo( Scr, TAG_DONE )))
  127.         return( 2L );
  128.  
  129.     return( 0L );
  130. }
  131.  
  132. void CloseDownScreen( void )
  133. {
  134.     if ( VisualInfo ) {
  135.         FreeVisualInfo( VisualInfo );
  136.         VisualInfo = NULL;
  137.     }
  138.  
  139.     if ( Scr        ) {
  140.         UnlockPubScreen( NULL, Scr );
  141.         Scr = NULL;
  142.     }
  143. }
  144.  
  145. int HandleTextIDCMP( void )
  146. {
  147.     struct IntuiMessage    *m;
  148.     int            (*func)();
  149.     BOOL            running = TRUE;
  150.  
  151.     while( m = GT_GetIMsg( TextWnd->UserPort )) {
  152.  
  153.         CopyMem(( char * )m, ( char * )&TextMsg, (long)sizeof( struct IntuiMessage ));
  154.  
  155.         GT_ReplyIMsg( m );
  156.  
  157.         switch ( TextMsg.Class ) {
  158.  
  159.             case    IDCMP_REFRESHWINDOW:
  160.                 GT_BeginRefresh( TextWnd );
  161.                 GT_EndRefresh( TextWnd, TRUE );
  162.                 break;
  163.  
  164.             case    IDCMP_VANILLAKEY:
  165.                 running = TextVanillaKey();
  166.                 break;
  167.  
  168.             case    IDCMP_GADGETUP:
  169.             case    IDCMP_GADGETDOWN:
  170.                 func = ( void * )(( struct Gadget * )TextMsg.IAddress )->UserData;
  171.                 running = func();
  172.                 break;
  173.         }
  174.     }
  175.     return( running );
  176. }
  177.  
  178. int OpenTextWindow( void )
  179. {
  180.     struct NewGadget    ng;
  181.     struct Gadget    *g;
  182.     UWORD        lc, tc;
  183.     UWORD        wleft = TextLeft, wtop = TextTop, ww, wh;
  184.  
  185.     ComputeFont( TextWidth, TextHeight );
  186.  
  187.     ww = ComputeX( TextWidth );
  188.     wh = ComputeY( TextHeight );
  189.  
  190.     if (( wleft + ww + OffX + Scr->WBorRight ) > Scr->Width ) wleft = Scr->Width - ww;
  191.     if (( wtop + wh + OffY + Scr->WBorBottom ) > Scr->Height ) wtop = Scr->Height - wh;
  192.  
  193.     if ( ! ( TextFont = OpenDiskFont( Font )))
  194.         return( 5L );
  195.  
  196.     if ( ! ( g = CreateContext( &TextGList )))
  197.         return( 1L );
  198.  
  199.     for( lc = 0, tc = 0; lc < Text_CNT; lc++ ) {
  200.  
  201.         CopyMem((char * )&TextNGad[ lc ], (char * )&ng, (long)sizeof( struct NewGadget ));
  202.  
  203.         ng.ng_VisualInfo = VisualInfo;
  204.         ng.ng_TextAttr   = Font;
  205.         ng.ng_LeftEdge   = OffX + ComputeX( ng.ng_LeftEdge );
  206.         ng.ng_TopEdge    = OffY + ComputeY( ng.ng_TopEdge );
  207.         ng.ng_Width      = ComputeX( ng.ng_Width );
  208.         ng.ng_Height     = ComputeY( ng.ng_Height);
  209.  
  210.         TextGadgets[ lc ] = g = CreateGadgetA((ULONG)TextGTypes[ lc ], g, &ng, ( struct TagItem * )&TextGTags[ tc ] );
  211.  
  212.         while( TextGTags[ tc ] ) tc += 2;
  213.         tc++;
  214.  
  215.         if ( NOT g )
  216.             return( 2L );
  217.     }
  218.  
  219.     if ( ! ( TextWnd = OpenWindowTags( NULL,
  220.                 WA_Left,    wleft,
  221.                 WA_Top,        wtop,
  222.                 WA_Width,    ww + OffX + Scr->WBorRight,
  223.                 WA_Height,    wh + OffY + Scr->WBorBottom,
  224.                 WA_IDCMP,    STRINGIDCMP|BUTTONIDCMP|SLIDERIDCMP|CYCLEIDCMP|IDCMP_VANILLAKEY|IDCMP_REFRESHWINDOW,
  225.                 WA_Flags,    WFLG_DRAGBAR|WFLG_DEPTHGADGET|WFLG_SMART_REFRESH|WFLG_ACTIVATE|WFLG_RMBTRAP,
  226.                 WA_Gadgets,    TextGList,
  227.                 WA_Title,    TextWdt,
  228.                 WA_ScreenTitle,    "Text Prefs",
  229.                 WA_PubScreen,    Scr,
  230.                 TAG_DONE )))
  231.     return( 4L );
  232.  
  233.     GT_RefreshWindow( TextWnd, NULL );
  234.  
  235.     return( 0L );
  236. }
  237.  
  238. void CloseTextWindow( void )
  239. {
  240.     if ( TextWnd        ) {
  241.         CloseWindow( TextWnd );
  242.         TextWnd = NULL;
  243.     }
  244.  
  245.     if ( TextGList      ) {
  246.         FreeGadgets( TextGList );
  247.         TextGList = NULL;
  248.     }
  249.  
  250.     if ( TextFont ) {
  251.         CloseFont( TextFont );
  252.         TextFont = NULL;
  253.     }
  254. }
  255.  
  256.