In the tutorials below, there are two things covered: the first, much longer tutorial completes your drop-down menus and makes them fully functional; the second shorter tutorial at the bottom, shows you the code for creating sound objects, and then playing and stopping the audio.
  - DROP-DOWN
    First, if you wish to experiment on my file first before implementing on your own, download the following flash file. It is set up exactly the way that we have been working with in class: LINK Second, we'll go about writing the code for the drop-down menu from scratch, beginning with the text that will fit inside of the buttons. The first line creates the array for that text; and the second line places the first text element (txtArray[0]) inside the text box of the main button. The next three lines places the next three text elements of the array (txtArray[1], txtArray[2], txtArray[3]), inside the text boxes of the option buttons. And finally, the last line, although unrelated to the text array, sets the default for the visibility of the options of the drop-down menu to false, making it invisible: 
      -   var txtArray:Array = new Array("main, "one", "two", "three");
-   menu.main.btn_txt.text=txtArray[0];
-   menu.options.opt_01.btn_txt.text=txtArray[1];
-   menu.options.opt_02.btn_txt.text=txtArray[2];
-   menu.options.opt_03.btn_txt.text=txtArray[3];
-   menu.options.visible = false;
 
  
  
  - 
    But already, despite the fact that the above code is pretty straightforward, there's a better, somewhat more efficient way of writing it, and that is using a new Actionscript element: a with statement. What this statement allows you to do is eliminate some repeated paths. In the above code where we placed text inside the option buttons, we repeated parts of the path 3 times. Such examples of repeatedly typing identical code increases the possibility of making errors, so therefore we must reduce and make it efficient here and wherever else we can. One way of doing this is using the with statement as suggest, allowing us to type that repeated part of the path only one time. See the following example: 
      -   var txtArray:Array = new Array("main, "one", "two", "three");
-   menu.main.btn_txt.text=txtArray[0];
-   menu.options.opt_01.btn_txt.text=txtArray[1];
-   menu.options.opt_02.btn_txt.text=txtArray[2];
-   menu.options.opt_03.btn_txt.text=txtArray[3];
-   with(menu.options) {
-       opt_01.btn_txt.text=txtArray[1];
-       opt_01.btn_txt.text=txtArray[2];
-       opt_01.btn_txt.text=txtArray[3];
-   }
-   menu.options.visible = false;
 
  - 
    Next, we have to add a new array. This array will contail multiple URLs. Here, in this example, I will just put a few random web addresses, but what you should use for your own projects is the file path to your various pages, the external .swf files. 
      -   var txtArray:Array = new Array("main, "one", "two", "three");
-   menu.main.btn_txt.text=txtArray[0];
-   with(menu.options) {
-       opt_01.btn_txt.text=txtArray[1];
-       opt_01.btn_txt.text=txtArray[2];
-       opt_01.btn_txt.text=txtArray[3];
-   }
-   menu.options.visible = false;
-   var address:Array = new Array();
-       address[0] = new URLRequest("http://lipsum.com");
-       address[1] = new URLRequest("html-color-codes.com");
-       address[2] = new URLRequest("http://dma-205.blogspot.com");
 
  
  
  - 
    Following this, we will create two color objects, one for the original color of the text and outline, and the other for the new color that they will change into when the user mouses over the buttons. 
      -   var txtArray:Array = new Array("main, "one", "two", "three");
-   menu.main.btn_txt.text=txtArray[0];
-   with(menu.options) {
-       opt_01.btn_txt.text=txtArray[1];
-       opt_01.btn_txt.text=txtArray[2];
-       opt_01.btn_txt.text=txtArray[3];
-   }
-   menu.options.visible = false;
-   var address:Array = new Array();
-       address[0] = new URLRequest("http://lipsum.com");
-       address[1] = new URLRequest("html-color-codes.com");
-       address[2] = new URLRequest("http://dma-205.blogspot.com");
-   var btnC_01:ColorTransform = new ColorTransform();
-       btnC_01.color=0x330066;
-   var btnC_02:ColorTransform = new ColorTransform();
-       btnC_02.color=0x3399cc;
 
  
  
  - 
    Now, in order for us to make use of those two colors, we have to create our first functions. These functions will do a few things. Most importantly, they will open and close the menu. We have done this before, and it simply entails setting the visible property to true for it to open, and then to false for it to go back to being closed. In addition to this, we want to change the colors of the main button (the button on top), the one that is always open and which triggers the opening and closing of the menu. When we mouse over it, we want the stroke color and the color of the text to change to a new color, and then, when we mouse off of it, we want those two elements to go back to their original color. You'll notice, however, that once the menu opens, that the other buttons do not change colors. We'll have to create another set of functions for that. 
      -   var txtArray:Array = new Array("main, "one", "two", "three");
-   menu.main.btn_txt.text=txtArray[0];
-   with(menu.options) {
-       opt_01.btn_txt.text=txtArray[1];
-       opt_01.btn_txt.text=txtArray[2];
-       opt_01.btn_txt.text=txtArray[3];
-   }
-   menu.options.visible = false;
-   var address:Array = new Array();
-       address[0] = new URLRequest("http://lipsum.com");
-       address[1] = new URLRequest("html-color-codes.com");
-       address[2] = new URLRequest("http://dma-205.blogspot.com");
-   var btnC_01:ColorTransform = new ColorTransform();
-       btnC_01.color=0x330066;
-   var btnC_02:ColorTransform = new ColorTransform();
-       btnC_02.color=0x3399cc;
-   function menu_open(evt:MouseEvent):void {
-       menu.options.visible=true;
-       menu.main.stroke.transform.colorTransform=btnC_01;
-       menu.main.btn_txt.transform.colorTransform=btnC_01;
-   }
-   function menu_close(evt:MouseEvent):void {
-       menu.options.visible=false;
-       menu.main.stroke.transform.colorTransform=btnC_02;
-       menu.main.btn_txt.transform.colorTransform=btnC_02;
-   }
 
  
  
  - 
    The only thing missing from the script above and which is keeping it from fully functioning are the Event Listeners. We'll create two, one for the MOUSE_OVER mouse event, and the other for the MOUSE_OUT mouse event. What is important here is WHICH object you choose. The mouse over listener is rather simple: currently, we really only have one object on the stage, and that is the main button; but the main button is inside of the menu. Since there is nothing else inside the menu currently visible for the user to interact with (not the options, nor the various buttons within the options), then which object we should choose is simple, the menu. That is what I put in front of the listener as done so below. Which object to choose for the second listener is a little more difficult since the whole menu is visible for this event. We could choose from any of the buttons available, the main, or any of the options. The difficulty is deciding which one would work the best. We can rule out the indvidual option buttons because we cannot put three objects in a listener and there'd be no logical to choose opt_01 over opt_02 or opt_03. That leaves us with the main button, the options movieclip or the whole menu movieclip. It doesn't make sense to choose the main button since the moment we'd mouse off of it to choose one of the options, the whole menu would close. With the options movieclip, recall that we created an transparent area that encompassed the entire menu and also hung off the edges of the menu. It's alpha is 0%, but that doesn't mean it isn't there, so its area is taken into consideration. This means that the area of the options movieclip is roughly the same as the menu as a whole. In fact, you could choose either object and the drop-down menu would work the same. For my own purposes, I'll choose the options object because the reason for opening the menu is to choose an option; and if I read that in the listener, it makes it more clear to me that it closes when I mouse off the options. 
      -   var txtArray:Array = new Array("main, "one", "two", "three");
-   menu.main.btn_txt.text=txtArray[0];
-   with(menu.options) {
-       opt_01.btn_txt.text=txtArray[1];
-       opt_01.btn_txt.text=txtArray[2];
-       opt_01.btn_txt.text=txtArray[3];
-   }
-   menu.options.visible = false;
-   var address:Array = new Array();
-       address[0] = new URLRequest("http://lipsum.com");
-       address[1] = new URLRequest("html-color-codes.com");
-       address[2] = new URLRequest("http://dma-205.blogspot.com");
-   var btnC_01:ColorTransform = new ColorTransform();
-       btnC_01.color=0x330066;
-   var btnC_02:ColorTransform = new ColorTransform();
-       btnC_02.color=0x3399cc;
-   function menu_open(evt:MouseEvent):void {
-       menu.options.visible=true;
-       menu.main.stroke.transform.colorTransform=btnC_01;
-       menu.main.btn_txt.transform.colorTransform=btnC_01;
-   }
-   function menu_close(evt:MouseEvent):void {
-       menu.options.visible=false;
-       menu.main.stroke.transform.colorTransform=btnC_02;
-       menu.main.btn_txt.transform.colorTransform=btnC_02;
-   }
-   menu.addEventListener(MouseEvent.MOUSE_OVER, menu_open);
-   menu.options.addEventListener(MouseEvent.MOUSE_OUT, menu_close);
 
  
  
  - 
    Now that we've successfully opened and closed the menu, we need to make the option buttons inside function properly: we first need to create functions that make the colors of the buttons change when we mouse on and off of them. The first function changes the colors of the stroke and the text to the new color, and the second function changes them back. A new term you will find here is the use of evt.currentTarget. The term evt is a kind of variable. Its first usage is inside the parentheses after the name of the function and before the term MouseEvent. What this variable contains IS the mouse event itself, and the mouse event happens to a particular object. By typing evt.currentTarget, we are selecting whatever the mouse happens to be targeting at that moment. Since the OPTIONS movieclip is what the user mouses on top of originally, something inside that movieclip is going to be the currentTarget, and that leaves us with 3 possibilities, one of the three buttons within it, opt_01, opt_02, or opt_03. So, depending on which one the user is on top of, THAT will be the currentTarget. Using this piece of code prevents us from having to write two functions for each button. Instead of writing six functions, all we have to write is two. 
      -   var txtArray:Array = new Array("main, "one", "two", "three");
-   menu.main.btn_txt.text=txtArray[0];
-   with(menu.options) {
-       opt_01.btn_txt.text=txtArray[1];
-       opt_01.btn_txt.text=txtArray[2];
-       opt_01.btn_txt.text=txtArray[3];
-   }
-   menu.options.visible = false;
-   var address:Array = new Array();
-       address[0] = new URLRequest("http://lipsum.com");
-       address[1] = new URLRequest("html-color-codes.com");
-       address[2] = new URLRequest("http://dma-205.blogspot.com");
-   var btnC_01:ColorTransform = new ColorTransform();
-       btnC_01.color=0x330066;
-   var btnC_02:ColorTransform = new ColorTransform();
-       btnC_02.color=0x3399cc;
-   function menu_open(evt:MouseEvent):void {
-       menu.options.visible=true;
-       menu.main.stroke.transform.colorTransform=btnC_01;
-       menu.main.btn_txt.transform.colorTransform=btnC_01;
-   }
-   function menu_close(evt:MouseEvent):void {
-       menu.options.visible=false;
-       menu.main.stroke.transform.colorTransform=btnC_02;
-       menu.main.btn_txt.transform.colorTransform=btnC_02;
-   }
-   function option_over(evt:MouseEvent):void{
-       evt.currentTarget.stroke.transform.colorTransform=btnC_02;
-       evt.currentTarget.btn_txt.transform.colorTransform=btnC_02;
-   }
-   function option_out(evt:MouseEvent):void{
-       evt.currentTarget.stroke.transform.colorTransform=btnC_01;
-       evt.currentTarget.btn_txt.transform.colorTransform=btnC_01;
-   }
-   menu.addEventListener(MouseEvent.MOUSE_OVER, menu_open);
-   menu.options.addEventListener(MouseEvent.MOUSE_OUT, menu_close);
 
  
  
  - 
    What we do have to type a lot of are listeners. Since we have 3 option buttons, and since we have two events for each (MOUSE_OVER & MOUSE_OUT), we have to type six listeners for these two functions. 
      -   var txtArray:Array = new Array("main, "one", "two", "three");
-   menu.main.btn_txt.text=txtArray[0];
-   with(menu.options) {
-       opt_01.btn_txt.text=txtArray[1];
-       opt_01.btn_txt.text=txtArray[2];
-       opt_01.btn_txt.text=txtArray[3];
-   }
-   menu.options.visible = false;
-   var address:Array = new Array();
-       address[0] = new URLRequest("http://lipsum.com");
-       address[1] = new URLRequest("html-color-codes.com");
-       address[2] = new URLRequest("http://dma-205.blogspot.com");
-   var btnC_01:ColorTransform = new ColorTransform();
-       btnC_01.color=0x330066;
-   var btnC_02:ColorTransform = new ColorTransform();
-       btnC_02.color=0x3399cc;
-   function menu_open(evt:MouseEvent):void {
-       menu.options.visible=true;
-       menu.main.stroke.transform.colorTransform=btnC_01;
-       menu.main.btn_txt.transform.colorTransform=btnC_01;
-   }
-   function menu_close(evt:MouseEvent):void {
-       menu.options.visible=false;
-       menu.main.stroke.transform.colorTransform=btnC_02;
-       menu.main.btn_txt.transform.colorTransform=btnC_02;
-   }
-   function option_over(evt:MouseEvent):void{
-       evt.currentTarget.stroke.transform.colorTransform=btnC_02;
-       evt.currentTarget.btn_txt.transform.colorTransform=btnC_02;
-   }
-   function option_out(evt:MouseEvent):void{
-       evt.currentTarget.stroke.transform.colorTransform=btnC_01;
-       evt.currentTarget.btn_txt.transform.colorTransform=btnC_01;
-   }
-   menu.addEventListener(MouseEvent.MOUSE_OVER, menu_open);
-   menu.options.addEventListener(MouseEvent.MOUSE_OUT, menu_close);
-   menu.options.opt_01.addEventListener(MouseEvent.MOUSE_OVER, option_over);
-   menu.options.opt_01.addEventListener(MouseEvent.MOUSE_OUT, option_out);
-   menu.options.opt_02.addEventListener(MouseEvent.MOUSE_OVER, option_over);
-   menu.options.opt_02.addEventListener(MouseEvent.MOUSE_OUT, option_out);
-   menu.options.opt_03.addEventListener(MouseEvent.MOUSE_OVER, option_over);
-   menu.options.opt_03.addEventListener(MouseEvent.MOUSE_OUT, option_out);
 
  
  
  - 
    At this point, we've gotten the menu to open and close, we've gotten the buttons to change colors when you mouse on and off of them, but we haven't gotten it to DO anything. The whole point of a drop-down menu is for the user to have a series of link options that bring up new 'pages' or take the user to different content. Therefore, the very last thing we must do is utilize those URLs that we put inside of that array near the beginning of this script. We will do this with a new statement type known as the switch statment. The switch statement functions similarly to an if/else conditional statement; but whereas the if/else statement has two conditions (if or else), the switch statment may have many different conditions. This is perfect for the use of a drop-down menu. Our menu only has three options, but some drop-down menus contain many more options. The conditions in a switch statement are known as cases, and they operate sort of like common speech as such: In the first case, do THIS
 In the second case, do THAT
 In the third case, do this OTHER THING.
 It really is this simple. We start by creating a variable which will contain the instance name of whichever button the user clicks on:   var optionBtn:String = evt.currentTarget.name; Next comes the switch statment with 3 cases, one for each button which have the instance names of opt_01, opt_02, and opt_03. Depending on which one of those buttons the user mouses over, its instance name will be stored in the variable. Which switch case is selected depends on which name is contained in the variable. If it finds "opt_01" inside that variable, then the switch statement goes with case 1; if it finds one of the other instance names inside, then it goes with the corresponding case, either the 2nd or the 3rd. switch (optionBtn) {
 case "opt_01" :
 trace(optionBtn);
 break;
 case "opt_02" :
 trace(optionBtn);
 break;
 case "opt_03" :
 trace(optionBtn);
 break;
 }
 Whichever switch case is selected, the function is going to set off a trace action, and this action will tell us what is inside of the variable optionBtn. What we hope will come out is the name of the button that you click on. The break action is necessary to stop the switch once a case is selected. This is just a temporary set of actions. We will modify them once we are certain the switch functions properly. If we can get a different button instance name each time we click on a different button, then we know the switch is working properly and we will be able to remove the trace actions and put in the right ones. 
      -   var txtArray:Array = new Array("main, "one", "two", "three");
-   menu.main.btn_txt.text=txtArray[0];
-   with(menu.options) {
-       opt_01.btn_txt.text=txtArray[1];
-       opt_01.btn_txt.text=txtArray[2];
-       opt_01.btn_txt.text=txtArray[3];
-   }
-   menu.options.visible = false;
-   var address:Array = new Array();
-       address[0] = new URLRequest("http://lipsum.com");
-       address[1] = new URLRequest("html-color-codes.com");
-       address[2] = new URLRequest("http://dma-205.blogspot.com");
-   var btnC_01:ColorTransform = new ColorTransform();
-       btnC_01.color=0x330066;
-   var btnC_02:ColorTransform = new ColorTransform();
-       btnC_02.color=0x3399cc;
-   function menu_open(evt:MouseEvent):void {
-       menu.options.visible=true;
-       menu.main.stroke.transform.colorTransform=btnC_01;
-       menu.main.btn_txt.transform.colorTransform=btnC_01;
-   }
-   function menu_close(evt:MouseEvent):void {
-       menu.options.visible=false;
-       menu.main.stroke.transform.colorTransform=btnC_02;
-       menu.main.btn_txt.transform.colorTransform=btnC_02;
-   }
-   function option_over(evt:MouseEvent):void{
-       evt.currentTarget.stroke.transform.colorTransform=btnC_02;
-       evt.currentTarget.btn_txt.transform.colorTransform=btnC_02;
-   }
-   function option_out(evt:MouseEvent):void{
-       evt.currentTarget.stroke.transform.colorTransform=btnC_01;
-       evt.currentTarget.btn_txt.transform.colorTransform=btnC_01;
-   }
-   function option_click(evt:MouseEvent):void{
-       var optionBtn:String = evt.currentTarget.name;
-       switch(optionBtn) {
-           case "opt_01" :
-               trace(optionBtn);
-               break;
-           case "opt_02" :
-               trace(optionBtn);
-               break;
-           case "opt_03" :
-               trace(optionBtn);
-               break;
-       }
-   }
-   menu.addEventListener(MouseEvent.MOUSE_OVER, menu_open);
-   menu.options.addEventListener(MouseEvent.MOUSE_OUT, menu_close);
-   menu.options.opt_01.addEventListener(MouseEvent.MOUSE_OVER, option_over);
-   menu.options.opt_01.addEventListener(MouseEvent.MOUSE_OUT, option_out);
-   menu.options.opt_02.addEventListener(MouseEvent.MOUSE_OVER, option_over);
-   menu.options.opt_02.addEventListener(MouseEvent.MOUSE_OUT, option_out);
-   menu.options.opt_03.addEventListener(MouseEvent.MOUSE_OVER, option_over);
-   menu.options.opt_03.addEventListener(MouseEvent.MOUSE_OUT, option_out);
-   menu.options.opt_01.addEventListener(MouseEvent.CLICK, option_click);
-   menu.options.opt_02.addEventListener(MouseEvent.CLICK, option_click);
-   menu.options.opt_03.addEventListener(MouseEvent.CLICK, option_click);
 
  
  
  - 
    Now that you know the switch statement is functioning properly in that when the user clicks on a button, whichever one of the three buttons that is, a different case is chosen, we can replace the trace() actions with real actions telling the script to do something. What we want to tell the script to do is something with those URLs in the array. Ultimately, what you should want it to do is load one of your pages, perhaps gallery one or gallery two, depending on what you have in your drop-down menus; however, what we will do here is simply make it load external websites. The code to load external websites is simple, we just have to tell flash to navigate to a web address, known in web parlance as URLs. 
      -   var txtArray:Array = new Array("main, "one", "two", "three");
-   menu.main.btn_txt.text=txtArray[0];
-   with(menu.options) {
-       opt_01.btn_txt.text=txtArray[1];
-       opt_01.btn_txt.text=txtArray[2];
-       opt_01.btn_txt.text=txtArray[3];
-   }
-   menu.options.visible = false;
-   var address:Array = new Array();
-       address[0] = new URLRequest("http://lipsum.com");
-       address[1] = new URLRequest("html-color-codes.com");
-       address[2] = new URLRequest("http://dma-205.blogspot.com");
-   var btnC_01:ColorTransform = new ColorTransform();
-       btnC_01.color=0x330066;
-   var btnC_02:ColorTransform = new ColorTransform();
-       btnC_02.color=0x3399cc;
-   function menu_open(evt:MouseEvent):void {
-       menu.options.visible=true;
-       menu.main.stroke.transform.colorTransform=btnC_01;
-       menu.main.btn_txt.transform.colorTransform=btnC_01;
-   }
-   function menu_close(evt:MouseEvent):void {
-       menu.options.visible=false;
-       menu.main.stroke.transform.colorTransform=btnC_02;
-       menu.main.btn_txt.transform.colorTransform=btnC_02;
-   }
-   function option_over(evt:MouseEvent):void{
-       evt.currentTarget.stroke.transform.colorTransform=btnC_02;
-       evt.currentTarget.btn_txt.transform.colorTransform=btnC_02;
-   }
-   function option_out(evt:MouseEvent):void{
-       evt.currentTarget.stroke.transform.colorTransform=btnC_01;
-       evt.currentTarget.btn_txt.transform.colorTransform=btnC_01;
-   }
-   function option_click(evt:MouseEvent):void{
-       var optionBtn:String = evt.currentTarget.name;
-       switch(optionBtn) {
-           case "opt_01" :
-               trace(optionBtn);
-               navigateToURL(address[0]);
-               break;
-           case "opt_02" :
-               trace(optionBtn);
-               navigateToURL(address[1]);
-               break;
-           case "opt_03" :
-               trace(optionBtn);
-               navigateToURL(address[2]);
-               break;
-       }
-   }
-   menu.addEventListener(MouseEvent.MOUSE_OVER, menu_open);
-   menu.options.addEventListener(MouseEvent.MOUSE_OUT, menu_close);
-   menu.options.opt_01.addEventListener(MouseEvent.MOUSE_OVER, option_over);
-   menu.options.opt_01.addEventListener(MouseEvent.MOUSE_OUT, option_out);
-   menu.options.opt_02.addEventListener(MouseEvent.MOUSE_OVER, option_over);
-   menu.options.opt_02.addEventListener(MouseEvent.MOUSE_OUT, option_out);
-   menu.options.opt_03.addEventListener(MouseEvent.MOUSE_OVER, option_over);
-   menu.options.opt_03.addEventListener(MouseEvent.MOUSE_OUT, option_out);
-   menu.options.opt_01.addEventListener(MouseEvent.CLICK, option_click);
-   menu.options.opt_02.addEventListener(MouseEvent.CLICK, option_click);
-   menu.options.opt_03.addEventListener(MouseEvent.CLICK, option_click);