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

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