小角色闪客 2003-12-21 00:04
[整理]flash的AS简单图文系列教程
[▓系列教程1▓]FLASH脚本的编写方法及基本脚本的使用
FLASH脚本的编写方法及基本脚本的使用
<br>
一、关于如何编写flash中的脚本
首先,要知道编写脚本,不需要用户对AS有完全的了解!
现在要考虑的问题是,如何在你的flash中添加编写脚本?简单的说,添加脚本可分为两种:一是把脚本编写在时间轴上面的关键桢上面(注意,必须是关键桢上才可以添加脚本)。二是把脚本编写在对象身上,比如把脚本直接写在MC(影片剪辑元件的实例)上、按钮上面。
此外,大家也需要简单理解一下flash是如何执行你编写的脚本的。当你在时间周的关键桢上添加了脚本,那么当flash运行的时候,它会首先执行这个关键桢上的脚本,然后才会显示这个关键桢上的对象。
还有一些简单的知识,AS中的对象都包括什么呢?它可以包含数据,也可以是舞台上的电影剪辑,也可以是舞台上的按钮等。既然包含了那么多对象,那么每种对象肯定有各自的属性!比如电影剪辑(movieclip)对象,它的属性就有:_height(高度),_rotation(旋转),等,这些属性不需要你去特意的记忆,当使用的时候可以随时翻阅脚本字典。在以后的教程中会陆续给大家介绍一些基础脚本的使用技巧。
废话少说,开始这次教程的例子吧
二、本次教学需要学到的基本AS命令如下:
stop()、play()、gotoandplay()、gotoandstop()、nextFrame()、prevFrame();、nextScene()、prevScene();、stopAllSounds(); 按钮的AS编写规则
三、实例制作
为了能更清楚的认识这些简单的命令,咱们就从一个最简单的例子开始!
首先看一下例子,简单的控制影片的[color=#FF0000]播放、暂停、前进、后退、停止[/color]
<br>
[URL=http://bbs.graphicvale.com/uploadImages/200352816303779409.rar]点右键目标另存为下载源文件[/URL]
<br>
[flash=500,350]http://bbs.graphicvale.com/uploadImages/200352816305064715.swf[/flash]
<br>
1、 打开flash,按ctrl+F8,新建立一个影片剪辑,并起名字为mo。需要先做一个简单的移动动画的影片剪辑。就做一个圆形的滚动效果吧。
<br>
[IMG]http://bbs.graphicvale.com/uploadImages/20035281664954556.jpg[/IMG]
<br>
2、 回到舞台工作区,按F11打开库,将mo影片剪辑拖放到舞台中。并给这个实例起个名字叫mc。(现在就可以按ctrl+回车测试效果,你可以看到这个圆形一直在不停的移动。)
3、 添加脚本,现在要让这个mc在影片一开始不要自动播放,不然怎么来控制它呢。咱们把脚本写在时间轴的关键桢上。选中时间轴的第一桢,按F9打开动作面板,选择专家模式,输入:_root.mc.stop(); (_root代表舞台,这个脚本的意思就是,舞台上名字叫mc的实例停止播放。)
4、 现在咱们来制作几个按钮,分别表示播放、暂停、前进、后退、停止。并摆放在舞台上。关于按钮的制作方法我就不多介绍。
<br>
[IMG]http://bbs.graphicvale.com/uploadImages/20035281672744750.jpg[/IMG]
<br>
5、 现在要添加控制影片的脚本。这次把脚本直接写在舞台上这些按钮的身上。选中播放按钮,打开动作面板,输入:
on (release) {
_root.mc.play();
}
如果要在按钮身上写脚本的话,必须使用on(事件){//脚本程序}的格式来写!上面的脚本作用就是:当你在这个按钮上按一下鼠标(release事件)的时候,就会执行下面的_root.mc.play();程序,它的意思是让舞台上的mc开始播放!
6、同理:咱们选中舞台上的暂停按钮,在它上面输入:on (release) {
_root.mc.stop()}
然后依次在快退上输入:on (release) {
_root.mc.prevFrame(); //prevFrame表示回到动画的上一桢
}
在快进的按钮上输入:on (release) {
_root.mc.nextFrame();
}
在停止的按钮上输入:
on (release) {
_root.mc.gotoAndStop(1);//跳到mc影片的第一桢,并停止播放!
}
<br>
好了,到现在为止就结束啦,你可以按ctrl+回车测试一下你的成果咯~
<br>
如果有什么疑问的话,下面发帖子问!
<br><br><br><br><br>
小角色闪客 2003-12-21 00:11
▓系列教程2▓-按钮的AS编写规则
[color=#FF0000]按钮的AS编写[/color]
<br>
先看一下效果[upload=swf]viewfile.asp?ID=83301[/upload]
[flash=500,350]http://www.flash8.net/viewfile.asp?ID=83301[/flash]
<br>
源文件下载:
<br>
[upload=rar]viewfile.asp?ID=83302[/upload]
<br>
在flash中的交互功能一般是由按钮来完成的。掌握按钮的编写规则也是一个闪客的基本技能。
Ok,现在咱们来说说按钮脚本如何编写。上一讲中提过,AS脚本编写可以写在时间轴的关键桢上,也可以写在对象本身上面。按钮也不例外,既可以写在时间轴上,也可以写在按钮本身上面。只不过这两种编写规则都要遵循一定的规矩,这是后话。
现在咱们来做一个例子,做一个按钮,这个按钮要实现的功能就是打开一个指定的网页。(这个例子非常基础,用这个例子来讲解按钮AS两种编写方法。)
第一种:把脚本写在按钮本身。
一、 在舞台上绘制一个矩形,选中矩形并按F8,将这个矩形转换成按钮元件。
二、 编写动作脚本:
选中按钮,按F9,打开动作面板,在专家模式下输入以下脚本:
on(release){
getURL("http://www.flash8.net/index.asp,”_blank”)
}
现在这个按钮就实现了一个打开网页的功能。通过例子你应该注意到,按钮的AS书写规则就是:
on(事件){
//要执行的脚本程序,刚才的例子是用getURL来打开一个网页。你也可以使用脚本程序来执行其他功能,例如跳转到某一个桢,或载入外部一个动画文件。
}
大可以看到,其实就一个on语句,这个on语句就是按钮的AS编写规则了。需要注意的是on里面的事件,这个事件你可以理解为是鼠标或键盘的动作。刚才的例子我们使用的事件是release(按一下鼠标)我现在把常用的按钮事件列出来:
事件名字 说明
Press 事件发生于鼠标在按钮上方,并按下鼠标
Release 发生在按钮上方按下鼠标,接着松开鼠标时。也就是“按一下”鼠标
Releaseoutside 发生于在按钮上方按下鼠标,接着把光标移动到按钮之外,然后松开鼠标
Rollover 当鼠标滑入按钮时
Rollout 当鼠标滑出按钮时
Dragover 发生于按着鼠标不放,光标滑入按钮
Dragout 发生于按着鼠标不放,光标滑出按钮
Keypress 发生于用户按下特定的键盘按键时
<br>
下面来看看第二种按钮AS的编写方法。
这种方法是把脚本程序写在时间轴上,而不是按钮本身上面。
一、 选中按钮,在下面的属性面板中为按钮起一个名字,这里我起了一个bt
二、 选中时间轴的第一桢,按F9打开动作面板。输入如下脚本:
bt.onrelease = function() {
getURL("http://www.flash8.net/index.asp";, "_blank");
};
这种编写AS的方法要遵循的规则就是下面的公式而已:
按钮实例的名字.事件名称=function(){
//要执行的脚本程序。
}
大家只要记住这个公式就可以套用了。
<br>
按钮的AS就先将到这了,这个可以算是基本技能了。希望大家都能掌握。:)
<br><br><br>
小角色闪客 2003-12-21 00:14
▓系列教程3▓-影片剪辑的AS编写规则
[color=#FF0000]电影剪辑动作的编写[/color]
<br>
电影剪辑在flash中可以说是使用最多的一种元件了,那么对于它的AS也是不少。
在讲解之前,我还是要重新说一下电影剪辑AS的编写规则,和上次讲按钮一样,分为两种,一种是写在电影剪辑本身上,一种是写在时间轴上面。
一、首先咱们先来做个简单的小例子。
或许你不用AS就能做出一个小球的移动动画。但是如果让你用AS来实现小球的移动呢?下面来看看如何用AS来实现吧。
在这个例子里,你首先会了解到如何在电影剪辑本身上编写AS,以及编写规则。
1、 新建立一个电影剪辑元件,里面你就随便画一个圆吧。之后把这个影片剪辑拖放到舞台之中(也就是创建一个此影片剪辑的实例)。
2、 现在开始编写脚本,选中这个MC,按F9打开动作面板,按照图
<br>
[IMG]http://bbs.graphicvale.com/uploadImages/20036116352417898.jpg[/IMG]
<br>
显示选择onClipEvent,之后在显示的事件中选择enterFrame,然后在里面编写脚本如下:
this._x+=5
<br>
这个脚本编写之后应该是:
onClipEvent (enterFrame) {// enterFrame的意思四以影片帧频不断地触发此动作
this._x += 5; //this代表这个影片剪辑自身。_x表示影片剪辑的X轴坐标。
}
<br>
[IMG]http://bbs.graphicvale.com/uploadImages/2003611636627770.jpg[/IMG]
<br>
呵呵,按下你的ctrl+回车测试一下吧,一个简单的移动动画就搞定了。
<br><br>
从这个例子咱们不难看出,如果把AS写在影片剪辑本身上,那么它是有自己的书写格式的。正确的书写格式就是:
onClipEvent (事件) {
//需要执行的脚本程序
}
这个可以看成是公式,你记住就行了,是写在影片剪辑身上的。括号里的“事件”其实是个触发器,当事件发生时,执行该事件后面花括号中的语句。,具体有哪些事件,我把它们都列出来。
- load 影片剪辑一旦被实例化并出现在时间轴中时,即启动此动作。
- unload 在从时间轴中删除影片剪辑之后,此动作在第一帧中启动。处理与 Unload 影片剪辑事件关联的动作之前,不向受影响的帧附加任何动作。
- enterFrame 以影片帧频不断地触发此动作。
- mouseMove 每次移动鼠标时启动此动作。_xmouse 和 _ymouse 属性用于确定当前鼠标位置。
- mouseDown 当按下鼠标左键时启动此动作。
- mouseUp 当释放鼠标左键时启动此动作。
- keyDown 当按下某个键时启动此动作。使用 Key.getCode 方法获取最近按下的键的有关信息。
- keyUp 当释放某个键时启动此动作。使用 Key.getCode 方法获取最近按下的键的有关信息。
- data 当在 loadVariables 或 loadMovie 动作中接收数据时启动此动作。当与 loadVariables 动作一起指定时,data 事件只发生一次,即加载最后一个变量时。当与 loadMovie 动作一起指定时,获取数据的每一部分时,data 事件都重复发生。
<br>
了解了事件之后,你可以自己试着修改一下脚本,如果让你们点一下鼠标,舞台上的圆就移动一下,该怎么做呢?
<br><br>
关于把AS写在影片剪辑本身的例子先讲到这,下面来看看如果把AS写在时间轴上面的话,应该怎么写。
<br>
首先你把刚才的脚本去掉。然后需要为这个影片剪辑实例起一个名字,比如起名为mc
在选中时间轴的第一桢,打开动作面板,输入以下脚本:
mc.onenterframe = function() {
this._x += 5; //你也可以把这句改为mc._x+=5 自己想一下为什么。
};
<br>
显而易见,在时间轴上的写法就应该套用以下公式:
实例名.事件名称=function(){
//脚本程序
}
需要注意的是,这种写法的事件名称不要忘了在前面加一个on,比如,事件如果是enterframe的话,你就应该写成onenterframe
<br>
下面简单说一下影片剪辑的属性。比如,影片剪辑有自己的X、Y轴坐标,有自己的透明度(_alpha),这些都是它的属性。
那么如何使用这些属性呢?你可以使用“点”语法来对属性进行设置。
把上面的脚本修改一下。
mc.onenterframe = function() {
mc._x += 5;
mc._alpha = random(100);
};
这里我加了一句this._alpha = random(100),它是设置影片剪辑的透明度的,使用的语句就是_alpha。后面的random()函数是随机选取一个100以内的数字作为它的透明度。从这个句子可以看出,“点”语法使用方法就是:实例名.属性(mc._alpha),你甚至可以简单理解为“点”就是“的”,那么this._alpha这句你就可以理解为:影片剪辑mc的透明度
上面的脚本mc._alpha = random(100)也可以改为_root. mc._alpha = random(100)
那么,你就可以理解为:舞台上的影片剪辑mc的透明度是随机选择100内的值。
关于影片剪辑的AS基本编写规则就说到这里,以后在具体的例子当中相信会更深刻的理解。 :)
<br>
小角色闪客 2003-12-21 00:20
如何使用动态文本以及脚本编写
一、flash中的动态文本使用方法
在flash中,文本工具提供了三种文本类型。分别是:静态文本、动态文本和输入文本。
<br><br>
[IMG]http://bbs.graphicvale.com/uploadImages/20036416493541913.jpg[/IMG]
<br>
下面讲解的内容属于[color=#B22222]动态文本的AS编写规则[/color]。要创建一个动态文本非常简单,只需要选中文本工具,然后选择动态文本类型,然后在舞台上拖拽出所需要的动态文本框就行了。
二、如何为动态文本赋值
当在舞台上拖拽出动态文本框之后,可以直接在里面进行文本输入或粘贴外部文本内容。
那么用AS如何来对动态文本框赋值呢?在这里为大家介绍两种方法进行赋值!
1、使用动态文本的实例名字来赋值
操作步骤:
(1)在舞台上创建一个动态文本框,并为这个动态文本实例起一个名字,例如test
<br>
[IMG]http://bbs.graphicvale.com/uploadImages/2003641650360293.jpg[/IMG]
<br>
(2)选中时间轴的第一桢,打开动作面板,输入以下脚本:
test.text = "为动态文本赋值"
按下ctrl+回车就可进行测试了。从这个简单的例子可以知道,如果要用文本实例名字来进行赋值的话,必须使用以下格式:动态文本实例的名字.text=”需要赋值的内容”
<br>
2、使用变量来赋值
(1)在舞台上创建一个动态文本框,并为这个动态文本实例起一个变量名text。
<br>
[IMG]http://bbs.graphicvale.com/uploadImages/20036416503279333.jpg[/IMG]
<br>
(2)选中时间轴的第一桢,打开动作面板,输入以下脚本:
test = "为动态文本赋值!"
不难看出,使用变量赋值更为简单实用!赋值格式为: 变量名=“赋值的内容”
<br>
以上两种赋值方法如果内容过多需要换行的时候,需要使用行用回车符(“
”即 ASCII 13)分隔!
三、如何载入外部txt文本里的内容
当内容过多的时候,使用上面的方法并不是太好,我们可以使用下面的方法,从外部获取文本资料内容!而外部的资料内容就放在一个普通的txt(记事本)文件中。
<br>
具体操作步骤如下:
1、创建一个动态文本实例,并并为这个动态文本实例起一个变量名text
2、选中时间轴的第一桢,打开动作面板,输入以下脚本:
loadVariablesNum("text.txt", 0);//载入外部名字叫text.txt的文本文件,加载级别为0
3、现在来准备外部的text.txt文本文件了。注意:要把这个文本文件和你刚才做的flash文件放在一个文件夹里!
这个txt文件里的资料应该按照如下格式编写:flash中动态文本变量的名字=这里就是所需要的资料内容。
对应上面的格式,外部text.txt中的内容为:test=哈哈哈,这样就行了。
最后一点,需要将这个文本文件保存为UTF-8格式。
<br>
[IMG]http://bbs.graphicvale.com/uploadImages/20036416511395357.jpg[/IMG]
<br>
4、 完成以上步骤之后,就可以进行测试了。
<br><br>
----------------------------------------------------------------------------------------------------------------------
下面介绍另外一种载入外部文本资料的方法,并介绍当文本内容过多时候,如何使用滚动条组件
(1)创建一个动态文本实例,并并为这个动态文本实例起一个实例名字mytest(注:是实例名而不是变量名)起一个变量名为test
(2)打开flash的组件面板(快捷键ctrl+F7),找到ScrollBar(滚动条)组件。按着它不动,然后拖放此组件至刚才的动态文本实例的右部边缘,如果成功的话,组件会和文本框结合在一起!
<br>
[IMG]http://bbs.graphicvale.com/uploadImages/20036416524355527.jpg[/IMG]
<br><br>
(3)选中舞台第一桢,编写如下脚本:
tt = new LoadVars();//创建一个 LoadVars 对象的实例,这里的实例名字叫tt
tt.load("text.txt");//创建的tt实例需要载入的对象是text.txt文本文件。
tt.onLoad = function(s) { //开始载入外部文件,具体格式请按照此例格式。参数s是指示 load 操作是否成功完成。如果完成,那么S的值就为true( 真),反之为false(假)
if (s) {
mytest.text = tt.test;
}//如果载入成功,则mytest文本框中的内容就等于tt.实例中的test的内容!(test是我们外部文本文件中的变量。)
};
(4) 至于外部的text.txt还可以使用刚才所创建的文本文件 ,为了测试滚动条的效果,你可以将内容适当的增多!
<br>
最后测试结果如图:
<br>
[IMG]http://bbs.graphicvale.com/uploadImages/2003641653899098.jpg[/IMG]
<br>
下面是源文件:
<br><br><br><br><br>
[upload=rar]viewfile.asp?ID=83304[/upload]
小角色闪客 2003-12-21 00:39
MC拖拽命令详细介绍
在网上经常看到的flash影片中有的对象可以被鼠标进行拖动。例如有的类似七巧板的拼图游戏,控制音量的滑杆等,所使用的就是flash中的拖拽动作。
<br>
一、拖拽命令详细介绍
<br>
1、首先介绍一下开始拖拽命令的详细用法,稍后在后面的例子中进行测试。
命令格式: StartDrag(要拖动的影片剪辑,[是否锁定到鼠标位置中央,左,上,右,下])
或写为
要拖动的影片剪辑.StartDrag([是否锁定到鼠标位置中央,左,上,右,下])
<br>
命令讲解:在制作动画的过程中,上面两种书写方法可任选一种。其中[]内的为可选参数,也就是可以写,也可以不写。至于左,上,右,下四个参数是用来控制被拖对象的移动范围。
<br>
2、停止拖拽命令讲解
<br>
命令格式: 被拖动的影片剪辑实例名.stopDrag()
<br>
这样就可以停止对对象的拖拽动作。
<br>
二、实例讲解
<br>
下面来用一个简单的例子实验拖拽命令。
<br>
操作步骤:
<br>
1、新建一个flash文档,并在舞台上绘制一个圆形。选中圆形并按F8,将此圆形转换为影片剪辑,起名为:圆 。确定后将会在舞台上创建一个圆的实例。如下图:
<br>
[IMG]http://www.pconline.com.cn/pcedu/sj/wz/flash/10306/pic/030618flashas0501.gif[/IMG]
<br>
2、选中此实例,并按F9打开动作面板。输入如下脚本:
on (press) {
this.startDrag(true);//当鼠标按下(press)之后,这个实例(因为我们把脚本写在实例本身了,所以这里用this代替影片剪辑实例的名字)可以被拖拽,使用命令如上面的命令解释。对于参数的选择方面,这里只填写了锁定到鼠标位置中央,如果想选不锁定到鼠标位置中央,可以把true改为false。有兴趣的朋友可以更改为false看看。
}
on (release) {
this.stopDrag();//同样道理,当鼠标释放(release)之后,将停止拖拽动作。
}
脚本书写如下图:
<br>
[IMG]http://www.pconline.com.cn/pcedu/sj/wz/flash/10306/pic/030618flashas0502.gif[/IMG]
<br>
3、好了,现在让我们按Ctrl+回车来测试一下吧,你将会看到舞台上的圆被你的鼠标拖动的效果。
<br>
4、OK,通过这个例子我们可以简单的应用拖拽动作了。现在需要把这个例子继续完成,还记得上面命令讲解中的左,上,右,下四个控制拖动范围的参数吗?现在来制作具有约束拖动范围的效果。
<br>
5、现在在舞台上绘制一个200*100大小的矩形,注意只要边框不要填充。如下图:
<br>
[IMG]http://www.pconline.com.cn/pcedu/sj/wz/flash/10306/pic/030618flashas0503.gif[/IMG]
<br>
6、如果我们希望在拖动的时候这个圆只能在矩形内拖动的话,就要先设置这个矩形的坐标,并记下矩形四个顶点的坐标(这点很重要!)。OK,比如,现在此例子中的矩形的四个顶点分别如上图所示。那我们要取的四个参数就应该是:左=50,上=100,右=250,下=200 现在打开动作面板,修改刚才的脚本如下:
<br>
on (press) {
this.startDrag(true, 50, 100, 250, 200);//这里我们就使用刚才确定好的4个参数。4个点的参数就对拖动对象实现了一个矩形区域的移动约束!
}
on (release) {
this.stopDrag();
}
<br>
脚本编写最后效果如下图:
<br>
[IMG]http://www.pconline.com.cn/pcedu/sj/wz/flash/10306/pic/030618flashas0504.gif[/IMG]
<br><br>
7、呵呵,迫不及待的想检测你的成果吧?好了,按Ctrl+回车去测试吧!
<br>
好了,关于拖拽的讲解先到这里,下面我们来学习如何结合着拖拽动作来检测对象之间的碰撞!不要走开哦 :)
<br>
[upload=swf]viewfile.asp?ID=83307[/upload]
<br><br>
[flash=350,350]http://www.flash8.net/viewfile.asp?ID=83307[/flash]
三、碰撞命令的讲解
<br>
命令格式: 目标影片剪辑的实例.hitTest(被拖拽的实例) 这个是比较简单的检测碰撞命令
<br>
目标影片剪辑的实例.hitTest(被拖拽实例的X轴坐标,被拖拽实例的Y轴坐标,对象的矩形区域范围还是对象本身范围) 这个是比较复杂点的检测碰撞命令
<br>
命令解释: 以上两个命令都是用来检测碰撞的,可以根据需要选择不同的命令。重点解释一下对象的矩形区域范围和对象本身范围(上面的命令中,false表示对象的矩形区域范围,true表示对象本身的范围)具体分别看下图:
<br>
[IMG]http://www.pconline.com.cn/pcedu/sj/wz/flash/10306/pic/030618flashas0505.gif[/IMG]
<br><br>
四、碰撞命令与拖拽命令的结合使用
<br>
(一)、下面通过简单的例子来学习碰撞命令(我们先来学习如何检测是否碰到对象的矩形区域范围)
<br>
1、新建一个flash文档,在舞台上绘制一个圆形。选中圆形并按F8将它转换为影片剪辑,起名:圆 。这样就在舞台上创建了一个圆的实例。 如下图:
<br>
[IMG]http://www.pconline.com.cn/pcedu/sj/wz/flash/10306/pic/030618flashas0506.gif[/IMG]
<br>
2、选中此实例,为它起一个名字,此例起名为:yuan 如图:
[IMG]http://www.pconline.com.cn/pcedu/sj/wz/flash/10306/pic/030618flashas0507.gif[/IMG]
<br>
3、选择文字工具,并选择文字类型为“动态文本”,在圆的实例下面拖绘出一个动态文本框。并起一个变量名为:tt 如下图:
[IMG]http://www.pconline.com.cn/pcedu/sj/wz/flash/10306/pic/030618flashas0508.gif[/IMG]
<br>
4、选中时间轴的第一桢,按F9打开动作面板,输入以下脚本:
<br>
_root.onenterframe = function() {
//这个是在时间轴上的AS编写规则,解释为舞台上每桢都执行下面的脚本(onenterframe)。
if (_root.yuan.hitTest(_root._xmouse, _root._ymouse, false)) {
//根据上面命令的讲解,这个语句就是检测碰撞了。如果鼠标碰到舞台上yuan这个实例的矩形区域范围的话,就执行下面的脚本。
tt = "接触矩形区域范围";//动态文本框就显示出“接触矩形区域范围”
} else {
tt = "没有接触到矩形区域范围";//如果鼠标没有碰到舞台上yuan这个实例的矩形区域范围的话,就显示没有接触到矩形区域范围。
}
}
第一桢上最后的完整脚本应该是如下图所示:
[IMG]http://www.pconline.com.cn/pcedu/sj/wz/flash/10306/pic/030618flashas0509.gif[/IMG]
<br>
5、OK,现在可以按Ctrl+回车去测试你的成果咯
<br>
[upload=swf]viewfile.asp?ID=83310[/upload]
[flash=350,350]http://www.flash8.net/viewfile.asp?ID=83310[/flash]
<br>
(二)、拖拽碰撞检测
<br>
现在再来一个例子讲解拖拽碰撞检测,想偷懒的话可以通过修改上面例子的代码来学习。
<br>
1、现在稍微修改一下上面的例子,以便让我们学习拖拽碰撞检测,在上面例子的舞台上绘制一个矩形,并把这个矩形转换成电影剪辑,起名为:矩形 。这样就在舞台上又创建了一个矩形的实例,现在为这个矩形实例起一个名为:juxing 。如下图:
<br>
[IMG]http://www.pconline.com.cn/pcedu/sj/wz/flash/10306/pic/030618flashas0510.gif[/IMG]
<br>
2、选中这个矩形实例,打开动作面板,输入可以拖拽这个实例的脚本。如下:
<br>
on (press) {
this.startDrag(true);
}
on (release) {
this.stopDrag();
}
<br>
这个脚本就是为了能拖动这个矩形实例。具体解释请参阅第一个拖动对象例子的脚本说明。
<br>
3、现在来修改脚本,选中时间轴的第一桢,按F9打开动作面板,你将会看到上个例子的碰撞检测脚本,把它修改为如下脚本:
<br>
_root.onenterframe = function() {
if (_root.yuan.hitTest(_root.juxing)) {
tt = "碰到了";
} else {
tt = "没有碰到";
}
}
<br>
这个脚本和上次的碰撞检测脚本类似,只不过不需要再书写X轴和Y轴,也不用写是否碰到矩形区域范围。简单吧 ^_^
<br>
完整脚本应该如下图所示:
[IMG]http://www.pconline.com.cn/pcedu/sj/wz/flash/10306/pic/030618flashas0511.gif[/IMG]
<br>
[upload=swf]viewfile.asp?ID=83311[/upload]
<br>
[flash=350,350]http://www.flash8.net/viewfile.asp?ID=83311[/flash]
结束语:相信你如果亲手成功完成了以上的例子(呵呵,比较多),你一定会掌握拖动对象以及碰撞检测的脚本编写。在实际的应用中,它们的用处非常广泛……
<br><br><br><br>
小角色闪客 2003-12-21 00:52
FLASH的流程控制与循环控制语句
众所周知,flash中动画依靠的是时间轴,在没有脚本的情况下,动画会依照时间轴从第一帧不停的播放到最后一帧,然后始重复播放或者干脆停止。为了能更好的控制动画,就必须使用脚本语句。而要想使动画具有逻辑判断的功能,就要使用流程控制和循环控制语句了!下面通过几个简单的小例子来学习流程与循环控制语句。
一、流程控制语句
<br>
所谓流程控制,无非就是我们想控制动画程序的执行顺序而已。我们可以让flash根据一些特定的条件,来决定要执行哪个程序。这样就好象给了程序一些判断的机制。
<br>
if...else控制语句
<br>
根据英文的意思,大家可以简单的理解上面的控制语句:如果...就...否则...就... 下面来看看这个流程控制语句的书写格式。
<br>
if(条件){
//条件成立的话,就执行这里的程序。
}else{
//条件不成立的话就执行这里的程序。
}
<br>
下面重点说一下if后面括号内的条件。这个条件可以是一个固定的值,也可以是一个变量或表达式。如果条件成立的话,也就是条件为真(true),就会执行if后面的程序,如果条件不成立,也就是条件为假(false),就会执行else里的程序。例如:有这么一个条件,A>B 将这个表达式代入if后面的括号内,这个流程语句的意思就变成:如果A>B的话,就执行第一个大括号内的程序,如果A不大于B,就将执行else后面大括号内的程序。
<br>
实例讲解:
<br>
1、新建一个flash文档,在舞台上绘制一个圆,选中圆并按F8转换成影片剪辑,起名为:圆 这样就在舞台上创建一个圆的实例。
<br>
[IMG]http://www.pconline.com.cn/pcedu/sj/wz/flash/10306/pic/030618flashas0601.gif[/IMG]
<br>
2、选中舞台上的实例,按F9打开动作面板,输入如下脚本:
<br>
onClipEvent (enterFrame) {
if (this._x<400) {//流程条件控制语句,如果这个圆的实例的X轴坐标小于400,就执行后面的程序。
this._x += 5;//让这个圆的坐标向右移动5个象素
} else {
this._x = 0;//控制语句,如果刚才的条件不成立。也就是圆实例的X坐标不小于400,就让它的X坐标为0
}
}
<br>
脚本最终编写效果如图:
[IMG]http://www.pconline.com.cn/pcedu/sj/wz/flash/10306/pic/030618flashas0602.gif[/IMG]
<br><br>
[upload=swf]viewfile.asp?ID=83313[/upload]
[flash=350,350]http://www.flash8.net/viewfile.asp?ID=83313[/flash]
上面的脚本是一个非常简单的流程控制语句,根据实例的坐标来进行判断。因为我们使用了enterFrame事件,所以flash会不停的执行下面if...else语句。
<br>
3、测试影片。会看到圆不停的向右移动,当它的X坐标大于或等于400的时候,程序会把它的X坐标重新更改为0。
<br>
二、循环控制语句
<br>
所谓的循环语句,其实也是用条件来控制的,只要条件成立,那么,程序就会不停的执行下去,一直执行到条件不成立为止! 常用的循环语句包括while循环、for循环等。因为篇幅有限,下面只重点讲解for循环的使用方法。
<br>
FOR循环命令格式:
<br>
for(初始变量;条件语句;迭加命令语句){
//用户自己编写的脚本。
}
<br>
首先强调一点,for语句的括号内有三个项目,必须要用分号间隔开!
初始变量:循环语句也是用条件是否成立来控制的,通常我们用一个变量来控制程序执行的次数。那么,这个初始变量就要先定义一个值。要注意的是,初始变量这个项目只执行一次!
<br>
条件语句:这个项目就是我们的判断语句了。如果这个项目判断为真(true),也就是条件成立了。它就直接跳进大括号{}内执行里面的程序!反之,如果条件为假(false),它就直接跳出这个for语句了。
<br>
迭加命令语句:接上面的条件语句,如果条件语句成立,会执行{}内的程序,那么执行完程序之后,就要回来执行迭加命令语句了。通常它就用来增加或减少刚开始时的初始变量的值。
<br>
实例讲解:
<br>
1、新建一个flash文档,在舞台上绘制一个圆,选中圆并按F8转换成影片剪辑,起名为:圆 这样就在舞台上创建一个圆的实例。
<br>
2、为这个实例起名为:yuan 如图:
<br>
[IMG]http://www.pconline.com.cn/pcedu/sj/wz/flash/10306/pic/030618flashas0603.gif[/IMG]
<br>
3、添加一个新的层,并选中新层的第一帧,按F9打开动作面板,输入如下脚本:
for (i=1; i<5; i++) { //我们定义一个变量i来控制程序的循环次数。条件语句为判断i是否小于5,迭加命令就让每次程序执行之后,让i自己增加一,使程序循环4次!
<br>
duplicateMovieClip("yuan", "yuan"+i, i);//duplicateMovieClip是复制命令,用来复制舞台上名字叫yuan的实例,每次复制出来一个,就把新复制出来的实例改名为"yuan"+i。影片的深度也改为i
_root["yuan"+i]._x = random(400);
_root["yuan"+i]._y = random(300);//设置每次复制出来的新实例的X、Y坐标,具体数值随机产生。
_root["yuan"+i]._alpha = random(100);//设置每次复制出来的新实例的透明度,具体数值从100里随机产生。
}
如果大家实在觉得for语言很难读懂的话,你可以按照for语言执行的顺序把i=1代入程序走一遍,可以帮助你理解程序。例如:当i等于1的时候,程序开始判断它是否小于5,那么1肯定小于5了,条件为真,就执行{}内的复制程序,同时复制出来的新实例的名字就变成了yuan1 ,接着就是设置yuan1的坐标和透明度。之后,for语句开始回去执行i++,此时,i的值就变为2了。然后又开始循环判断执行下去......(你可以算一下,这个for循环总共循环了几次呢?答案是4次。)
<br>
脚本如图:
<br>
[IMG]http://www.pconline.com.cn/pcedu/sj/wz/flash/10306/pic/030618flashas0604.gif[/IMG]
<br>
4、选中时间轴的第6帧,按F6插入一关键帧,打开动作面板输入以下脚本:
<br>
gotoAndPlay(1);
<br>
让flash播放到第6帧的时候返回第1帧再来执行for循环语句。
<br>
如图:
<br>
[IMG]http://www.pconline.com.cn/pcedu/sj/wz/flash/10306/pic/030618flashas0605.gif[/IMG]
<br>
5、测试效果吧,你会看到舞台上会循环4次复制出4个圆。
<br>
[upload=swf]viewfile.asp?ID=83314[/upload]
<br><br>
[flash=350,350]http://www.flash8.net/viewfile.asp?ID=83314[/flash]
<br><br>
小角色闪客 2003-12-21 01:04
绘图及颜色的AS编写
一、绘图命令讲解
<br>
在使用flash的过程中,难免会进行绘图的操作。除了用工具面板上的工具绘制图形之外,我们也可以使用ActionScript来绘制图形。
<br>
如何绘制线段及命令解释
lineStyle(粗细,颜色,透明度) //设置绘制图形的线条粗细、颜色和透明度
Moveto(X坐标,Y坐标) //设置绘图线条的起点坐标
lineto(X坐标,Y坐标) //设置线条的结束坐标
<br>
现在就用刚才的三个命令在舞台上绘制出来一个300*100大小的矩形。
步骤:
<br>
1、新建立一个flash文档。
<br>
2、既然要绘制一个300*100大小的矩形,我们就要先确定矩形4个顶点的坐标,然后就可以使用lineto命令进行编写了。顶点坐标如下图:
[IMG]http://www.pconline.com.cn/pcedu/sj/wz/flash/10306/pic/030623flashas0701.gif[/IMG]
<br>
3、选中时间轴的第一桢,打开动作面板。现在已经确定了矩形的4个顶点,那么我们就可以来编写脚本命令了,请输入以下脚本:
<br>
_root.lineStyle(1, 0x000000, 100);//设置线条的粗细,颜色和透明度
_root.moveTo(50, 50);//设置开始点的坐标。
_root.lineTo(350, 50);
_root.lineTo(350, 150);
_root.lineTo(50, 150);
_root.lineTo(50, 50); //设置结束点坐标,整个矩形绘制完毕
<br>
相信大家通过上面的命令就很容易的用AS绘制出所需要的形状,充分发挥你的想象力,可以通过lineto命令来设置多个点,从而创造出各种各样的形状。
<br>
[upload=swf]viewfile.asp?ID=83315[/upload]
[flash=350,350]http://www.flash8.net/viewfile.asp?ID=83315[/flash]
熟悉了绘制线条的命令之后我们来用一个例子加深印象。
<br>
操作步骤:
<br>
1、新建立一个flash文档,在舞台上绘制一个圆,选中它并按F8转换成影片剪辑,起名为:圆 。
<br>
2、按F11打开库面板,请将影片剪辑“圆”在舞台上再拖放一个实例,使舞台上存在两个圆的实例。如图:
[IMG]http://www.pconline.com.cn/pcedu/sj/wz/flash/10306/pic/030623flashas0702.gif[/IMG]
<br>
3、现在为舞台上两个实例分别起名字为a和b 如下图:
[IMG]http://www.pconline.com.cn/pcedu/sj/wz/flash/10306/pic/030623flashas0703.gif[/IMG]
<br>
4、选中时间轴第一桢,打开动作面板,输入以下脚本:
<br>
function draw() { //自己定义一个函数,这个函数起名为draw(可自定),函数的功能是要实现以a实例的坐标为起点,向b实例绘制线条。
_root.clear();//清除舞台上绘制的线条。
_root.lineStyle(1, 0x000000, 90);//设置线条的粗细,颜色和透明度。
_root.moveTo(a._x, a._y);//以a实例的坐标为起点开始绘制线条。
_root.lineTo(b._x, b._y);//以b实例的坐标为绘制线条的结束点。
}
draw();//执行函数draw,它将会在a与b之间绘制出一条黑色的线条。
<br>
完成后的时间轴第一桢脚本如下图:
[IMG]http://www.pconline.com.cn/pcedu/sj/wz/flash/10306/pic/030623flashas0704.gif[/IMG]
<br>
解释:为了减轻编写AS的工作量和程序的重复率,可以将某些功能定义为一个函数,例如上面的draw(),在使用的时候,直接执行定义过的函数,就可以完成函数的功能。
<br>
5、现在创建拖动效果,选中舞台上的b实例,打开动作面板,输入以下脚本:
<br>
on (press) {
//点击此实例,开始拖动
this.startDrag(true);
}
on (release) {
//释放鼠标,停止拖动
this.stopDrag();
}
onClipEvent (mouseMove) { //当鼠标移动,也就是这个b实例移动的时候,就执行里面的程序。
_root.draw();//执行舞台上定义过的draw()函数,开始在a与b之间绘制线条。
updateAfterEvent();//强制更新画面,是整个动画更加流畅。
}
<br>
完整脚本如下图:
[IMG]http://www.pconline.com.cn/pcedu/sj/wz/flash/10306/pic/030623flashas0705.gif[/IMG]
<br>
6、按Ctrl+回车测试动画效果
<br>
[upload=swf]viewfile.asp?ID=83318[/upload]
[flash=350,350]http://www.flash8.net/viewfile.asp?ID=83318[/flash]
二、颜色命令讲解
<br>
setRGB() 用来设置实例的颜色值,注意,这个值用16进制表示,例如 0x000000(黑色)
<br>
getRBG() 获取实例的颜色值
<br>
下面用一个相对简单的例子来说明颜色命令的使用以及如何填充颜色
<br>
要想使用颜色命令,我们必须先构建一个Color对象。方法就是 自定义名字 = new Color("要改变颜色的对象"),构建完color对象之后,我们就能使用setRGB或getRGB来设置或获取颜色了。
<br>
步骤:
<br>
1、新建立一flash文档,设置影片大小为550*400
<br>
2、选中时间轴第一桢,打开动作面板,我们现在要用AS来帮助我们创建一个影片剪辑的实例。所用到的命令为:
createEmptyMovieClip("实例名称",深度)。创建一个影片剪辑实例,并起名为cl。输入下面脚本。
<br>
_root.createEmptyMovieClip("cl", 1);
//使用创建命令在舞台上创建一个名字叫cl的影片剪辑实例,深度为1
<br>
接下来我们要对这个cl实例进行绘制图形和填充图形!现在我们用AS绘制一个300*100大小的矩形,并且把这个矩形填充为黑色,脚本如下:
<br>
with (cl) {
//使用with命令设置cl的各个属性
beginFill(0x000000, 85);
//开始填充这个cl实例,颜色为黑色,透明度为85
lineStyle(1, 0x999999, 100);
//设置这个实例的边框粗细为1,颜色为灰色,透明度为100
moveTo(50, 50);
//设置绘制线条的起点坐标
lineTo(350, 50);
lineTo(350, 150);
lineTo(50, 150);
lineTo(50, 50);
//结束绘制,将在舞台上绘制出一个300*100大小的矩形。
endFill();
//结束填充,与beginFill()命令对应。
}
<br>
OK,现在我们就已经创建了一个黑色的矩形。现在我们要继续实现变色的功能,也就是当鼠标移动的时候,这个矩形会随机变换颜色!就需要用到我们的构建Color对象的命令了。脚本如下:
<br>
_root.onMouseMove = function() {//当鼠标移动的时候就执行下面的脚本命令。
cl_color = new Color("cl");//构建一个名字叫cl_color的Color对象。
yanse = "0x"+random(100)+random(100)+random(100);//用一个变量yanse来获取一个数值,这个数值就是颜色值
cl_color.setRGB(yanse);//设置矩形的颜色。
<br>
OK,这个例子是完全由脚本编写而成,所有脚本都在时间轴的第一桢,完整脚本如下图
<br>
[IMG]http://www.pconline.com.cn/pcedu/sj/wz/flash/10306/pic/030623flashas0706.gif[/IMG]
<br>
3、按Ctrl+回车来测试你的影片吧~会看到矩形会随着鼠标的移动而不断进行颜色变化。
[upload=swf]viewfile.asp?ID=83319[/upload]
<br>
[flash=350,350]http://www.flash8.net/viewfile.asp?ID=83319[/flash]
<br><br><br><br><br>
小角色闪客 2003-12-21 01:15
声音AS的编写与控制
前言:一个好的flash作品,缺少了声音,就如同人不会讲话一样。而flash中对声音的支持也非常不错,除了可以使用时间轴放置声音文件之外,我们还可以使用AS来更加准确的控制声音!
<br>
一、FLASH中如何创建声音控件
<br>
如果想控制动画中的声音,我们可以使用flash中的sound对象,通过sound命令创建一个新的sound对象。之后再用attaceSound命令连接到库里的声音,就可以用来控制动画中的声音了。
常用命令讲解:
new Sound() 此命令用来创建一个新的sound对象,有了sound对象我们才能用AS来控制声音。
attachSound("库中的声音") 此命令可以使我们创建的声音对象连接到库里的声音,以便进行控制。
start([从第几秒开始播放, 循环次数]) 此命令可以是声音开始播放,里面的两个参数是可选的。
stop() 停止声音的播放。
setVolume(音量级别) 此命令可以控制声音的音量高低,音量级别只能是从0-100之间的数字。
<br>
呵呵,罗嗦了半天,现在咱们也应该用AS先做一个简单的小例子了。
<br>
二、创建一个简单的声音播放动画,可以实现简单的开始与停止播放声音。
<br>
操作步骤:
<br>
1、新建一个flash文档,按Ctrl+R(文件导入)导入一个声音文件,声音文件可以是MP3或WAV格式的。声音文件导入之后,在舞台上是看不见的,必须打开库才能看到我们导入的声音。如图:
<br>
[IMG]http://www.pconline.com.cn/pcedu/sj/wz/flash/10306/pic/030624flashas0801.gif[/IMG]
<br>
2、选中库中的声音文件,单击鼠标右键,在弹出的菜单中选择“链接...”将会弹出一个链接的对话框,请勾选“为动作脚本导出”和“在第一桢导出”选项,并输入一个标识符:mysound (名字可任意写),单击确定。如下图:
<br>
[IMG]http://www.pconline.com.cn/pcedu/sj/wz/flash/10306/pic/030624flashas0802.gif[/IMG]
<br>
[IMG]http://www.pconline.com.cn/pcedu/sj/wz/flash/10306/pic/030624flashas0803.jpg[/IMG]
<br>
3、回到主舞台,选中时间轴的第一桢,按F9打开动作面板。现在我们要创建一个新的声音对象,并且连接到库里的声音。用来控制声音。输入以下脚本:
music = new sound();//创建一个名字叫music的声音对象。
music.attachSound("mysound");//将这个声音对象与库里的标识符为“mysound”的声音连接。
<br>
完成脚本如下图:
[IMG]http://www.pconline.com.cn/pcedu/sj/wz/flash/10306/pic/030624flashas0804.gif[/IMG]
<br>
4、现在需要在舞台上放置两个按钮分别控制声音的播放与停止。选择“窗口”--“公用库”--“按钮”,打开flash为我们设置的公用按钮元件库,再将Circle Buttons中的Play按钮和Stop按钮拖放到舞台上。
<br>
[IMG]http://www.pconline.com.cn/pcedu/sj/wz/flash/10306/pic/030624flashas0805.gif[/IMG]
<br>
5、此时,舞台上将有播放和停止两个按钮,选中Play按钮,打开动作面板,输入以下脚本:
<br>
on (release) {
music.start();
}//播放声音
<br>
选中Stop按钮,输入以下脚本:
on (release) {
music.stop();
}//停止播放声音
<br>
6、OK,一个简单的控制声音播放与停止的例子就完成了,快按Ctrl+回车来测试吧。:)
[upload=swf]viewfile.asp?ID=83320[/upload]
<br>
三、创建一个稍微复杂的例子,用来滑动按钮来控制声音的音量。
<br>
操作步骤:
<br>
1、新建一个flash文档,并按Ctrl+R导入一个声音文件。
<br>
2、参照上个例子,打开库,并把导入的声音文件设置一个链界标识符。这里设置标识符为“mysound”。
<br>
3、选中舞台时间轴第一桢,打开动作面板,创建一个新的声音对象,连接库中声音,并播放这个声音。输入脚本如下:
<br>
music = new sound();
music.attachSound("mysound");
music.start(1, 10);//播放声音,从第一秒开始播放,并循环10次
<br><br>
4、现在需要一个按钮做为滑动按钮,用来控制声音的音量!按钮可以自己制作或使用公用库中的按钮,此例中我使用公用库中的按钮。请在舞台适当位置放置一个按钮实例。如下图:
<br>
[IMG]http://www.pconline.com.cn/pcedu/sj/wz/flash/10306/pic/030624flashas0806.jpg[/IMG]
<br>
5、选中按钮,打开动作面板输入以下脚本:
<br>
on (press) {
this.startDrag(false, left, top, right, bottom);//开始拖动这个按钮,并且要规定它的拖动范围,分别由四个变量控制,4个变量的初始值稍后设置。
drag = true;//用一个变量来判断这个按钮是否被拖动了。如果它被拖动了,变量值为true(真)
}
on (release, releaseOutside) {
this.stopDrag();//当松开按钮或在按钮外部松开,就停止拖动。并且下面的drag变量为假,表示按钮没有被拖动。
drag = false;
}
<br>
完整脚本如图:
[IMG]http://www.pconline.com.cn/pcedu/sj/wz/flash/10306/pic/030624flashas0807.gif[/IMG]
<br>
6、再次选中这个按钮,并按F8键将它转换成一个影片剪辑!起名为:控制音量。也就是“控制音量”这个影片剪辑里面包含了刚才的按钮。如图:
[IMG]http://www.pconline.com.cn/pcedu/sj/wz/flash/10306/pic/030624flashas0808.gif[/IMG]
<br>
7、选中舞台上这个控制音量影片剪辑的实例,打开动作面板,现在要设置拖动范围的4个初始值和设置音量大小控制。请输入以下脚本:
<br>
onClipEvent (load) {//当这个flash动画一开始,就设置下面4个变量的初始值。为了使按钮只能上下拖动,所以,拖动范围的左、右都固定!只能让按钮在上下100象素以内拖动。
top = _y;
left = _x;
right = _x;
bottom = _y+100;
}
onClipEvent (enterFrame) {
if (drag == true) {//如果按钮被拖动了,就开始执行下面的设置音量的算法,用来控制音量。
_root.music.setVolume(100-(_y-top));//设置音量大小,比较难理解的是里面的算法:100-(_y-top),通过代入数字来帮助我们理解,如果_y的值是100,我们的top值也是固定的为100。当拖动按钮往下时,_y值就会变大,比如变为130,那么_y-top就等于30了,在用100-30就等于70,这个70就是音量的级别了。伴随着按钮越往下拖,音量级就会变的越小,那么也就实现音量的控制了。
}
}
<br>
[IMG]http://www.pconline.com.cn/pcedu/sj/wz/flash/10306/pic/030624flashas0809.gif[/IMG]
<br>
8、现在就来测试你的成果吧!
<br>
结束语:通过以上两个例子,应该要掌握的就是创建sound对象播放、停止声音,以及控制声音的方法。
<br>
[upload=swf]viewfile.asp?ID=83323[/upload]
小角色闪客 2003-12-21 17:37
顶一下,这么好的东东
mengyue 2003-12-21 18:21
是啊
超好的东西
谢谢小角色闪客
woohyukrui 2003-12-22 06:29
晕了~~~!还多啊!不过都是经典!!!谢谢小角色!!!!
meale 2003-12-22 09:11
收了
红星闪闪 2003-12-22 22:07
8错啊
lhhailei 2003-12-25 05:11
晕死,哈哈 ,偶在太平洋发的教程怎么被你弄到这里来啦?郁闷~~~贴过来也不贴偶的名字~
smilewiwi 2003-12-25 09:16
明知是好的,要顶!
那就要尊重别人的劳动成果!
凡人不凡 2003-12-26 19:45
谢谢!我也会简单的AS了。
[upload=swf]viewfile.asp?ID=85019[/upload]
piaoxue 2003-12-26 22:42
接下了,我很受用,不过感觉还是复杂了点,我的E文不好啊。
来去飞 2003-12-28 02:42
好东东,你真是好样的
赵盈 2004-3-28 18:24
经典以后多发啊。
zhang9394 2004-3-31 22:13
我是菜鸟
<br>
希望可以多发
雪鼠 2004-4-2 04:54
很好的AS教程,谢谢小闪.
sway 2004-4-2 18:07
谢谢了,学习AS中,太感谢了~
jarryzhong 2004-5-1 05:03
超厉害啊
<br>
只有佩服二字
song0710 2004-6-30 17:41
顶顶顶!
<br>
感谢大侠的无私相助!
ox_thedarkness 2004-7-9 00:34
呵呵~~ 真不错~~ flash AS基础的彻底整理阿~~ 这帖子偶在游戏版收了~
<br>
恩,掉了不少图图和swf~ 不晓得能否修正一下,十全十美最好嘛~
<br>
很重要的建议:改一下有些地方的大小写,不然用2004的人按教程作可能会失败:
<br>
gotoAndStop gotoAndPlay onEnterFrame
<br>
onRelease 、还有事件on()中小写的 press release 等等
绝情>_<伤心 2004-7-10 02:15
好东西`本来不知道动作脚本怎么写的`现在有了一定的了解了`非常的感谢~~
rex-xw 2004-7-10 02:49
今天没空了,先收藏...
关锁 2004-7-12 21:31
看了一天,终于看完了,真是好啊!
墨斗鱼 2004-7-13 00:16
(1)在舞台上创建一个动态文本框,并为这个动态文本实例起一个名字,例如test <A title=新窗口打开 onfocus=this.blur() href="http://bbs.graphicvale.com/uploadImages/2003641650360293.jpg" target="_blank" ><IMG src="http://bbs.graphicvale.com/uploadImages/2003641650360293.jpg" onload="if(this.width>screen.width-333)this.width=screen.width-333" border=0></A>
<br>
(2)选中时间轴的第一桢,打开动作面板,输入以下脚本:<BR> test.text = "为动态文本赋值"<BR>
<br>
是不是要把动态文本框转为MC?这个效果做完了测试出来的效果是怎样的,我没做出来。
<br>
知日 2004-7-16 10:51
其实这个只要略学了点C语言与VB的人就很好理解。
<br>
还是很好入门的
ddeepred 2004-7-16 14:41
及时雨!正在想as是怎么回事呢,就看到了这部教材,学习中。。。
ddeepred 2004-7-16 14:56
刚学就遇上问题了。小球不听我的指挥,我已经写上_root.mc.stop了,可是他还在不停地转动,这是怎么回事啊?请指教。[upload=swf]UploadFile/2004-7/200471665651406.sw<BR>
豆子224 2004-7-21 23:33
教程好好!!谢谢!!!!
dalong1001 2004-7-22 05:35
我是新学的啊!脚本还是不好理解的,多实践吧!真想在这里有个学习的地方啊!
今天不感冒 2004-7-22 20:00
多谢楼主分享,3Q!
<br>
正要学习这方面的知道呢。
今天不感冒 2004-7-22 20:02
好多图片都成叉叉了呢,。
<br>
楼主好心更新下吧。。
QinaBiao 2004-7-23 21:45
爱惜你等于爱惜自己
ddeepred 2004-7-28 18:36
刚开始接触flash的时候,这部教程没看懂。如今我回过头来再看它:哇塞!真是好东东!写的好极了。文体特棒,既言简意赅,又通俗易懂,图文并茂,步步实例。实为上佳作品!收获不小,谢了。楼主辛苦!
zhcp 2004-7-29 09:33
这教程很好,比看书的通俗多了,很好理解
duan_sky 2004-9-1 17:52
好东东<BR>
wxywb 2004-9-4 20:19
非常不错,顺便想知道隐形mc的做法,因为我才11岁。
hikaruk 2004-9-15 21:34
能不能麻烦UP下图片,很多链接都失效了!
不知何方 2004-10-12 04:05
虽然习惯有比较传统的方法,学了还是有用的,一定要多用才会,flash本来可以傻瓜编程的,现在越学越难了,不过今晚还是硬肯下去了,学到多少看做化了!
不知何方 2004-10-12 04:08
你将脚本放在哪里了,有没放好位置,还有你的mc起名字了吗?
RockZ 2004-10-14 01:01
看的我眼花了,不过是好东西,顶,给我不少帮助!
yangfan153 2004-10-18 19:09
我要好好学学。。。
dalong1001 2004-10-21 06:13
很通俗易懂的啊!谢谢楼主!!
闪客太子 2004-10-21 16:53
写的真详细呀,谢了
wangting33 2004-10-27 03:19
我怎么下不了原文件啊
<br>
一下就让我写密码还有个或怎么添啊
<br>
写了密码还让我写进不去啊55555555
lone8 2004-10-27 09:28
就是啊,要输入密码才行呢
shunni 2004-10-28 06:59
超级好的教程,VERY VERY VERY GOOD的教程
trojanox 2004-10-31 16:46
很好...
梅飘雪原 2004-10-31 23:01
刚发现这个好东东,大家快来看那!
<br>
[em23][em23][em23][em23][em23][em23]
<br>
[em44][em44][em44][em44][em44][em44]
gdy66 2004-11-1 03:41
好东东,我收藏了。楼主辛苦了。
ywfzwq 2004-11-7 04:18
真是好东西,从明天开始又有了新的目标了!!
<br>
哈哈!!``
amygu 2004-11-11 17:56
不错呀,很适合我,谢谢!!!1
superyjy201 2004-11-16 21:53
很好,对我们这些菜鸟来说,
<br>
是很好的教材。。
<br>
谢谢了!!
蛤蟆龙 2004-12-7 08:18
谢谢~顶了
dqx 2004-12-8 05:19
难得,写的易懂!
沙漠沙 2004-12-23 09:09
顶一下吧~看了看,转了转~