home *** CD-ROM | disk | FTP | other *** search
/ World of A1200 / World_Of_A1200.iso / datafiles / text / c_manual / intuition / gadgets / example10.c < prev    next >
C/C++ Source or Header  |  1995-02-27  |  11KB  |  301 lines

  1. /***********************************************************/
  2. /*                                                         */
  3. /* Amiga C Encyclopedia (ACE) V3.0      Amiga C Club (ACC) */
  4. /* -------------------------------      ------------------ */
  5. /*                                                         */
  6. /* Book:    ACM Intuition               Amiga C Club       */
  7. /* Chapter: Gadgets                     Tulevagen 22       */
  8. /* File:    Example10.c                 181 41  LIDINGO    */
  9. /* Author:  Anders Bjerin               SWEDEN             */
  10. /* Date:    92-05-01                                       */
  11. /* Version: 1.10                                           */
  12. /*                                                         */
  13. /*   Copyright 1992, Anders Bjerin - Amiga C Club (ACC)    */
  14. /*                                                         */
  15. /* Registered members may use this program freely in their */
  16. /*     own commercial/noncommercial programs/articles.     */
  17. /*                                                         */
  18. /***********************************************************/
  19.  
  20. /* This program will open a normal window which is connected to the   */
  21. /* Workbench Screen. The window will use all System Gadgets, and will */
  22. /* close first when the user has selected the System gadget Close     */
  23. /* window. Inside the window we have put a Proportional gadget which  */
  24. /* uses a custom image knob.                                          */ 
  25.  
  26.  
  27.  
  28. #include <intuition/intuition.h>
  29.  
  30.  
  31.  
  32. struct IntuitionBase *IntuitionBase;
  33.  
  34.  
  35.  
  36. /* THE PROPORTIONAL GADGET's STRUCTURES: */
  37.  
  38. /* The IntuiText structure: */
  39. struct IntuiText my_text=
  40. {
  41.   1,         /* FrontPen, colour register 1. */
  42.   0,         /* BackPen, colour register 0. */
  43.   JAM1,      /* DrawMode, draw the characters with colour 1, do not */
  44.              /* change the background. */ 
  45.   -65, 8,    /* LeftEdge, TopEdge. */
  46.   NULL,      /* ITextFont, use default font. */
  47.   "Volume:", /* IText, the text that will be printed. */
  48.   NULL,      /* NextText, no other IntuiText structures. */
  49. };
  50.  
  51.  
  52. /* Image data for the knob: */
  53. /* Remember that Image data must ALWAYS be in chip memory! */
  54. USHORT chip my_knob_data[80]=
  55. {
  56.   0x01E0,0x0000, /* Bitplane ZERO */
  57.   0x03F0,0x0000,
  58.   0x03F0,0x0000,
  59.   0x03F0,0x0000,
  60.   0x03F0,0x0000,
  61.   0x03F0,0x0000,
  62.   0x03F0,0x0000,
  63.   0x07F8,0x0000,
  64.   0x7BF7,0x8000,
  65.   0x83F0,0x4000,
  66.   0x83F0,0x4000,
  67.   0x7BF7,0x8000,
  68.   0x07F8,0x0000,
  69.   0x03F0,0x0000,
  70.   0x03F0,0x0000,
  71.   0x03F0,0x0000,
  72.   0x03F0,0x0000,
  73.   0x03F0,0x0000,
  74.   0x03F0,0x0000,
  75.   0x01E0,0x0000,
  76.  
  77.   0x0000,0x0000, /* Bitplane ONE */
  78.   0x01E0,0x0000,
  79.   0x01E0,0x0000,
  80.   0x01E0,0x0000,
  81.   0x01E0,0x0000,
  82.   0x01E0,0x0000,
  83.   0x01E0,0x0000,
  84.   0x01E0,0x0000,
  85.   0x05E8,0x0000,
  86.   0x7DEF,0x8000,
  87.   0x7DEF,0x8000,
  88.   0x05E8,0x0000,
  89.   0x01E0,0x0000,
  90.   0x01E0,0x0000,
  91.   0x01E0,0x0000,
  92.   0x01E0,0x0000,
  93.   0x01E0,0x0000,
  94.   0x01E0,0x0000,
  95.   0x01E0,0x0000,
  96.   0x0000,0x0000
  97. };
  98.  
  99. /* The Image structure for the knob: */
  100. struct Image my_knob=
  101. {
  102.   0, 0,         /* LeftEdge, TopEdge */
  103.   18, 20,       /* Width, Height */
  104.   2,            /* Depth */
  105.     my_knob_data, /* ImageData */
  106.   0x03, 0x00,   /* PlanePick, PlaneOnOff */
  107.   NULL          /* NextImage */
  108. };
  109.  
  110.  
  111. struct PropInfo my_prop_info=
  112. {
  113.   FREEHORIZ,      /* Flags, the knob should be moved horizontally. */
  114.   0,              /* HorizPot, start position of the knob. */
  115.   0,              /* VertPot, 0 since we will not move the knob hor. */
  116.   MAXBODY * 1/64, /* HorizBody, 64 steps. */
  117.   0,              /* VertBody, 0 since we will not move the knob hor. */
  118.  
  119.   /* These variables are initialized and maintained by Intuition: */
  120.  
  121.   0,              /* CWidth */
  122.   0,              /* CHeight */
  123.   0, 0,           /* HPotRes, VPotRes */
  124.   0,              /* LeftBorder */
  125.   0               /* TopBorder */
  126. };
  127.  
  128.  
  129. struct Gadget my_gadget=
  130. {
  131.   NULL,            /* NextGadget, no more gadgets in the list. */
  132.   80,              /* LeftEdge, 80 pixels out. */
  133.   30,              /* TopEdge, 30 lines down. */
  134.   200,             /* Width, 200 pixels wide. */
  135.   24,              /* Height, 24 pixels lines heigh. */
  136.   GADGHNONE,       /* Flags, no highlightning. */
  137.   GADGIMMEDIATE|   /* Activation, our program will recieve a message */
  138.   RELVERIFY,       /* when the user has selected this gadget, and when */
  139.                    /* the user has released it. */ 
  140.   PROPGADGET,      /* GadgetType, a Proportional gadget. */
  141.   (APTR) &my_knob, /* GadgetRender, a pointer to our knob Image str. */
  142.   NULL,            /* SelectRender, NULL since we do not supply the */
  143.                    /* gadget with an alternative image. */
  144.   &my_text,        /* GadgetText, volume. */
  145.   NULL,            /* MutualExclude, no mutual exclude. */
  146.   (APTR) &my_prop_info, /* SpecialInfo, pointer to a PropInfo structure. */
  147.   0,               /* GadgetID, no id. */
  148.   NULL             /* UserData, no user data connected to the gadget. */
  149. };
  150.  
  151.  
  152.  
  153. /* Declare a pointer to a Window structure: */ 
  154. struct Window *my_window;
  155.  
  156. /* Declare and initialize your NewWindow structure: */
  157. struct NewWindow my_new_window=
  158. {
  159.   50,            /* LeftEdge    x position of the window. */
  160.   25,            /* TopEdge     y positio of the window. */
  161.   320,           /* Width       320 pixels wide. */
  162.   100,           /* Height      100 lines high. */
  163.   0,             /* DetailPen   Text should be drawn with colour reg. 0 */
  164.   1,             /* BlockPen    Blocks should be drawn with colour reg. 1 */
  165.   CLOSEWINDOW|   /* IDCMPFlags  The window will give us a message if the */
  166.                  /*             user has selected the Close window gad, */
  167.   GADGETDOWN|    /*             or a gadget has been pressed on, or */
  168.   GADGETUP,      /*             a gadge has been released. */
  169.   SMART_REFRESH| /* Flags       Intuition should refresh the window. */
  170.   WINDOWCLOSE|   /*             Close Gadget. */
  171.   WINDOWDRAG|    /*             Drag gadget. */
  172.   WINDOWDEPTH|   /*             Depth arrange Gadgets. */
  173.   WINDOWSIZING|  /*             Sizing Gadget. */
  174.   ACTIVATE,      /*             The window should be Active when opened. */
  175.   &my_gadget,    /* FirstGadget A pointer to the String gadget. */
  176.   NULL,          /* CheckMark   Use Intuition's default CheckMark. */
  177.   "Proportional Window", /* Title Title of the window. */
  178.   NULL,          /* Screen      Connected to the Workbench Screen. */
  179.   NULL,          /* BitMap      No Custom BitMap. */
  180.   320,           /* MinWidth    We will not allow the window to become */
  181.   60,            /* MinHeight   smaller than 320 x 60, and not bigger */
  182.   640,           /* MaxWidth    than 640 x 200. */
  183.   200,           /* MaxHeight */
  184.   WBENCHSCREEN   /* Type        Connected to the Workbench Screen. */
  185. };
  186.  
  187.  
  188.  
  189. main()
  190. {
  191.   /* Boolean variable used for the while loop: */
  192.   BOOL close_me;
  193.  
  194.   /* Declare a variable in which we will store the IDCMP flag: */
  195.   ULONG class;
  196.  
  197.   /* Declare a pointer to an IntuiMessage structure: */
  198.   struct IntuiMessage *my_message;
  199.  
  200.  
  201.  
  202.   /* Before we can use Intuition we need to open the Intuition Library: */
  203.   IntuitionBase = (struct IntuitionBase *)
  204.     OpenLibrary( "intuition.library", 0 );
  205.   
  206.   if( IntuitionBase == NULL )
  207.     exit(); /* Could NOT open the Intuition Library! */
  208.  
  209.  
  210.  
  211.   /* We will now try to open the window: */
  212.   my_window = (struct Window *) OpenWindow( &my_new_window );
  213.   
  214.   /* Have we opened the window succesfully? */
  215.   if(my_window == NULL)
  216.   {
  217.     /* Could NOT open the Window! */
  218.     
  219.     /* Close the Intuition Library since we have opened it: */
  220.     CloseLibrary( IntuitionBase );
  221.  
  222.     exit();  
  223.   }
  224.  
  225.  
  226.  
  227.   /* We have opened the window, and everything seems to be OK. */
  228.  
  229.  
  230.  
  231.   close_me = FALSE;
  232.  
  233.   /* Stay in the while loop until the user has selected the Close window */
  234.   /* gadget: */
  235.   while( close_me == FALSE )
  236.   {
  237.     /* Wait until we have recieved a message: */
  238.     Wait( 1 << my_window->UserPort->mp_SigBit );
  239.  
  240.     /* We have now recieved one or more messages. */
  241.  
  242.     /* Since we may recieve several messages we stay in the while loop */
  243.     /* and collect, save, reply and execute the messages until there is */
  244.     /* a pause: */
  245.     while(my_message=(struct IntuiMessage *)GetMsg( my_window->UserPort))
  246.     {
  247.       /* GetMsg will return a pointer to a message if there was one, */
  248.       /* else it returns NULL. We will therefore stay in this while loop */
  249.       /* as long as there are some messages waiting in the port. */
  250.       
  251.       /* After we have collected the message we can read it, and save */
  252.       /* any important values which we maybe want to check later: */
  253.       class = my_message->Class;      /* Save the IDCMP flag. */
  254.  
  255.       /* After we have read it we reply as fast as possible: */
  256.       /* REMEMBER! Do never try to read a message after you have replied! */
  257.       /* Some other process has maybe changed it. */
  258.       ReplyMsg( my_message );
  259.  
  260.       /* Check which IDCMP flag was sent: */
  261.       switch( class )
  262.       {
  263.         case CLOSEWINDOW:  /* The user selected the Close window gadget! */
  264.                close_me=TRUE;
  265.                break;
  266.              
  267.         case GADGETDOWN:   /* The user has selected the Prop. gadget: */
  268.                printf("Proportional gadget selected.\n");
  269.                break;
  270.              
  271.         case GADGETUP:     /* The user has released the Prop. gadget: */
  272.                printf("Proportional gadget released.\n");
  273.                break;
  274.       }
  275.     }
  276.     printf("Volume= %1.0f\n\n", (float) my_prop_info.HorizPot/MAXPOT*64);
  277.   }
  278.  
  279.   /* We should always close the windows we have opened before we leave: */
  280.   CloseWindow( my_window );
  281.  
  282.  
  283.  
  284.   /* Close the Intuition Library since we have opened it: */
  285.   CloseLibrary( IntuitionBase );
  286.  
  287.   /* THE END */
  288. }
  289.  
  290. /*************************************************************************/
  291. /* EXTRA INFORMATION:                                                    */
  292. /* We will recieve a message (GADGETDOWN) when the user selects the      */
  293. /* knob, and one message (GADGETUP) when the user releases the knob. If  */
  294. /* the user on the other hand clicks inside the container (not on the    */
  295. /* knob) we will recieve both a GADGETDOWN and a GADGETUP message at the */
  296. /* same time.                                                            */
  297. /* It is because of that we need to have a while loop which collects the */
  298. /* messages once one or more has arrived. We can not as before just wait */
  299. /* and then collect one message, since there may be more in the queue.   */
  300. /*************************************************************************/
  301.