Friday, 21 May 2010
Module Evaluation
During this project I came across a number of problems which some I was able to solve but some are still yet to be solved.
The first main problem I had was the actionscript used for the drag and drop function so the user could move the stickers around. The actionscript that was going to be used originally was going to be placed on the layer of each sticker and just changing the instance name. See Blog Post. The problem with this actionscript is that because the stickers are within the sticker book movieclip, the stickers move up and down when the sticker book is opened and closed so I needed to find a way of making the sticker come out of the sticker book movie clip when it is released. I did this by making the sticker, that is dragged from the movieclip, move to -1000000 on the y axis and attaching the same sticker movieclip when the mouse is released so the user can't tell its a different movieclip but this way the stickers don't move when the sticker book does. See Blog Post.
When the sticker book is closed there is a tab with a movieclip on it with text that says 'Sticker Book' inside it. When the user clicks on this, the sticker book opens and then the user can still see the sticker book text but above this they can now see another movieclip with text that says 'Close' inside it so when the user clicks on this is closes the sticker book. I wanted to make it so when the user clicked on the sticker book text it changed to close and when they clicked on close it would change back to sticker book. I tried finding out ways I could do this and I did try a number of different pieces of actionscript but I couldn't get any to work therefore this still has to be solved.
Another problem I had was making the print button work on the postcard page and this is a problem that still has to be solved. I created a movieclip with the text 'Print' inside it and placed it on the postcard page and because I have never created a print button in flash before, I looked for tutorials on the internet and looked in flash books. I found a number of different pieces of actionscript that used the print function but I couldn't get a lot of them to work. I found some actionscript that worked when I placed it on the print button and when I previewed the movie in flash and pressed the print button, it printed the postcard exactly as I wanted it to. The problem is, when I uploaded the game to the internet and previewed the game in the browser, the print button worked as it did print something but it wasn't the postcard like it was when previewing it in flash and instead it just printed out a blue page. I looked on the internet again to try find a way to fix this but failed therefore this is something that needs a bit more time to be able to solve. See Blog Post.
I wanted to make the game so the user could go to the next level after collecting all the stickers, which I managed to achieve, but I also wanted the game to allow the user to go back to a previous level and view what they had collected. I had a real problem with this because everytime I tried to make it work, when it came to testing it, instead of taking the user to the previous level and showing they had answered all the questions and showing all the stickers they had collected in the places that the user put them, it just took the user back to the previous level but with no stickers available so the user had to answer all the questions again. Because I was running out of time at this point, I decided to leave it and maybe go back to it if I had time at the end.
How the Product Works:
This game has been created using flash and works by different pieces of actionscript being placed on objects on different layers within different timelines to tell the movie what to do when the user does a certain thing. To play the game the user basically has to enter the game and click on the questions and answer them correctly in order to unlock a sticker which can then be dragged from the sticker book and onto the island. When all the questions have been answered correctly on all the levels, the user wins a postcard at the end which can then be printed pressing the print button. The print button works because of the actionscript that has been placed onto the print button movieclip.
Testing & Feedback:
I did some user testing but because I was so late in finishing my flash game, I found it difficult to find children aged between 6 and 8 years old to test it. Therefore I asked a few people that were a bit older to see what feedback I got from them. The questions I asked for my user testing were originally aimed at the target audience, children, so the answers I got back from older people might be slightly different because the game will be easier for them to play. The questions I asked were:
1. Did you find it easy to start the game?
2. Did you know how to open and close the sticker book?
3. Did you find the questions easy or hard?
4. Did you know how to move the stickers around on the page?
5. Did you know how to get to the next level?
6. Did you like the background music?
7. At the end of the game did you find it easy to get to your postcard?
8. Did you like the game?
9. Did you think the game was fun?
10. Did you understand how to play the game?
11. Was the writing easy to read?
12. Did you get stuck at any time?
13. What was your favourite bit of the game? Why?
14. How could the game be improved?
From the people I asked they all said they really enjoyed playing the game and they knew how to do certain things on the game such as opening and closing the sticker book, moving to the next level etc. The all commented on the music saying that it was good and appropriate for each level and one person said that the sound effects added atmosphere to the game. The things people liked the most about the game included the sound effects on each level and the fact they received stickers as a reward of getting questions correct. One person also commented on the design saying that the design and the images appeal to the right age group. When asked what could be improved on the game, I received some helpful feedback. Some of the people asked were a bit confused when entering the first level as it took them a while to figure out how to get to the first question. Their suggestion was maybe putting an arrow above question 1 that says 'Click here' or something along those lines. They also said a variety of questions would have been more fun and interesting and also more imagery is needed on the underwater level to indicate that they are underwater.
Although I am disappointed I couldn't get any feedback from the target audience, I am pleased with the feedback I got and I think this feedback would help me to improve my game by making it more understandable and more fun and interesting for the user.
Evaluation & Appraisal:
I am pleased with how my self initiated went and I feel like I have learnt a lot from doing this. Although I learnt a lot from this project, I have found it challenging and I haven't been able to do everything I originally proposed at the start of the project. I was originally going to have a number of different questions for each question number and when the user clicked on the button it would randomly pick and display a question so they could play it more than once without getting the same questions so it makes it more fun. As I started to run out of time, I decided to just have one question for each question number. I also wanted to make it so the postcard at the end would display the islands that the user actually created (showing the stickers in exactly the same place as the user placed them on the screen) and having the option to print the page and also send the postcard to some one they know by entering the person's email address. This is the first time I have used actionscript other than gotoAndPlay() etc, so I did find it quite difficult but I enjoyed learning it and trying different pieces of actionscript until a certain thing worked as I wanted it to.
There are a lot of improvements that I could make to this project. I would like to improve the questions on each level so that there are a number of different questions for each one and they are randomly picked when the user clicks on a question so the user would get a different question everytime they played the game so they wouldn't get bored. Another thing I planned to do but didn't have time to do was making it so the user could go back to the last level. I have only made it so the user can go to the next level and I did try making it so the user could go back to the last level but it displayed the level with none of the questions answered and the user had to unlock all the stickers again. If I had more time I would have research this and tried to find a solution. I think to make the game better and more interesting and fun for the user, some of the objects could have been animated e.g. the clouds moving across the sky, or the sea moving (little waves), and even the eyes moving on the characters I created. Another thing that would have been good to put on the game are control buttons for the music such as play, stop pause. This would have given the user a choice whether they wanted to listen to the music or not where as at the moment they don't have a choice as the music is always on unless they turn the sound off on their computer. From the user testing I have found out other ways to improve the game also. One of these has already been mentioned above and this was to include a variety of questions so the user doesn't get bored. Another way to improve it was to make it more clear where the user has to click to get to the first question. The last thing the users that were testing the game suggested was to use more imagery on the underwater level because they felt that there wasn't enough when entering the game to indicate that they were underwater.
Overall I am pleased with how this project has gone and although there is a lot of room for improvement, a lot has been learnt during this project and I do feel a lot more confident using flash than I did at the start of the project.
Adding Music to a Level
Linking the Levels Together
on (release) {
this._y = -10000000
loadMovieNum("beachlevel21.swf", 1);
}
This code means that when the user clicks on the play button, it will move to -10000000 on the y axis so the button can't be clicked during the game and then it loads beach level 21.
Then to get from the first level to the second level I put the following actionscript onto the jungle button:
on (press) {
this._parent.removeMovieClip();
loadMovieNum("junglelevel8.swf", 1);
}
on (release) {
stopAllSounds();
}
this actionscript means the when the button clicks on the jungle level it will remove the current movieclip (the beach level) and load the jungle level and also when the user release their mouse, it stops all the background music.
This is how all the levels and the introduction and postcard pages were linked together.
Postcard Page
On the postcard I also had a print above. It was meant to be so the user could click print to print the postcard they had won so they actually got something out of playing the game. The actionscript I used on the print movieclip was:
on (release) {
print(postcard.swf, "bframe")
}
When testing the movie in flash it printed the postcard with no problem but when it is online, it doesn't print the postcard and instead just prints a blue page.
Introduction Page
Thursday, 20 May 2010
Making the Jungle Level and the Underwater Level
Wednesday, 19 May 2010
Tuesday, 18 May 2010
Monday, 17 May 2010
Changing how the user can arrange the stickers
Closing the sticker book
_root.closeStickerBook = function() {
var yStickerTween:Tween = new Tween(_root.stickerBook, "_y", Regular.easeOut, -72, - 330, 1, true);
};
I then went inside the sticker book movieclip and clicked on a sticker and put the following actionscript underneath the on(release) section:
_root.closeStickerBook()
This was placed on all the stickers.
Tuesday, 11 May 2010
Drag and Dropping the Stickers
on (press) {
startDrag(this);
}
on (release) {
this.stopDrag();
}
The problem with this code is, because the stickers are within the stickerbook movie clip, when the user drops the sticker onto the island it is fine but when the stickerbook is not displayed on the stage, the sticker also moves with the stickerbook movieclip so I need to make it so when the user releases the sticker, it removes the sticker movieclip that is within the stickerbook movie clip and replace it with the same sticker which will be outside of the stickerbook movieclip so when the stickerbook is not displayed, it won't affect the stickers that the user has already placed on the island.
This actionscript is saying that when the user releases the sticker, it is going to attach the movieclip 'starfish' and then where abouts to place the starfish movieclip on the x and y axis and also how big or small to make the movie clip. I have chosen to make the movieclip that is being attached to be slightly bigger than the sticker that is in the stickerbook so it is more fun for the user.
Displaying the sticker book when a question is answered correctly
This actionscript is telling the movieclip to bring the question buttons back onto the stage and also if the answer the user chose is correct then open the sticker book. Then it tells the movie clip to remove the current movieclip which is the question.
Once the user has clicked ok then sticker page is displayed but the next bit of code is needed to make it appear and it is played within the actionscript layer on the main timeline:
stop();
import mx.transitions.Tween;
import mx.transitions.easing.*;
_root.openStickerBook = function() {
var yStickerTween:Tween = new Tween(_root.stickerBook, "_y", Regular.easeOut, -330, -72, 1, true);
};
For each question that is answered correctly a different sticker is unlocked. The question movie clip will need to know which frame to go to in the stickerbook movieclip so I put the following actionscript on frame one within the question movieclip:
The actionscript above shows that if the user answer answers the question correctly, will will go to frame to within the stickerbook movie clip which will then display the unlocked sticker which is the starfish.
Creating the sticker book
Above: Shows frame one with all the stickers faded.
Above: Shows frame four with three unlocked stickers
Above: Shows frame six with all the stickers unlocked