1. week 1
  2. week 2
  3. week 3
  4. week 4
  5. week 5
  6. week 6
  7. week 7
  8. week 8
  9. week 9
  10. week 10
  11. week 11
  12. week 12
  13. week 13

Saturday, October 30, 2010

Fall 2010 week 7:
—10/27: Wed 12:25pm - 3:25pm &
—10/29: Fri 6:00pm - 9:00pm

Hi Everyone,

I'm very proud of all of you this week. You have been trying very hard to solve this problem of the back button. I'm not putting the steps to solve it here in this blog post. I'll take you through them in class.

Instead, I have some steps for you to follow for a little something new.

Carter-



  1. WEEK 8
    1. Classwork
      • LINK    no class files this week
    2. Homework:
      • Exercise 1:    Now let's play around a little bit with the display.

        1. Perhaps, your first question would be to ask, "what is the display?". What this is really about is stuff that is displayed in the player when you test a flash movie. It's about doing cool stuff with ActionScript. Many of you, I am sure, will be happy to know that after the last couple of weeks of all this typing and absolutely NOTHING visual, no graphics, nada, that here we begin doing graphic stuff again, but with code.

        2. What we're about to explore is known as the display list, in case you want to look it up in your own book or do a search online. As in many other things with ActionScript 3.0, the terminology is a bit deceptive and non-descriptive, but oh well. They didn't ask me.

        3. The display list is made up of a hierarchy of display objects. All of these belong to what is known as the DisplayObject class, which is just part of the DisplayObjectContainer class, both of which are built-in classes that are part of Flash when you buy or download it. There are many children of these classes, basically everything visual that you can put in or create in a Flash movie is part of a Flash class. Here are some examples of these classes:

          1. DisplayObject—This class provides basic graphical properties to objects, such as width, height, x, and y.
          2. InteractiveObject—This class provides various methods and properties that allow users to interact with objects in Flash, such as Movieclips.
          3. DisplayObjectContainer—This class provides the ability for some objects to contain other objects, such as Movieclips which may, for example, contain other Movieclips.
          4. Sprite—This class provides similar functionality to Movieclips. It is not something that you can create graphically by drawing it as you can with Movieclips, but may only be created through code.
          5. MovieClip—This class will be the most familiar to you as you have been creating Movieclips now for a few semesters. This class of objects have their own timeline and all the properties and functionality that go along with that, such as playing and stopping the timeline.

        4. So, let us get started. First, you'll need to create a new project folder named dma213_project_01. As you have surely noticed by now, in all classes that use coding such as HTML, JavaScript, and PhP, you need to be careful, specific, and tediously precise about naming and saving your files. ActionScript is no different, especially when you start working with classes.

        5. Open up a new .fla file and save it as display.fla within this new folder.

        6. Draw a perfect square with the dimensions 100 X 100 and with a rather thick black outline.

        7. Select this square (make sure you get both the fill and the stroke, and convert it into a symbol. Name it Square (upper-case S), select movieclip for type, make sure the registration point is the upper-left, and then, if necessary, click on the advanced button here to open up and see additional options. Once you do so, or if the convert to symbol box already opened up wide, check off where it says Export for ActionScript. Once you do so, you'll see the symbol name appear there (now also a class name) and what sort of class it is (MovieClip). The reason we're doing this is because we're going to save our class in a separate folder. As you've learned in other coding classes, it is always good to segregate your different types of files. It is no different in Flash. Moreover, in Flash, it is often possible to re-use your classes for other projects, so we will often locate them in other disparate folders. Now, click Okay.

        8. Now, with the symbol selected, give it an instance name of square (lower-case s).

        9. Now, within the folder that you've already created, you must create a new folder named wk8.

        10. Once you do that, back in Flash, Create a new ActionScript file for the document class. Save the file within the new wk8 folder and name it DisplayTest.as.

        11. Within the new .as file, type the following class definition and class constructor:

          1. package wk8 { /* package is named the same thing as the
                            folder where the class is located. */
          2.  
            1. import flash.display.Sprite;
            2.  
            3. public class DisplayTest extends Sprite { /* here, we are
                            using the properties of the Sprite class as
                            it already exists in Flash to indicate to
                            what family, or class, our own custom class
                            (DisplayTest) belongs.*/
              1. public function DisplayTest() {
              2. }
            4.  
            5. }
          3.  
          4. }

        12. But we have a couple more things to do before we can test this out. First, let's put a trace in our constructor method above so that it does something, and we're actually going to trace the instance name of the movieclip, square.

          1. package wk8 {
          2.  
            1. import flash.display.Sprite;
            2.  
            3. public class DisplayTest extends Sprite {
              1. public function DisplayTest() {
                1. trace(square);
              2. }
            4.  
            5. }
          3.  
          4. }

        13. Save that (but don't test yet because you'll get an error). Before you test it, since we have saved our class into a different folder, we have to specify that in our class instance, the .fla file. We have to indicate that the display.fla movie should use our DisplayTest class as its document class. So, click somewhere in an empty area of the stage to deselect all, and then open up the Properties panel to show the properties for the movie. Where it says Document class:, you need to type the path (using dot notation) to the class as follows: wk8.DisplayTest. Save your changes and test your movie.
        14. More than likely, you'll still get an error, one that mentions something about type not found and MovieClip. To get around this problem, you have to import the MovieClip class in the same way that you imported the Sprite clas:

          1. package wk8 {
          2.  
            1. import flash.display.MovieClip;
            2. import flash.display.Sprite;
            3.  
            4. public class DisplayTest extends Sprite {
              1. public function DisplayTest() {
                1. trace(square);
              2. }
            5.  
            6. }
          3.  
          4. }

          Now, once you test your movie again, you should get some output that tells you the object with the instance name square is a movieclip:

          1. [object MoveClip]

        15. Big deal!!! You might say sarcastically. Okay, so let's now modify our square by moving it to a new spot using new x/y coordinates, and let's also modify it's shape using width/height:

          1. package wk8 {
          2.  
            1. import flash.display.MovieClip;
            2. import flash.display.Sprite;
            3.  
            4. public class DisplayTest extends Sprite {
              1. public function DisplayTest() {
                1. trace(square);
                2. square.x = 300;
                3. square.y = 300;
                4. square.width = 200;
                5. square.height = 25;
              2. }
            5.  
            6. }
          3.  
          4. }

        16. Let's also rotate the object and change its opacity:
          1. package wk8 {
          2.  
            1. import flash.display.MovieClip;
            2. import flash.display.Sprite;
            3.  
            4. public class DisplayTest extends Sprite {
              1. public function DisplayTest() {
                1. trace(square);
                2. square.x = 300;
                3. square.y = 300;
                4. square.width = 200;
                5. square.height = 25;
                6. square.rotation = 60;
                7. square.alpha = .5;
              2. }
            5.  
            6. }
          3.  
          4. }

          Below you have something like what your stage should look like in your .fla file.



          And then you have what the .swf file should look like when you generate it, ctrl or cmd-enter.




      • Extra Credit:    Below I will lead you through some more experimentation with the display. If you complete these steps, you will receive extra credit in the next class. We are going to work with blend modes, filters, as well as other properties throughout the rest of this posting.

        1. Depth—Normally, when working with objects on the stage, you manage depth primarily with layers. In ActionScript, the depth of an object is determined by an index number in an array of child objects on the stage. The higher the index number, the further toward the front of the movie that object appears. A Sprite instance or a MovieClip instance with an index of 0 will appear below another object with an index of 1. This depth of the display object may be manipulated, meaning that you can change the stacking order of the objects on the stage.

          1. Create a new ActionScript file, save it into the wk8 folder with the name of DepthTest.as. Then place the following lines of code inside of it:

            1. package wk8 {
            2.  
              1. import flash.display.MovieClip;
              2. import flash.display.Sprite;
              3.  
              4. public class DepthTest extends Sprite {
              5.  
                1. public function DepthTest() {
                  1. trace(getChildIndex(square_01));
                2. }
              6.  
              7. }
            3.  
            4. }

          2. Save this file as depth.fla, set the document class in the properties panel as before to wk8.DepthTest. If you test the movie now, you should see that the square object is at depth 0; but this is boring. Let's see what happens when we add a few more instances to the stage.

          3. In the .fla file, drag three more instances of the Square MovieClip symbol from the Library onto the stage, and make certain each is in its own layer. Move them around so that the squares overlap each other so that you can see which is on top of which.

          4. Provide each of these symbol instances with instance names, such as square_02, square_03, and square_04.

          5. Go back to the DepthTest.as file and add a few additional trace() statements:

            1. package wk8 {
            2.  
              1. import flash.display.MovieClip;
              2. import flash.display.Sprite;
              3.  
              4. public class DepthTest extends Sprite {
              5.  
                1. public function DepthTest() {
                  1. trace("square_01: " + getChildIndex(square_01));
                  2. trace("square_02: " + getChildIndex(square_02));
                  3. trace("square_03: " + getChildIndex(square_03));
                2. }
              6.  
              7. }
            3.  
            4. }

          6. Save your changes to the .as file, switch back to the .fla file, and test the movie. What you will find is that the symbols are arranged from level 0 to level 2.

        2. Manipulate Depth—Now that we have several objects to work with, we can begin to play around a bit with their depths using the setChildIndex() method.
          1. This method has two parameters that need to be satisfied: when using it, you must state two things, which object you want to manipulate, and then to which index level you want to move it.

          2. We'll first move the first square we had on the stage to the top of the display. As mentioned, we'll call the setChildIndex() method, passing the object named square and its new depth. Since we have only three objects, and since we are dealing with an array of 3 objects, the depths start at 0 and count up to 2 (0, 1, 2). We could use the number 2 as the top depth, but the best way to bring an object to the top of the list is to use numChildren to determine the highest depth. This property is much like the length property for arrays. If we wanted the last index of an array, we simply subtract 1 from the length (i.e. myArray.length-1). Therefore, we'll use numChildren - 1 to determine the highest index number. A parent object with three child objects has a top depth of 2 (0 for the depth of the 1st child, 1 for the depth of the 2nd child, and 2 for the depth of the 3rd child).

            1. package wk8 {
            2.  
              1. import flash.display.MovieClip;
              2. import flash.display.Sprite;
              3.  
              4. public class DepthTest extends Sprite {
              5.  
                1. public function DepthTest() {
                  1. trace("square_01: " + getChildIndex(square_01));
                  2. trace("square_02: " + getChildIndex(square_02))
                  3. trace("square_03: " + getChildIndex(square_03));
                  4.  
                  5. setChildIndex(square_01, numChildren-1);
                  6.  
                  7. trace("square_01: " + getChildIndex(square_01));
                  8. trace("square_02: " + getChildIndex(square_02))
                  9. trace("square_03: " + getChildIndex(square_03));
                2. }
              6.  
              7. }
            3.  
            4. }

          3. Once you save the above changes, and test your .fla file again, you'll see that the original first square is now at the top of the list (with a 2 as its index. The indexes of the other two objects have been reduced by one.

            1. square_01: 0
            2. square_02: 1
            3. square_03: 2
            4. square_01: 2
            5. square_02: 0
            6. square_03: 1

        3. Swapping Depths—Another way of changing the index level of an object is to swap its index with another of the objects. There are two ways of doing this: use teh swapChildren() method and pass the instance names of the objects that you want to exchange depths, and the swapChildrenAt() method and instead pass the index numbers that you want to switch with each other.
          1. First, let's swap the index levels of square_02 and square_03:

            1. package wk8 {
            2.  
              1. import flash.display.MovieClip;
              2. import flash.display.Sprite;
              3.  
              4. public class DepthTest extends Sprite {
              5.  
                1. public function DepthTest() {
                  1. trace("square_01: " + getChildIndex(square));
                  2. trace("square_02: " + getChildIndex(square_02))
                  3. trace("square_03: " + getChildIndex(square_03));
                  4.  
                  5. setChildIndex(square_01, numChildren-1);
                  6.  
                  7. trace("square_01: " + getChildIndex(square));
                  8. trace("square_02: " + getChildIndex(square_02))
                  9. trace("square_03: " + getChildIndex(square_03));
                  10.  
                  11. swapChildren(square_02, square_03);
                2. }
              6.  
              7. }
            3.  
            4. }

          2. Now, let's try swapping the indexes of the objects at level 0 and 2.

            1. package wk8 {
            2.  
              1. import flash.display.MovieClip;
              2. import flash.display.Sprite;
              3.  
              4. public class DepthTest extends Sprite {
              5.  
                1. public function DepthTest() {
                  1. trace("square_01: " + getChildIndex(square));
                  2. trace("square_02: " + getChildIndex(square_02))
                  3. trace("square_03: " + getChildIndex(square_03));
                  4.  
                  5. setChildIndex(square_01, numChildren-1);
                  6.  
                  7. trace("square_01: " + getChildIndex(square));
                  8. trace("square_02: " + getChildIndex(square_02))
                  9. trace("square_03: " + getChildIndex(square_03));
                  10.  
                  11. swapChildren(square_02, square_03);
                  12. swapChildrenAt(0, 2);
                  13.  
                  14. trace("square_01: " + getChildIndex(square));
                  15. trace("square_02: " + getChildIndex(square_02))
                  16. trace("square_03: " + getChildIndex(square_03));
                2. }
              6.  
              7. }
            3.  
            4. }






Thursday, October 21, 2010

Fall 2010 week 6:
—10/20: Wed 12:25pm - 3:25pm &
—10/22: Fri 6:00pm - 9:00pm

Hi Everyone,

This week, I want you all to review what we did last week and make certain that you understand most of it. This blog will deal with re-stating what you did for homework last week.

I know it seemed difficult what we have been doing, probably especially what we started last week for homework, but I promise you'll be happy with the results in the end. Try to keep in mind that fully-functioning scripts each week are NOT the most important thing. Try not to get stuck on any one thing to the detriment of other things for this class or for your other classes.

The most important thing is that you begin to UNDERSTAND what we are doing and that IF YOU DO NOT UNDERSTAND, THAT YOU COME TO CLASS WITH QUESTIONS!!!.

The second most important thing is that you begin to learn to find your errors. As I've mentioned, most of your errors continue to be naming errors. These are silly and annoying and keep you from finding out what really is the problem. Once you start to get the handle on things, you'll see that Flash and ActionScript are very powerful and can be extremely fun and interesting with what you can create.

Carter-



  1. WEEK 6
    1. Classwork
      • LINK    class files
    2. Review:
      • MIDTERM—Exercise 1:    Look through the steps below to review and reinforce what we have done over the past week for homework and in class.
        1. Let's start off where we left off in class. I'll try to explain once again the small script that we'd ended up with up to that point:


          1. package {

            1. public class MPlay {

              1. public var mName:String="";
              2. public var mVolume:int=10;
              3. public var mTList:Array;
              4. public var mTCurrent:int=0;
              5. public var mMix:Boolean = false;


              6. public function play():void {
                1. trace("Playing: " + mTList[mTCurrent]);
              7. }

              8. public function next():void {
                1. if (mMix) {
                  1. mTCurrent=Math.floor(Math.random() * mTList.length);
                  2. } else {
                    1. if (mTCurrent==mTList.length - 1) {
                      1. mTCurrent=0;
                      2. } else {
                        1. mTCurrent++;
                    2. }
                2. }
                3. play();
              9. }
            2. }
          2. }


        2. This is our class declaration, and it includes 5 properties and 2 methods. The top 5 items are the properties, created as you would variables. And the bottom 2 items are methods, created as you would functions.
        3. Recall that a class is like a group of objects. I myself have several classes at TCI. What sort of objects are contained within my classes? Why student objects, of course.
        4. So, if I were to define one of my student classes, I would say that the student objects within my student class should have the following properties:
          • person (no fish or antelopes allowed),
          • education up to HS level,
          • desire to learn,
          • open mind,
          • creativity;
          and they should have the following methods:
          • come to class,
          • study,
          • learn,
          • create,
          • bring apples to teacher.
          Notice that properties are like adjectives which describe the student objects, and that methods are like verbs which indicate something the student objects may (or may not) do.
        5. The properties are pretty self-explanatory, so let's examine the first method, the play() method:

          1. public function play():void {
            1. trace("Playing: " + mTList[mTCurrent]);
          2. }

        6. That line of code is simply the function declaration, which we have seen many times so far in this class. When used inside of a class definition as we have here, we call this a method. A method is really just a function, but a function which belongs to an object In this case, our object is the class. Beyond that, it is a function of type void which means it will not return any data.

          1. public function play():void {
            1. trace("Playing: " + mTList[mTCurrent]);
          2. }

        7. That line of code above is held within the function. It is a simple function because it holds only one line of code within it; and this line is a trace. All this will do is trace out some data and some text. The trace contains a concatenation which is simply combining the string "Playing" with the output from our Array, named mTList. As you should know, an array is an object which can hold more than one element of data, unlike a variable which can hold only one data element. To separate the data elements, each piece of information is given an index number. These index numbers, unless told to do otherwise, begin counting at 0. By default, our variable, mTCurrent, holds a piece of numerical data, and its default value is 0. Therefore, unless we somehow change that number, our player will continue to play track 0 over and over.

        8. The following line of code is the next function declaration which creates the function named next(). It is also of the type void because it will not be returning any data either. Remember, a function returns data when it is typed as something other than void and when it has a return statement within it. This function is a bit more involved than the previous, as it has several more lines within it.

          1. public function next():void {
            1. if (mMix) {
              1. mTCurrent=Math.floor(Math.random() * mTList.length);
              2. } else {
                1. if (mTCurrent==mTList.length - 1) {
                  1. mTCurrent=0;
                  2. } else {
                    1. mTCurrent++;
                2. }
            2. }
            3. play();
          2. }

        9. What we have inside this function are a pair of nested if/else statements. Nested means that one is inside of the other. An if/else statement deals with at least 2 conditions. This means, one thing will happen under one condition, and another thing will happen under another condition.

        10. With the first part, the if portion of our first if/else statement, the script must first determine whether mMix is true. If it IS true, then it runs the code between the curly brackets that follow (mTCurrent=Math.floor(Math.random() * mTList.length);).

        11. Basically, what that line of code is doing is generating a random number. Now, that number canNOT be completely random. Why not? Well, if we have only 10 music tracks, but we generate a completely random number, that number could be something completely strange and irrelevant, such as 8,237.41. For one thing, it is far beyond the number of tracks within our array (mTList), and for another thing, it has a decimal. What kind of track would be track number .41 ? Instead, what we need is to generate a random number that is no greater than our current number of tracks, whatever that may be. Currently, we have 10 tracks, at least I do in my player; however, it could be more or less in your player or some other player. We're not certain how many tracks it will be: we only know that we want is the total number of tracks in our array.

        12. It turns out that there is something that I have introduced to you that tells us the total number of elements within an array, and that is the length property. Therefore, mTList.length would tell us how many elements (i.e. how many tracks) were within our array.

        13. There is also a code element that is part of ActionScript that will automatically generate a random number; however, it only generates a random number between 0 and 1. This means that it will be some decimal number less than 1 but greater than zero, such as 0.2, or 0.88, or 0.413. All of those numbers are greater than zero, but they are still less than one. Now, once again, how does that help us? We need a number between between 1 and 10 (or 0 and 9), so how do we get from those decimal numbers less than 1, to some whole numbers? The answer is that we multiply those decimals TIMES the total number of tracks that we have: 0.2 X mTlist.length, 0.88 X mTlist.length, 0.413 X mTlist.length.

        14. But what numbers will we get when we do that? Well, 0.2 is easy:
          0.2 X mTList.length = 2, and 2 is between 0 and 9 and it is a whole number without decimals. But, 0.88 and 0.413 are more complicated:
          0.88 * mTList.length = 8.8,
          and
          0.413 * mTList.length = 4.13.

          Those are both between 0 and 9, but they are decimal numbers. In fact, whatever random number we come up with, if we multiply it by our total number of tracks, we will always get some number between 0 and our total. Great, so what we need to do is type the following:
          Math.random() * mTList.length;

          You might've noticed that they are not whole numbers. They are NOT integers. To change them into integers, we must round them out to the nearest whole number.

        15. It turns out that flash also has a little built-in function that rounds numbers to the nearest whole number: Math.floor. If you were to put some number, say 7.22, in between the parentheses, what you'd get would be the nearest whole number. In this case, it would be rounded down to 7. This solves the last problem, then, so we must put our number between the parentheses of the Math.floor() function.

          We get our number with this: Math.random() * mTList.length;
          Therefore, we must put that between the parentheses as follows:
          Math.floor(Math.random() * mTList.length).

          Therefore, the first IF portion of our if/else statement reads as follows:

          1. if (mMix) {
            1. mTCurrent=Math.floor(Math.random() * mTList.length);
            2. } else {
            3. . . .
            4. . . .
          2. }

        16. However, when mMix in the if portion does NOT evaluate to true, but instead evaluates to FALSE, then it skips that code within the curly brackets. What it does instead is move on to the else portion of the if/else statement and runs the code there between its curly brackets instead.

          1. public function next():void {
            1. if (mMix) {
              1. mTCurrent=Math.floor(Math.random() * mTList.length);
              2. } else {
                1. if (mTCurrent==mTList.length - 1) {
                  1. mTCurrent=0;
                  2. } else {
                    1. mTCurrent++;
                2. }
            2. }
            3. play();
          2. }

        17. But here, we also have ANOTHER if/else statement. This is where the nested conditions occur.

        18. The first if statement that we have already examined, has to determine whether mMix is true or if it is false. This is essentially deciding if we want the songs to play all mixed up, or to play in sequence, in order. If mMix is true, then that means we want them mixed up (to shuffle).

        19. If mMix is false, then that means we want them to play in sequential order from 1 - 10 (or 0 -9, according to the array).

        20. So, let's consider that mMix is false, for example. This means that the tracks will play in sequence; but what happens when the track number reaches the end? What if the track number keeps going up, say to 14, or 15, or 88? We don't have 14 or 15, much less 88 tracks. That means that we have to have some way to start back at the beginning once we reach the end of the track list. Once we reach the number of tracks in our list, and right now it's 10, we have to start back at the beginning.

        21. As mentioned, we currently have 10 tracks, so that means the length of our array, mTList would come out to 10, perfect! However, there's one little problem, the last item of our array has an index number of 9. Recall, we start counting in arrays at the number, 0. So, our tracks are numbered 0 through 9 and NOT 1 -10. This will always happen with arrays: the last item of the array will always be one less than the total number of tracks. In an array of 45 items, the last item will have an index of 44. In an array of 178 items, the last item will have an index of 177. This means that someArray.length minus one will give us the last index number, which for our array (mTList), we'd type like so:
          mTList.length - 1.

        22. So how does that help us? Well, it will help us determine when we reach the last track number, when we reach the end, so that we know when to start over again. Recall, here, we also have 2 conditions:
          1. one: if we have reached the end of the array, then we must start back at the beginning;
          2. and two: if we have NOT reached the end of the array, then we should just count like normal in sequence.

        23. The if portion of our if/else statement, should ask if we have counted to the end of the array, if the current track number is equal to the last track number of the array:

          1. if (mTCurrent == mTList.length - 1) {

        24. If that is true, then we have to start counting at 0 again:

          1. if (mTCurrent == mTList.length - 1) {
            1. mTCurrent = 0;
          2. }

        25. If that is false, then that means we haven't gotten to the end of the array, and that we haven't counted to the last number; therefore, we can continue counting normally. We can just add one to the previous track number and increment it upwards.

          1. if (mTCurrent == mTList.length - 1) {
            1. mTCurrent = 0;
            2. } else {
              1. mTCurrent++;
          2. }

        26. Finally, whatever the condition, whether we've either counted upwards, started over from the beginning, or mixed up the tracks, we then must play the track. This means we must call or invoke the play() function.

          1. public function next():void {
            1. if (mMix) {
              1. mTCurrent=Math.floor(Math.random() * mTList.length);
              2. } else {
                1. if (mTCurrent==mTList.length - 1) {
                  1. mTCurrent=0;
                  2. } else {
                    1. mTCurrent++;
                2. }
            2. }
            3. play();
          2. }

        27. Now, let's try and simplify a few things. As always, when I say simplify, what that means is to provide a way of making things more efficient in the long run. At times, especially when creating a small script like this one, it may not seem so much more efficient; however, when typing more lengthy scripts, it is always much better. One of those ways is to create, as mentioned last week, a constructor.

        28. A constructor allows you to initialize a class instance with only a few properties. Now, that first sentence may seem very difficult to understand, with the new term constructor, together with the terms initialize, class instance, and properties, so let me break it down.

        29. To initialize means to set an object at its beginning or starting point.

        30. A class instance, you will recall from my discussion in class this past week, is a particular example of a class. If I were talking about one of MY CLASSES, I would be referring to students; and each individual student is an instance of one of my student classes. We create our classes in an .as file, and we create its instances in .fla files.

        31. A property, once again, is a characteristic of an object. In this case, our object is the class we create, and its properties are the variables and arrays we create in the class.

        32. Finally, back to where we started, a constructor allows you to start up (initialize) a new example of the class (an instance) by setting only a few of its absolutely required characteristics (properties).


          1. package {

            1. public class MPlay {

              1. public var mName:String="";
              2. public var mVolume:int=10;
              3. public var mTList:Array;
              4. public var mTCurrent:int=0;
              5. public var mMix:Boolean=false;


              6. public function MPlay(
              7. mName:String="",
              8. mVolume:int=10,
              9. mMix:Boolean=false
              10. ):void {
                1. this.mName = mName;
                2. this.mVolume = mVolume;
                3. this.mMix = mMix
                4. mTCurrent=0;
                5. mTList = new Array();
              11. }

              12. public function play():void {
                1. trace("Playing: " + mTList[mTCurrent]);
              13. }

              14. public function next():void {
                1. if (mMix) {
                  1. mTCurrent=Math.floor(Math.random() * mTList.length);
                  2. } else {
                    1. if (mTCurrent==mTList.length - 1) {
                      1. mTCurrent=0;
                      2. } else {
                        1. mTCurrent++;
                    2. }
                2. }
                3. play();
              15. }
            2. }
          2. }


        33. In order to test the class that we have so far, in the same folder, you'll need to create a new .fla file named myMPlay_ex.fla, and type the code in the actions panel that you see below:

          1. var myMPlay:MPlay = new MPlay("Carter's Music Player", 15, true);
          2. myMPlay.mTList =
            1. ["The XX - Crystalized", "Fever Ray - If I Had a Heart", "Crystal Castles - Celestica", "Animal Collective - My Girls", "Bat for Lashes - Moon and Moon", "New Order - Crystal", "Cut Copy - Hearts on Fire", "Of Montreal - Gronlandic Edit", "Janelle Monae - Many Moons", "The Rapture - Get Myself Into It"];
          3.  
          4. function onNextClick(evt:MouseEvent):void {
            1. myMPlay.next();
          5. }
          6.  
          7. next_btn.addEventListener(MouseEvent.CLICK, onNextClick);

        34. Once you do that, you'll need to follow the steps below as you did last week:
          1. In your .fla file, create a simple movieclip out of a rectangle or circle, or whatever you want by selecting it, choosing convert-to-symbol.
          2. Give it a name, select movieclip as type, and then click okay.
          3. Give this new movieclip the instance name of next_btn.
          4. When you test the movie and click on that button, it should activate the code and "play" the next song.

        35. The next step is to add a new property, but not one that is publicly available as those that we have typed up to now are. What we want is a variable that is set to private, which means it will NOT be available to modify. We use this for those variables or those properties that should not ever be changed, but which may be different for each class instance. The example that we used last week was the serial number. A serial number does not ever change, but it is different for each person and item.

          1. package {

            1. public class MPlay {

              1. public var mName:String;
              2. public var mVolume:int;
              3. public var mTList:Array;
              4. public var mTCurrent:int;
              5. public var mMix:Boolean;

              6. private var _mSerial:String;


              7. public function MPlay(
              8. mSerial:String,
              9. mName:String="",
              10. mVolume:int=10,
              11. mMix:Boolean=false
              12. ):void {
                1. _mSerial = mSerial,
                  1. /*
                    1. Notice that when I place the serial property above here, that I do not put underscore. That is because it is actually a different variable here in the constructor. The one without the underscore, is the one that will be available in the .fla file. The one with the underscore belongs here in the .as file.
                  2. */
                2. this.mName = mName;
                3. this.mVolume = mVolume;
                4. this.mMix = mMix
                5. mTCurrent=0;
                6. mTList = new Array();
              13. }

              14. public function play():void {
                1. trace("Playing: " + mTList[mTCurrent]);
              15. }

              16. public function next():void {
                1. if (mMix) {
                  1. mTCurrent=Math.floor(Math.random() * mTList.length);
                  2. } else {
                    1. if (mTCurrent==mTList.length - 1) {
                      1. mTCurrent=0;
                      2. } else {
                        1. mTCurrent++;
                    2. }
                2. }
                3. play();
              17. }
            2. }
          2. }

        36. Recalling from last week, if you were to try to trace() the value of mSerial, you would get an error. That is because it is set to private, but also because we haven't put it into the code in the .fla file:

          1. var myMPlay:MPlay = new MPlay("B031167", "Carter's Music Player", 15, true);

        37. Okay, now we're up to the part of the script that we did not get to last week and which is a little complicated. I want to add the get/set methods. These properties behave as if they were functions in that they not perform the actions of actually getting a value from a property and returning it for us to use; or setting a value, giving it the particular number or string that we desire.

        38. They are a pair of methods, and they have the same name. The get function is called whenever you need to read or see the property; and the set function is called when you want to assign a value (give a particular number or string) to that property.

        39. The reason we might want to use these two methods right now is because we may wish to change the current track number to something new, to set it to the next track number in sequence, from 7 to 8, or from 3 to 4, or from 22 to 23, for example; or we may wish to pick another track number at random.

        40. The variable that we have that pertains to the track number is named mTCurrent. Now, because we don't want this change just whenever, but only in particular circumstances, we'll first change it to a private property, and then we'll go about the get/set methods.

          1. package {

            1. public class MPlay {

              1. public var mName:String;
              2. public var mVolume:int;
              3. public var mTList:Array;
              4. public var mTCurrent:int;
              5. public var mMix:Boolean;

              6. private var _mSerial:String;
              7. private var _mTCurrent:int;


              8. public function MPlay(
              9. mSerial:String,
              10. mName:String="",
              11. mVolume:int=10,
              12. mMix:Boolean=false
              13. ):void {
                1. _mSerial = mSerial,
                2. this.mName = mName;
                3. this.mVolume = mVolume;
                4. this.mMix = mMix
                5. _mTCurrent = 0;
                6. mTList = new Array();
              14. }

              15. public function play():void {
                1. trace("Playing: " + mTList[mTCurrent]);
              16. }

              17. public function next():void {
                1. if (mMix) {
                  1. _mTCurrent=Math.floor(Math.random() * mTList.length);
                  2. } else {
                    1. if (_mTCurrent==mTList.length - 1) {
                      1. _mTCurrent=0;
                      2. } else {
                        1. _mTCurrent++;
                    2. }
                2. }
                3. play();
              18. }
            2. }
          2. }

        41. The first of the methods is simple and straightforward: all we need it to do is to get a value from the property of the same name. This means, we want it to get whatever value is held inside of _mTCurrent, we want this method to extract it and feed it back to us. We will then use that value in the next method:

          1. package {

            1. public class MPlay {

              1. public var mName:String;
              2. public var mVolume:int;
              3. public var mTList:Array;
              4. public var mMix:Boolean;

              5. private var _mSerial:String;
              6. private var _mTCurrent:int;


              7. public function MPlay(
              8. mSerial:String,
              9. mName:String="",
              10. mVolume:int=10,
              11. mMix:Boolean=false
              12. ):void {
                1. _mSerial = mSerial,
                2. this.mName = mName;
                3. this.mVolume = mVolume;
                4. this.mMix = mMix
                5. _mTCurrent = 0;
                6. mTList = new Array();
              13. }

              14. public function play():void {
                1. trace("Playing: " + mTList[mTCurrent]);
              15. }

              16. public function next():void {
                1. if (mMix) {
                  1. _mTCurrent=Math.floor(Math.random() * mTList.length);
                  2. } else {
                    1. if (_mTCurrent==mTList.length - 1) {
                      1. _mTCurrent=0;
                      2. } else {
                        1. _mTCurrent++;
                    2. }
                2. }
                3. play();
              17. }

              18. public function get mTCurrent();int {
                1. return _mTCurrent;
                }
            2. }
          2. }

        42. The second of the two methods, the set method, is a little more complicated to figure out. We now have the value that we attained from the get method. But in order to figure it out, let's recall what we're going to do with this property (the mTCurrent property of our MPlay class). This property lists the current track number, and by default it is set to 0.

        43. What we want to do is be able to change the track number, to move it up by one in the list sequentially, or change it randomly. If we change it sequentially, it would go from 1 to 2, or 5 to 6, or 44 to 45, depending on where we were in the list, and depending on how many tracks we have in our list, of course. We couldn't be on track 44 if there were only 12 tracks in our list. Therefore, we DO NOT WANT TO GO BEYOND OUR TOTAL NUMBER OF TRACKS. Moreover, WE DO NOT WANT TO GO TO A NEGATIVE NUMBER.

        44. There are two functions built-in to ActionScript that can help us with this, and they are the Math.min() and the Math.max() functions. The Math.min() function looks at two values, determines the smaller of the two, and returns that one. The Math.max() also looks at two values, but it determines the greater of the two, and returns that one.

        45. Given the two values, 12 and 8, Math.min() would determine that 8 was the lesser value and return that one as its value.

          1. var myValue:int = Math.min(12, 8);
          2. trace(myValue); // this would trace the value 8

        46. Given those same two values, 12 and 8, Math.max(), on the other hand, would determine that 12 was the greater value and return that one as its value.

          1. var myValue:int = Math.max(12, 8);
          2. trace(myValue); // this would trace the value 12

        47. So the question remains, how does this help us? If we are trying to make certain that we don't go over the total number of tracks, then how do these two methods aid us? Okay, so let's break it down:
          1. We want to change the value back to zero if we've somehow gotten a track number that is below zero, but let's go backwards one step, and that is to the very important statement that reads: mTList.length -1: right now, we have 10 tracks in our list, if our current track number, mTCurrent, is 10, that means we've gotten to the end of the list and that we must start over from the beginning at 0, (we count from 0 - 9 in an Array of 10 elements). Also, remember that mTList.length is always going to be one greater than the index number of the last track. For an array of 10 elements—our array has 10 songs—the last element has an index number of 9 (once again, we count from 0 -9 in an array).

            1. var mTCurrent:int = 10;
            2. var myValue:int = Math.max(mTCurrent, mTList.length - 1);
            3. trace(myValue); // this would trace the value 10, because, for our array, mTList.length - 1 will be 9.

          2. From our script, the line of code at the beginning of this function
            (public function set mTCurrent(value:int):void {
            is where we first see the variable named value. The other method of the pair of get/set methods, the get mTCurrent method, actually goes and gets the value of _mTCurrent. That value is used by the set mTCurrent method. It is placed inside the value variable in that first line, for later use later down inside the function.

          3. The next line of code:
            value = Math.max(0, value);)
            is going to compare the current value of the variable named value with 0. Obviously, any positive number other than 0 is greater than zero; so, only if the variable named value already has a value of something less than 0 will its value change. Only if it is negative will that line of code return zero as its value. This line of code is simply there to prevent negative numbers from entering into the picture. Remember, this line of code picks the GREATER of the two numbers; so, if 0 gets picked, that means that the variable named value had a value less than 0.

          4. The 2nd line of code inside the function,
            value = Math.min(value, mTList.length -1);
            is going to compare the current value of the variable named value with the total number of tracks minus 1, which in our case is going to be 9, since we have 10 tracks. This means that if at some point the variable, value, goes above the total number of tracks, the script will automatically return the total number of tracks. Essentially, this line of code does NOT allow that variable to get any higher than the total number of tracks.

          5. The 3rd line of code inside the function,
            _mTCurrent = value;
            sets whatever ends up being the value of the variable named value is also given as the value here to the variable that holds the current track number, _mTCurrent.
          6. Therefore, what we will have in the following new lines added to the script is code that prevent our track number from either being 0 or being greater than the total number of tracks.

          1. package {

            1. public class MPlay {

              1. public var mName:String;
              2. public var mVolume:int;
              3. public var mTList:Array;
              4. public var mMix:Boolean;

              5. private var _mSerial:String;
              6. private var _mTCurrent:int;


              7. public function MPlay(
              8. mSerial:String,
              9. mName:String="",
              10. mVolume:int=10,
              11. mMix:Boolean=false
              12. ):void {
                1. _mSerial = mSerial,
                2. this.mName = mName;
                3. this.mVolume = mVolume;
                4. this.mMix = mMix
                5. _mTCurrent = 0;
                6. mTList = new Array();
              13. }

              14. public function play():void {
                1. trace("Playing: " + mTList[mTCurrent]);
              15. }

              16. public function next():void {
                1. if (mMix) {
                  1. _mTCurrent=Math.floor(Math.random() * mTList.length);
                  2. } else {
                    1. if (_mTCurrent==mTList.length - 1) {
                      1. _mTCurrent=0;
                      2. } else {
                        1. _mTCurrent++;
                    2. }
                2. }
                3. play();
              17. }

              18. public function get mTCurrent():int {
                1. return _mTCurrent;
                }
              19. public function set mTCurrent(value:int):void {
                1. value = Math.max(0, value);
                2. value = Math.min(value, mTList.length - 1);
                3. _mTCurrent = value;
                }
            2. }
          2. }

        48. Lastly, we are going to modify one of our properties and allow you to see its value without actually being able to change it. This is known as read-only, and we do this with a get method, without using its couple at all, the set method. Therefore, if at some point part of your script tries to assign a value to the property or modify it in some way, ActionScript and Flash will give you an error and it will not read your code

        49. This is a perfect thing to do for a property like the _mSerial property. This will allow everyone to see it, but without allowing them to affect its value.

          1. package {

            1. public class MPlay {

              1. public var mName:String;
              2. public var mVolume:int;
              3. public var mTList:Array;
              4. public var mMix:Boolean;

              5. private var _mSerial:String;
              6. private var _mTCurrent:int;


              7. public function MPlay(
              8. mSerial:String,
              9. mName:String="",
              10. mVolume:int=10,
              11. mMix:Boolean=false
              12. ):void {
                1. _mSerial = mSerial,
                2. this.mName = mName;
                3. this.mVolume = mVolume;
                4. this.mMix = mMix
                5. _mTCurrent = 0;
                6. mTList = new Array();
              13. }

              14. public function play():void {
                1. trace("Playing: " + mTList[mTCurrent]);
              15. }

              16. public function next():void {
                1. if (mMix) {
                  1. _mTCurrent=Math.floor(Math.random() * mTList.length);
                  2. } else {
                    1. if (_mTCurrent==mTList.length - 1) {
                      1. _mTCurrent=0;
                      2. } else {
                        1. _mTCurrent++;
                    2. }
                2. }
                3. play();
              17. }

              18. public function get mTCurrent():int {
                1. return _mTCurrent;
                }
              19. public function set mTCurrent(value:int):void {
                1. value = Math.max(0, value);
                2. value = Math.min(value, mTList.length - 1);
                3. _mTCurrent = value;
                }
              20. public function get mSerial():String {
                1. return _mSerial;
              21. }
            2. }
          2. }

        50. And lastly, you will need to add a trace() statement to your .fla file as follows:

          1. var myMPlay:MPlay = new MPlay("Carter's Music Player", 15, true);
          2. trace(myMPlay.mSerial);



      • MIDTERM—Exercise 2:    For the next part of the homework, close PART II of the project above with the GET/SET methods and REOPEN the FIRST PART. You are going to have to try to do something on your own: as mentioned in last week's homework, you will now have to try and use another instance of that movieclip button that you have created and make it activate a BACK/PREVIOUS method of your own creation that goes backward to the track before the current track. I know this is not an easy thing for you to try and figure out, but please do.

        100% success is NOT the most important thing. A SERIOUS and SINCERE EFFORT IS!!!.

      • MIDTERM—Exercise 3:    Since little new is added here, please be prepared to answer questions about the material here.