Hi Everyone,
Okay Everyone, here we go, the last final week, the final push until, well, the final is due. What you will find here is a painstaking list of all the code and explanations that you will need for your final project. You will also find an additional aspect, a new thing, that you will have to add to your project, a toggle button that turns music on and off. This is not worth the most points, so everything else in the project is definitely more important, but doing it will definitely separate the good projects from the truly excellent projects.
What I'm trying to say here is that you should do everything else first, and then if you have time, work on the music toggle. Good luck, and let me know if you have any questions. Don't wait until the last minute.
Don't forget: I am going to be at TCI around 11am tomorrow. The school closes at 3pm, so I will remain as long as students need me. If you come, you should come early, because once I am no longer needed, I will leave. See you there!
Carter-
- PART I
- Declarations: You should always start out your code at the top with your declarations. What this means is that you are announcing to AS3 that you are going to be using some variables or other data storage devices, and that you are going to use certain objects in your script down below. For our script, you will need to start out with two Arrays, and then a number of ColorTransform objects. If we need any others later, we will return to the top of the script and add them.
- Array Objects
- Text Array
- First, an array is a particular kind of object in Flash and ActionScript, and all objects begin as variables. These variables, however, are then modified so that they take on additional properties that ordinary variables do not possess.
- Second, remember that an array is an object, much like a variable, which holds data. However, an array is able to hold many, many data items, unlike variables which may only hold onto one data element.
- The first array that we need is the array that we will use to add text to the buttons. These elements must simply state whatever label you want to appear in your buttons.
- Each data item held in an array is indicated by a number. these numbers are known as index numbers, and they always begin counting with the number zero (0).
- var txtArray:Array = new Array();
- txtArray[0] = "bio";
- txtArray[1] = "art";
- txtArray[2] = "galleries";
- txtArray[3] = "gallery 1";
- txtArray[4] = "gallery 2";
- txtArray[5] = "gallery 3";
- txtArray[6] = "resources";
- Another, shorter way of giving an array data, which is what we just did above (we put strings, pieces of text with quotation marks around them) and otherwise known as populating an array is here:
- var txtArray:Array = new Array("bio, "art", "galleries", "gallery 1", "gallery 2", "gallery 3", "resources");
- Yet another, even shorter and more efficient way of populating an array is what is known as literal notation:
- var txtArray:Array = ["bio, "art", "galleries", "gallery 1", "gallery 2", "gallery 3", "resources"];
- Any of these is acceptable when declaring and populating an array. They all do exactly the same thing. It is simply a matter of preference.
- Now, assuming that you've already created your buttons, you need to apply the text to them. Recall, the way that you should have created your buttons are as MovieClip instances, and that this button movieclip must contain 2 additional movieclips within it, a stroke_mc movieclip for the stroke and a fill_mc for the fill. It should also contain a dynamic text box.
- Each of these three items that are inside of your button movieclip should have instance names. I have givem them the instance names of stroke, fill, and btn_txt.
- You might also want to take note that for the instance names for the button movieclips, I have started with btn_00. I have done this to match the counting of the array which also begins at 0.
- btn_00.btn_txt.text = txtArray[0];
- btn_01.btn_txt.text = txtArray[1];
- btn_02.btn_txt.text = txtArray[2];
- Furthermore, you must remember that the buttons of the drop-down menu are INSIDE another movieclip which, in class, I named options:
- btn_00.btn_txt.text = txtArray[0];
- btn_01.btn_txt.text = txtArray[1];
- btn_02.btn_txt.text = txtArray[2];
- options.btn_03.btn_txt.text = txtArray[3];
- options.btn_04.btn_txt.text = txtArray[4];
- options.btn_05.btn_txt.text = txtArray[5];
- btn_06.btn_txt.text = txtArray[6];
- URL Array
- The second array should be typed below the first and is going to be used for the URLs for when we need to request the content files, also known as the external .swf files. Whichever mode of creating and populating an array that you used above, you could use here as well. Consistency in a script is always best and helps to avoid confusion later on. However, since each item in our array is also a URLRequest object, the best way to type it is as follows:
- var urlArray:Array = new Array();
- urlArray[0] = new URLRequest("bio.swf");
- urlArray[1] = new URLRequest("art.swf");
- urlArray[2] = ...etc...
- If you want to put your content pages in a separate sub-folder named content, for example, you would type your array slightly differently as below:
- var urlArray:Array = new Array();
- urlArray[0] = new URLRequest("content/bio.swf");
- urlArray[1] = new URLRequest("content/art.swf");
- urlArray[2] = ...etc...
- ColorTransform Objects
- New Colors
- ColorTransform objects are really just what their name suggests they might be: they are objects which have the ability to change the color of something. In this case, we want to change the color of a movieclip from its current color to a new color. For that, we need to create a ColorTransform object and then apply it to the item that we wish to transform.
- The first color object I have down below will be attached to my stroke so that I can modify the color of my stroke to a new color. Thus, in front of the c, I have put the letter s, referring to stroke.
- Also, notice down below that the way we create this object is virtually identical to the way that we created our arrays:
- var sc_new:ColorTransform = new ColorTransform();
- sc_new.color = 0x990000;
- Next, is the new color for the fill movieclip, for which I follow exactly the same procedure, except instead of the s in front of the c, I have placed an f to refer to fill:
- var fc_new:ColorTransform = new ColorTransform();
- fc_new.color = 0xffaaaa;
- Many of you have also created a ColorTransform object for your text:
- var tc_new:ColorTransform = new ColorTransform();
- tc_new.color = 0x660000;
- Old Colors
- The next set of colors are, for lack of better terminology, are the old colors. These are the original colors that our buttons began with and which they should return to once the user stops interacting with them. If you have three new colors, you should also have 3 old colors:
- var sc_old:ColorTransform = new ColorTransform();
- sc_old.color = 0x000000;
- var fc_old:ColorTransform = new ColorTransform();
- fc_old.color = 0xffffff;
- var tc_old:ColorTransform = new ColorTransform();
- tc_old.color = 0x000000;
- Functions: After our declarations above, we will start with our functions. I want to start from the simplest and then progress to the more advanced. At the same time, I would like to start with the general functions, the ones that affect many objects and move to the more particular functions, the ones that affect fewer objects.
- Color Modification Function
- New Stroke Color
- The first function we will try is the function that will change the colors of the buttons. To start this out, however, instead of trying to change all three colors for the stroke, the fill, and the text all at once, it's always better to do one thing at at time. Then, once you get that one thing to function, you can add additional features. Let's start with getting the stroke color for ONE of the button movieclips to change.
- function overIt(evt:MouseEvent):void{
- btn_00.stroke.transform.colorTransform = sc_new;
- }
- That's very simple, but it won't work at all until we add a listener to call on this function when we MOUSE_OVER the button.
- btn_00.addEventListener(MouseEvent.MOUSE_OVER, overIt);
- Multiple Button Color Change
- Now, when you mouse over the first button, the stroke should change colors. There is a problem with this, however: you should notice that inside the function that I used a particular instance name, btn_00. Therefore, this will only work for that one button. If you try mousing over any of the other buttons, it doesn't work at all on them.
- Using this logic, then, we'd have to write a separate function for each button just to change the color of each button. That is too much typing to do something simple.
- This means, to be more efficient, we have to think of something that allows us to change the color of whatever button that the user happens to be mousing over at any given time. How can we pinpoint a particular button, the button the user is mousing over at any given moment, without actually calling it by name? Because if we call it by name, that means we'll have to go through each one and call each one by name one at a time. This is not efficient at all.
- The answer is in the little variable in the function declaration, evt:MouseEvent. There, the term evt (an abbreviation of the word event), is actually a variable. As you should know, a variable is a data container. In this case, this variable contains a particular kind of data. The word after it MouseEvent tells you what kind of data is contained within that variable, information about a event that occurs with the mouse. Whenever the user mouses over the button, information about the button and the event is stored in that variable.
- This means, that that variable, evt, contains information about whatever button that the user happens to be mousing over at any given time, and we can access that information.
- One of the properties of a MouseEvent is currentTarget. The word target is whatever happens to be the target of the user's attention with the mouse. If the user is mousing over a button, that button is the currentTarget.
- Let's try something: let us put a trace in our function and for the moment disable our statement by commenting it out. We are going to trace the name of the current target.
- function overIt(evt:MouseEvent):void{
- //btn_00.stroke.transform.colorTransform = sc_new;
- trace(evt.currentTarget.name);
- }
- Now, let's add listeners for the remaining buttons:
- btn_00.addEventListener(MouseEvent.MOUSE_OVER, overIt);
- btn_01.addEventListener(MouseEvent.MOUSE_OVER, overIt);
- btn_02.addEventListener(MouseEvent.MOUSE_OVER, overIt);
- options.btn_03.addEventListener(MouseEvent.MOUSE_OVER, overIt);
- options.btn_04.addEventListener(MouseEvent.MOUSE_OVER, overIt);
- options.btn_05.addEventListener(MouseEvent.MOUSE_OVER, overIt);
- options.btn_06.addEventListener(MouseEvent.MOUSE_OVER, overIt);
- You should see now, that when you test your movie you the name of the button you are mousing over, of WHICHEVER button you are mousing over, pops up in the output window.
- So, let's apply that to the color change:
- function overIt(evt:MouseEvent):void{
- btn_00evt.currentTarget.stroke.transform.colorTransform = sc_new;
- }
- New Fill Color
- We can apply the same technique to making the color of the fill and text change:
- function overIt(evt:MouseEvent):void{
- evt.currentTarget.stroke.transform.colorTransform = sc_new;
- evt.currentTarget.fill.transform.colorTransform = fc_new;
- evt.currentTarget.btn_txt.transform.colorTransform = tc_new;
- }
- Original Stroke & Fill Colors
- Now that we have changed the color, let's make it change back. We'll begin this by creating a new function:
- function outIt(evt:MouseEvent):void{
- evt.currentTarget.stroke.transform.colorTransform = sc_old;
- evt.currentTarget.fill.transform.colorTransform = fc_old;
- evt.currentTarget.btn_txt.transform.colorTransform = tc_old;
- }
- And then the listeners:
- btn_00.addEventListener(MouseEvent.MOUSE_OUT, outIt);
- btn_01.addEventListener(MouseEvent.MOUSE_OUT, outIt);
- btn_02.addEventListener(MouseEvent.MOUSE_OUT, outIt);
- options.btn_03.addEventListener(MouseEvent.MOUSE_OUT, outIt);
- options.btn_04.addEventListener(MouseEvent.MOUSE_OUT, outIt);
- options.btn_05.addEventListener(MouseEvent.MOUSE_OUT, outIt);
- options.btn_06.addEventListener(MouseEvent.MOUSE_OVER, outIt);
- Great, now it changes back and forth easily from one set of colors back to the original set of colors. Great, now onto the next job, opening and closing the drop-down menu.
- Drop-Down Function
- Close Menu
- The first thing we need to do is close the menu so that when we first open our site it is NOT opened with all of the buttons underneath it showing. We don't want those buttons showing until we mouse over the top button of the menu, the only one that should be showing. All the others, remember, are inside another movieclip that we named options.
- That's very easy, at the very top of your script in the actions window, type the following line of code:
- this.options.visible = false;
- And that's it for that. When you test the movie, you'll see those buttons are gone
- Open Menu
- But now, we want to make them appear when we mouse over the top button. That's easy enough. All we would have to do is create a function so that when you MOUSE_OVER the top button of the menu, the other buttons below it become visible.
- If you recall, however, we already have a listener for the MOUSE_OVER event, and it calls our first function, overIt. That means we have to put this part within that function.
- function overIt(evt:MouseEvent):void{
- evt.currentTarget.stroke.transform.colorTransform = sc_new;
- evt.currentTarget.fill.transform.colorTransform = fc_new;
- evt.currentTarget.btn_txt.transform.colorTransform = tc_new;
- this.options.visible = true;
- }
- Aha! If you tested that, you found that it didn't quite work. It opens when you mouse over ANY of the buttons, not only the one with the menu. That's a problem. We ONLY want it to open when we mouse over the top button with the menu and ONLY that button, none of the others.
- To do that we'll need to learn about a new type of statement, a conditional statement. We also call these if/else statements.
- In an If/else statement, you can pinpoint an action that you want to have happen only IF a certain condition is met.
- Our condition is if the user mouses over the top button of the menu. In my script, my top button has an instance name of btn_02, so that will be my condition:
- function overIt(evt:MouseEvent):void{
- evt.currentTarget.stroke.transform.colorTransform = sc_new;
- evt.currentTarget.fill.transform.colorTransform = fc_new;
- evt.currentTarget.btn_txt.transform.colorTransform = tc_new;
- if (evt.currentTarget.name == "btn_02") {
- this.options.visible = true;
- }
- }
- To make certain that the menu stays open so long as we are mousing over ANY of the buttons of the menu, not just the top one, but also the others below it, we must add some conditions to our statement.
- Not only do we want it to remain open IF we mouse over the top button, but we want it to remain open if we mouse over the top button OR the 2nd button, OR the 3rd button, OR the 4th button. The way we includ the OR OPTIONS is with the || characters, which are located at the SHIFT - \.
- function overIt(evt:MouseEvent):void{
- evt.currentTarget.stroke.transform.colorTransform = sc_new;
- evt.currentTarget.fill.transform.colorTransform = fc_new;
- evt.currentTarget.btn_txt.transform.colorTransform = tc_new;
- if (evt.currentTarget.name == "btn_02" || evt.currentTarget.name == "btn_03" || evt.currentTarget.name == "btn_04" || evt.currentTarget.name == "btn_05") {
- this.options.visible = true;
- }
- }
- Now, the menu will remain open until you mouse over another button. This isn't a perfect solution, but it is fine for now. I will give extra credit to anyone who comes up with a solution in which the menu closes when you mouse off any of the buttons, without having to wait until you mouse over another button before it closes. Don't spend a lot of time and don't write a lot of code to solve this. It isn't that important. Other things in this project are much more important.
- Loading External Files
- Loader Object
- We left off at the beginning one of our objects, and that is the Loader object. This is essential for placing external files within another main file.
- We have our URLRequest objects that request a particular file. Now we need to place the requested file within an object that will actually do the job of loading it, of bringing it from outside the current (index) .swf file and preparing it for placement onto the current file. If you recall my gun analogy from class, the URLRequest is the external file, so it is like a bullet. The loader, then, is the gun that will deliver our bullet.
- The next two jobs then are to create the loader and then place the bullets inside our gun. Our gun, however, is a special sort of gun that can only hold and fire one bullet at a time. That means it is like most shotguns: we have to reload it with a new shell each time we shoot with it.
- First let's create the loader at the top, in the declarations section of our code. We can place it beneath the array with the URLRequests:
- var urlArray:Array = new Array();
- urlArray[0] = new URLRequest("bio.swf");
- urlArray[1] = new URLRequest("art.swf");
- urlArray[2] = ...etc...
- var swfLoader:Loader = new Loader();
- Now, at the bottom, in the functions section of our code, let's start with a new function for loading the external .swf files.
- function loadIt(evt:MouseEvent):void {
- }
- Now, at the bottom, in the functions section of our code, let's start with a new function for loading the external .swf files.
- function loadIt(evt:MouseEvent):void {
- swfLoader.load(urlArray[0]);
- box_mc.addChild(swfLoader);
- }
- Create a listener grouped at the bottom with all of the other listeners. Since we are trying to load the first item of our array, this means we want the listener to relate to the first button.
- btn_00.addEventListener(MouseEvent.CLICK, loadIt);
- This is very nice and all, but we have a similar problem that we did above when we wanted to change the colors of the different buttons. If you look in our function, you will see that it will only add the first item of the array, and none of the others. If we followed this logic, as with the color function, we'd have to write one function for every button. That is terribly inefficient, and there is a better way.
- Once again, we need to rely on that little variable named evt within the parentheses in the function declaration.
- Like we did with the colors, we'll use it together with the currentTarget property:
- function loadIt(evt:MouseEvent):void {
- //swfLoader.load(urlArray[0]);
- //box_mc.addChild(swfLoader);
- trace(evt.currentTarget.name);
- }
- Now, when you click on the first button, in the output window, you'll see the name of the button. So, let's add the listeners for all of the other buttons:
- btn_00.addEventListener(MouseEvent.CLICK, loadIt);
- btn_01.addEventListener(MouseEvent.CLICK, loadIt);
- btn_02.addEventListener(MouseEvent.CLICK, loadIt);
- options.btn_03.addEventListener(MouseEvent.CLICK, loadIt);
- options.btn_04.addEventListener(MouseEvent.CLICK, loadIt);
- options.btn_05.addEventListener(MouseEvent.CLICK, loadIt);
- btn_06.addEventListener(MouseEvent.CLICK, loadIt);
- Notice that I have a line through the listener for btn_02 (the third button). That is because it is the one with the drop-down menu. It doesn't load external files, so we don't need to include it in this function.
- Now, when you click on the individual buttons, you see their names pop up in the output window.
- Next, let's load a file, but to do so we'll have to learn a new type of statement. As above with the drop-down menu, we have conditions. In this case, we don't have only ONE condition OR another. No, in this case we have MULTIPLE CONDITIONS.
- We could still use the If/else statement, but when you have many conditions, it is better to use the switch statement.
- In our situation, we have several buttons and each of those buttons loads a different file. IF we mouse over one button, THEN we must load a certain file. Otherwise, IF we mouse over another button, THEN we must load another file; and so on for several buttons.
- The variable, evt allows us to capture which button the user happens to be mousing over or clicking on at any given moment. Once again, this is very useful to us. This time, like before, we are going to capture the instance name of the button; but in addition, we are going to store it in a new variable within the function:
- function loadIt(evt:MouseEvent):void {
- var btnName:String = evt.currentTarget.name;
- //swfLoader.load(urlArray[0]);
- //box_mc.addChild(swfLoader);
- //trace(evt.currentTarget.name);
- }
- With this variable, you will see that it contains the necessary information. If we put the variable within the trace you will see that it traces the same info as before here: trace(evt.currentTarget.name);
- function loadIt(evt:MouseEvent):void {
- var btnName:String = evt.currentTarget.name;
- //swfLoader.load(urlArray[0]);
- //box_mc.addChild(swfLoader);
- trace(btnName);
- }
- As you can see if you try that out, nothing has changed with the addition of that variable.
- Now, we can use that variable, btnName to determine which button the user happens to be mousing over. And then, once we determine which case it is, we'll tell actionscript to load one file or another.
- In the case of btn_00, then Flash should load the first file; in the case of btn_01, then Flash should load the second file; and so on for all the files.
- function loadIt(evt:MouseEvent):void {
- var btnName:String = evt.currentTarget.name;
- //swfLoader.load(urlArray[0]);
- //box_mc.addChild(swfLoader);
- //trace(btnName);
- switch (btnName) {
- case "btn_00" :
- do something;
- stop;
- case "btn_01" :
- do something else;
- stop;
- case "btn_03" :
- do this other thing;
- stop;
- case "btn_04" :
- do yet another thing;
- stop;
- case "btn_05" :
- blah blah blah;
- stop;
- case "btn_06" :
- yadda yadda yadda;
- stop;
- }
- }
- So, what we actually want to tell the switch statement to do is to load different files depending on which button is clicked:
- function loadIt(evt:MouseEvent):void {
- var btnName:String = evt.currentTarget.name;
- //swfLoader.load(urlArray[0]);
- //box_mc.addChild(swfLoader);
- //trace(btnName);
- switch (btnName) {
- case "btn_00" :
- swfLoader.load(urlArray[0]);
- box_mc.addChild(swfLoader);
- break;
- case "btn_01" :
- swfLoader.load(urlArray[1]);
- box_mc.addChild(swfLoader);
- break;
- case "btn_03" :
- swfLoader.load(urlArray[2]);
- box_mc.addChild(swfLoader);
- break;
- ...etc...
- }
- }
- In addition, we want to make certain that the drop-down menu closes when you click on any of the buttons that are within the menu. In my case, in the drop-down menu that I've created here, that would be the 4th, 5th, and 6th buttons (btn_03 - btn_05).
- function loadIt(evt:MouseEvent):void {
- var btnName:String = evt.currentTarget.name;
- //swfLoader.load(urlArray[0]);
- //box_mc.addChild(swfLoader);
- //trace(btnName);
- switch (btnName) {
- case "btn_00" :
- swfLoader.load(urlArray[0]);
- box_mc.addChild(swfLoader);
- break;
- case "btn_01" :
- swfLoader.load(urlArray[1]);
- box_mc.addChild(swfLoader);
- break;
- case "btn_03" :
- swfLoader.load(urlArray[2]);
- box_mc.addChild(swfLoader);
- this.options.visible = false;
- break;
- case "btn_04" :
- swfLoader.load(urlArray[3]);
- box_mc.addChild(swfLoader);
- this.options.visible = false;
- break;
- ...etc...
- }
- }
- PART II
- Music: For the last part of this project, you will need to do two things: create what's known as a toggle button, which is a button that has an ON position and an OFF position. When you click on it once it turns ON, and then when you click on it again, it turns OFF.
- Toggle Button:
- As with the other buttons, this button will be a nested set of movieclips. This simply means that you will have movieclips within movieclips.
- For example, perhaps you will have a shape that looks like a speaker for your ON position, and then a red slash that appears over the speaker for your OFF position.
- So, your first job is to draw a side-view of the way a speaker looks: ( http://www.tuaw.com/2007/09/12/access-your-macs-super-quiet-mode/ ). That is an example.
- Once you do that, convert it into a movieclip symbol.
- Next, draw a diagonal red slash over the top of it and conver it into a movieclip as well.
- Both of these movieclips should have instance names.
- The speaker I will call sndON, and the slash I will call simply sndOFF.
- Now place the red slash on top of the speaker if you haven't already.
- Select them both and convert them into another symbol named sndBtn.
- Enter into edit mode for this new symbol and then select both objects.
- Right-click on your selection and select distribute to layers.
- Delete the blank layer and exit edit mode.
- Give your symbol the instance name of snd.
- Toggle Button Actions:
- This button is very similar to the drop-down menu: first we have to hide the red slash. Therefore, at the very top of your code, on the 2nd line, type the following line of code:
- this.snd.sndOFF.visible = false;
- Since the sndOFF movieclip, the one of the red slash is going to be INvisible, the visibility is FALSE, then all the user will see is the speaker. This means that the movie will start off with the sound playing. The default is to have music. The user will have to turn it off if he/she wishes.
- Now, we need to create a function that switches the visibility of the slash from false to true. This will signify that the sound has stopped and no longer playing because the speaker will have a VISIBLE red slash over the speaker.
- function sndOnOff(evt:MouseEvent):void {
- this.snd.sndOFF.visible = true;
- }
- Following this, you will need to add the listener for the snd movieclip:
- snd.addEventListener(MouseEvent.CLICK, sndOnOff);
- The problem with this function is that it only turns the sound ON. It would be better if the function turned it both on AND off. To do that we will need another if/else statement. This statement will simply determine if the red slash is visible or invisible. If it is visible, then the sound is OFF; and if it is invisible, then the sound is ON.
- function sndOnOff(evt:MouseEvent):void {
- if(snd.sndOFF.visible == false) {
- snd.sndOFF.visible = true;
- } else {
- snd.sndOFF.visible = false;
- }
- }
- Music File:
- Now, in your main folder, create another folder named music.
- Within that folder, you need to place a music file. This music file MUST be an .mp3 file.
- Music Actions:
- In order to have this button place music into your site, you will first need to declare three objects. Therefore, scroll UP to the declarations section of your code at the top.
- The first object is the sound object and it contains the music sound itself.
- The second object is the sound channel object and it controls the behavior of the sound, whether it is playing or not.
- The third object is the URLRequest object, which, like any of our other request objects, requests an external file and prepares it for loading into the main .swf movie file.
- var sndMus:Sound = new Sound();
- var sndChan:SoundChannel = new SoundChannel();
- var sndReq:URLRequest = new URLRequest("song.mp3");
- Next, you have to load the requested file:
- var sndMus:Sound = new Sound();
- var sndChan:SoundChannel = new SoundChannel();
- var sndReq:URLRequest = new URLRequest("song.mp3");
- sndMus.load(sndReq);
- Now, you have to create a function to play the loaded file; but that doesn't make any sense: we already have a function that operates the button. We can just add some actions to that function:
- function sndOnOff(evt:MouseEvent):void {
- if(snd.sndOFF.visible == false) {
- snd.sndOFF.visible = false;
- sndChan = sndMus.play();
- } else {
- snd.sndOFF.visible = true;
- sndChan.stop();
- }
- }