Saturday, January 19, 2008

How to make a "torch" effect

In this tutorial I'm explaining the most basic way of doing it.

What's on stage?

Only 2 layers, the mask and the masked.



In layer 1, the masked one, I have an image and in layer 2, the mask, a MovieClip instanced as "torch".

The actionScript there is:

startDrag("torch", true);
Mouse.hide();

And that's all. With startDrag we tell the movie to drag our MovieClip with the mouse and then we hide our mouse.

Here you can see it in action





Download the source code here

Friday, January 18, 2008

Shots in the Darkness

After a week looking for a sponsor, I decided to release Shots in the Darkness with MochiAds. Yesterday I started promoting it and today I submitted it to Newgrounds. It has a 3.2 score, which I think it's pretty good. I'll keep you up to date with the MochiAds earning, so you can judge if they're useful.

Here you can play the game:

Monday, January 14, 2008

Looking for sponsor

I haven't wrote anything in the last days because I was looking for a sponsor for my new game. I haven't found any yet, so I've made a decision: if on Friday I still haven't got a sponsor, I'll release it with mochiads.

Tuesday, January 8, 2008

Adding game

Let me show you "Learn to Add Up", a game we made for young children that ended in failure. Why? Because pages that offer games for kids don't sponsor games, and pages that sponsor games don't want games for young children. Maybe I can use MochiAds and MochiBot, as a little experiment...

Play it


Thursday, January 3, 2008

Flash "Find the differences" game creation tutorial - Part 2b

Let's have a look at the actionscript in the "4 differences" game:

Frame 1:

Contains:
-1 button, instanced as playbutton (the red one with the "play the game!" text)

Actionscript:

stop();
playbutton.onRelease = function() {
gotoAndPlay(2);
}


Very easy: telling the game to stop at Frame1 (stop();) and telling it to go to Frame 2 if the "playbutton" is released.

Frame 2:

Contains:



1 - 2 similar images
2- 4 MovieClips, instanced as "Rect1", "Rect2", "Rect3", "Rect4"
3- A dinamic text instanced as "congrat"
4- 4 buttons instanced as "Df1", "Df2", "Df3", "Df4"
5- A MovieClip called Timebar, without instance name

*Remember we have the "cursor" MovieClip in our library, linked as "cursor"

Actionscript:

stop();
differences_left = 4;

//Setting a new variable, "differences_left" and setting it to 4
Mouse.hide();
attachMovie("cursor", "cursor", 1);
cursor.onEnterFrame = function() {
this._x =
_xmouse;
this._y
= _ymouse;
};

//Hidding the mouse and attaching the cursor MovieClip and telling it //to have the same _x and _y coordinates as the mouse.
Df1.onRelease = function() {
// If you click on the 1st difference...
differences_left -= 1;
// The variable "differences_left" is decreased by 1
_root.Rect1._x = this._x;
_root.Rect1._y = this._y;

// The "Rect1" MovieClip's _x and _y become the same as the "Df1" //button _x and _y
Df1._x = 1500;
// And then, the "Df1" button's _x becomes 1500, so you can't see or //click on it
if(_root.differences_left == 0){
gotoAndPlay(3);
}

// Checking if the variable "differences_left" is 0, if so telling the //game to go to Frame 3, the one with the "You win" text
_root.congrat.text = "You found a difference! Only " + differences_left + " more to go";
// Making the "congrat" text become "You found a difference! Only x //differences more to go", where x is the current value of the //variable "differences_left"
};
Df2.onRelease = function() {
differences_left -= 1;
_root.Rect2._x = this._x;
_root.Rect2._y = this._y;
Df2._x = 1500;
if(_root.differences_left == 0){
gotoAndPlay(3);
}
_root.congrat.text = "You found a difference! Only " + differences_left + " more to go";
};

// The same as in the "Df1" button
Df3.onRelease = function() {
differences_left -= 1;
_root.Rect2._x = this._x;
_root.Rect2._y = this._y;
Df3._x = 1500;
if(_root.differences_left == 0){
gotoAndPlay(3);
}
_root.congrat.text = "You found a difference! Only " + differences_left + " more to go";
};

// The same, too
Df4.onRelease = function() {
differences_left -= 1;
_root.Rect4._x = this._x;
_root.Rect4._y = this._y;
Df4._x = 1500;
if(_root.differences_left == 0){
gotoAndPlay(3);
}
_root.congrat.text = "You found a difference! Only " + differences_left + " more to go";
};

// The same again


Now let's check what's inside the "Timebar" MovieClip:



5 Layers: stroke, mask, fill, dots and background

Take special attention at the masking (highlighted with a red rectangle in the image). The layer Mask is masking the layers "fill" and "dots", but not the layer background. (You can modify masking by right clicking on the layer>properties )

The layer Mask contains a MovieClip instanced as "bar".


And now, see the actionscript in the "Timebar" MovieClip (not inside it) :

onClipEvent(enterFrame){
this.bar._x -=0.25;
// The "bar" MovieClip's _x decreases
if(this.bar._x<=0){
// If it's _x gets to 0...
_root.gotoAndPlay(4);
// The game goes to Frame 4 ( the loser one )
}
}


Frames 3 and 4 only have a static text saying "Loser" or "You win" and a stop(); in its actions layer