home *** CD-ROM | disk | FTP | other *** search
/ Gold Fish 1 / GoldFishApril1994_CD2.img / d4xx / d456 / cmanual / acm1.lzh / Gadgets / Example8.c < prev    next >
C/C++ Source or Header  |  1990-01-30  |  9KB  |  256 lines

  1. /* Example8                                                           */
  2. /* This program will open a normal window which is connected to the   */
  3. /* Workbench Screen. The window will use all System Gadgets, and will */
  4. /* close first when the user has selected the System gadget Close     */
  5. /* window. Inside the window we have put an Integer gadget.           */
  6.  
  7.  
  8.  
  9. #include <intuition/intuition.h>
  10.  
  11.  
  12.  
  13. struct IntuitionBase *IntuitionBase;
  14.  
  15.  
  16.  
  17. /* THE INTEGER GADGET's STRUCTURES: */
  18.  
  19. /* The coordinates for the box: */
  20. SHORT my_points[]=
  21. {
  22.    -7, -4, /* Start at position (-7, -4) */
  23.   200, -4, /* Draw a line to the right to position (200,-4) */
  24.   200, 11, /* Draw a line down to position (200,11) */
  25.    -7, 11, /* Draw a line to the right to position (-7,11) */
  26.    -7, -4  /* Finish of by drawing a line up to position (-7,-4) */ 
  27. };
  28.  
  29. /* The Border structure: */
  30. struct Border my_border=
  31. {
  32.   0, 0,        /* LeftEdge, TopEdge. */
  33.   1,           /* FrontPen, colour register 1. */
  34.   0,           /* BackPen, for the moment unused. */
  35.   JAM1,        /* DrawMode, draw the lines with colour 1. */
  36.   5,           /* Count, 5 pair of coordinates in the array. */
  37.   my_points,   /* XY, pointer to the array with the coordinates. */
  38.   NULL,        /* NextBorder, no other Border structures are connected. */
  39. };
  40.  
  41.  
  42.  
  43. /* The IntuiText structure: */
  44. struct IntuiText my_text=
  45. {
  46.   1,         /* FrontPen, colour register 1. */
  47.   0,         /* BackPen, colour register 0. */
  48.   JAM1,      /* DrawMode, draw the characters with colour 1, do not */
  49.              /* change the background. */ 
  50.   -37, 0,    /* LeftEdge, TopEdge. */
  51.   NULL,      /* ITextFont, use default font. */
  52.   "Nr:",     /* IText, the text that will be printed. */
  53.   NULL,      /* NextText, no other IntuiText structures. */
  54. };
  55.  
  56.  
  57.  
  58. UBYTE my_buffer[25]; /* 25 characters including the NULL-sign. */
  59. UBYTE my_undo_buffer[25]; /* Must be at least as big as my_buffer. */
  60.  
  61.  
  62.  
  63. struct StringInfo my_string_info=
  64. {
  65.   my_buffer,       /* Buffer, pointer to a null-terminated string. */
  66.   my_undo_buffer,  /* UndoBuffer, pointer to a null-terminated string. */
  67.                    /* (Remember my_buffer is equal to &my_buffer[0]) */
  68.   0,               /* BufferPos, initial position of the cursor. */
  69.   25,              /* MaxChars, 25 characters + null-sign ('\0'). */
  70.   0,               /* DispPos, first character in the string should be */
  71.                    /* first character in the display. */
  72.  
  73.   /* Intuition initializes and maintaines these variables: */
  74.  
  75.   0,               /* UndoPos */
  76.   0,               /* NumChars */
  77.   0,               /* DispCount */
  78.   0, 0,            /* CLeft, CTop */
  79.   NULL,            /* LayerPtr */
  80.   NULL,            /* LongInt */
  81.   NULL,            /* AltKeyMap */
  82. };
  83.  
  84.  
  85. struct Gadget my_gadget=
  86. {
  87.   NULL,          /* NextGadget, no more gadgets in the list. */
  88.   68,            /* LeftEdge, 68 pixels out. */
  89.   30,            /* TopEdge, 30 lines down. */
  90.   198,           /* Width, 198 pixels wide. */
  91.   8,             /* Height, 8 pixels lines heigh. */
  92.   GADGHCOMP,     /* Flags, draw the select box in the complement */
  93.                  /* colours. Note: it actually only the cursor which */
  94.                  /* will be drawn in the complement colours (yellow). */
  95.                  /* If you set the flag GADGHNONE the cursor will not be */
  96.                  /* highlighted, and the user will therefore not be able */
  97.                  /* to see it. */
  98.   GADGIMMEDIATE| /* Activation, our program will recieve a message when */
  99.   RELVERIFY|     /* the user has selected this gadget, and when the user */
  100.                  /* has released it. */ 
  101.   LONGINT,       /* An Integer gadget. */
  102.   STRGADGET,     /* GadgetType, a String gadget. */
  103.   (APTR) &my_border, /* GadgetRender, a pointer to our Border structure. */
  104.   NULL,          /* SelectRender, NULL since we do not supply the gadget */
  105.                  /* with an alternative image. */
  106.   &my_text,      /* GadgetText, a pointer to our IntuiText structure. */
  107.   NULL,          /* MutualExclude, no mutual exclude. */
  108.   (APTR) &my_string_info, /* SpecialInfo, a pointer to a StringInfo str. */
  109.   0,             /* GadgetID, no id. */
  110.   NULL           /* UserData, no user data connected to the gadget. */
  111. };
  112.  
  113.  
  114.  
  115. /* Declare a pointer to a Window structure: */ 
  116. struct Window *my_window;
  117.  
  118. /* Declare and initialize your NewWindow structure: */
  119. struct NewWindow my_new_window=
  120. {
  121.   50,            /* LeftEdge    x position of the window. */
  122.   25,            /* TopEdge     y positio of the window. */
  123.   320,           /* Width       320 pixels wide. */
  124.   100,           /* Height      100 lines high. */
  125.   0,             /* DetailPen   Text should be drawn with colour reg. 0 */
  126.   1,             /* BlockPen    Blocks should be drawn with colour reg. 1 */
  127.   CLOSEWINDOW|   /* IDCMPFlags  The window will give us a message if the */
  128.                  /*             user has selected the Close window gad, */
  129.   GADGETDOWN|    /*             or a gadget has been pressed on, or */
  130.   GADGETUP,      /*             a gadge has been released. */
  131.   SMART_REFRESH| /* Flags       Intuition should refresh the window. */
  132.   WINDOWCLOSE|   /*             Close Gadget. */
  133.   WINDOWDRAG|    /*             Drag gadget. */
  134.   WINDOWDEPTH|   /*             Depth arrange Gadgets. */
  135.   WINDOWSIZING|  /*             Sizing Gadget. */
  136.   ACTIVATE,      /*             The window should be Active when opened. */
  137.   &my_gadget,    /* FirstGadget A pointer to the String gadget. */
  138.   NULL,          /* CheckMark   Use Intuition's default CheckMark. */
  139.   "Integer Window",/* Title       Title of the window. */
  140.   NULL,          /* Screen      Connected to the Workbench Screen. */
  141.   NULL,          /* BitMap      No Custom BitMap. */
  142.   320,           /* MinWidth    We will not allow the window to become */
  143.   50,            /* MinHeight   smaller than 320 x 50, and not bigger */
  144.   640,           /* MaxWidth    than 640 x 200. */
  145.   200,           /* MaxHeight */
  146.   WBENCHSCREEN   /* Type        Connected to the Workbench Screen. */
  147. };
  148.  
  149.  
  150.  
  151. main()
  152. {
  153.   /* Boolean variable used for the while loop: */
  154.   BOOL close_me;
  155.  
  156.   /* Declare a variable in which we will store the IDCMP flag: */
  157.   ULONG class;
  158.  
  159.   /* Declare a pointer to an IntuiMessage structure: */
  160.   struct IntuiMessage *my_message;
  161.  
  162.  
  163.  
  164.   /* Put an integer value in the string: */
  165.   /* This is very important! */
  166.   strcpy( my_buffer, "0" );
  167.  
  168.  
  169.  
  170.   /* Before we can use Intuition we need to open the Intuition Library: */
  171.   IntuitionBase = (struct IntuitionBase *)
  172.     OpenLibrary( "intuition.library", 0 );
  173.   
  174.   if( IntuitionBase == NULL )
  175.     exit(); /* Could NOT open the Intuition Library! */
  176.  
  177.  
  178.  
  179.   /* We will now try to open the window: */
  180.   my_window = (struct Window *) OpenWindow( &my_new_window );
  181.   
  182.   /* Have we opened the window succesfully? */
  183.   if(my_window == NULL)
  184.   {
  185.     /* Could NOT open the Window! */
  186.     
  187.     /* Close the Intuition Library since we have opened it: */
  188.     CloseLibrary( IntuitionBase );
  189.  
  190.     exit();  
  191.   }
  192.  
  193.  
  194.  
  195.   /* We have opened the window, and everything seems to be OK. */
  196.  
  197.  
  198.  
  199.   close_me = FALSE;
  200.  
  201.   /* Stay in the while loop until the user has selected the Close window */
  202.   /* gadget: */
  203.   while( close_me == FALSE )
  204.   {
  205.     /* Wait until we have recieved a message: */
  206.     Wait( 1 << my_window->UserPort->mp_SigBit );
  207.  
  208.     /* Collect the message: */
  209.     my_message = (struct IntuiMessage *) GetMsg( my_window->UserPort );
  210.  
  211.     /* Have we collected the message sucessfully? */
  212.     if(my_message)
  213.     {
  214.       /* After we have collected the message we can read it, and save any */
  215.       /* important values which we maybe want to check later: */
  216.       class = my_message->Class;      /* Save the IDCMP flag. */
  217.   
  218.       /* After we have read it we reply as fast as possible: */
  219.       /* REMEMBER! Do never try to read a message after you have replied! */
  220.       /* Some other process has maybe changed it. */
  221.       ReplyMsg( my_message );
  222.   
  223.       /* Check which IDCMP flag was sent: */
  224.       switch( class )
  225.       {
  226.         case CLOSEWINDOW:  /* The user selected the Close window gadget! */
  227.                close_me=TRUE;
  228.                break;
  229.                
  230.         case GADGETDOWN:   /* The user has selected the Integer gadget: */
  231.                            /* (Clicked inside the select box) */
  232.                printf("Integer gadget selected.\n");
  233.                break;
  234.                
  235.         case GADGETUP:     /* The user has released the Integer gadget: */
  236.                            /* (Pressed ENTER or RETURN) */
  237.                printf("Integer gadget released.\n");
  238.                /* Print out the integer value: */
  239.                printf("Nr: %d\n\n", my_string_info.LongInt);
  240.                break;
  241.       }
  242.     }
  243.   }
  244.  
  245.  
  246.   /* We should always close the windows we have opened before we leave: */
  247.   CloseWindow( my_window );
  248.  
  249.  
  250.  
  251.   /* Close the Intuition Library since we have opened it: */
  252.   CloseLibrary( IntuitionBase );
  253.  
  254.   /* THE END */
  255. }
  256.