Flash 与课件制作:缓冲公式

   百度谷歌搜索,网上已经很多flash缓冲公式使用。其实原理很多人都会清楚的,今天徘徊在这个公式计算当中。在使用的时候,发现有趣的地方。

  

   mc.x+=(目标点-mc.x)*ratio;

这个例子当中,是以x坐标变化进行缓冲。ratio 是一个系数,默认取小于1的小数。0.1xxx-0.9xxxx区间内。

在每一帧刷新的情况下:   mc.x-是无限趋向于目标点,而目标点-mc.x差距会逐渐缩窄。不无穷靠近目标的点。

  下面是一组比较长的图片,当鼠标移动的时候,图片会左右移,当图片层在左边和右边边界的时候就停下来。而舞台上,图片层会很长的,我们所看到只会在红色的区间里面看到的。

经过遮罩后,图片显示情况

 

   第一步:首先创建一个cs3文档

   第二步:将我们所需要的图片做成一个元件mcc,注册点为左上角

   第三步:将元件放在舞台上位置

   第四步:建立遮罩层,并将遮罩层坐标和宽度记录 (69.7,542.5+69.7);

   第五步:书写代码

   第六步:计算左右两边临界区值。采用百分比计算办法。

stage.addEventListener(Event.ENTER_FRAME,Run); function Run(event:Event):void { move(mcc,69.7,542.5+69.7); } function move(mc:*,startPoint:Number,endPoint:Number,ratio:Number=0.5):void { var temp:Number=mouseX; if(mouseX<startPoint) { temp=startPoint; } if(mouseX>endPoint) { temp=endPoint; } var k:Number=(temp-startPoint)/(endPoint-startPoint); mc.x+=((startPoint-(mc.width-(endPoint-startPoint))*k)-mc.x)*ratio; }

然后我们再制作另外一个例子:

1  创建一个640x400的文档。

2 在舞台上创建一些图案和四个文字按钮。并对每一个进行命名。

3.创建一组图片序列

4 书写代码进行交互

                                                             Demo图

我们会采用这种缓冲制作遮罩中的一种动画效果。首先会在网上搜索一些摄影的作品(来源网上摄影网站),然后组成一个元件。

如下面,对每一张图片进行大小比例相等调节后,这些图片就可以做我们缓冲的时候用的图片。我们使用遮罩层只对一张图片进行遮罩效果。

如上面的Demo演示图,所看到的就是一张图片,其余都被隐藏起来了。接下来我们就需要考虑到怎样移动这张图片。当然我们依旧回归到使用这个公式来制作我们的课件。

 mc.x+=(目标点-mc.x)*ratio; 这条简单而实用的公式。

我们对每一张图片设计一个目标点位置。当我们鼠标移动到文字上方的时候,图片就会跟随移动起来了。这个简单效果就可以完成到了。

简单的代码效果:

代码当中只是个演示,其中我们只是需要理解到这个公式使用就可以,交互代码可以进行更改和设计,使其符合自己的设计目的和需要。

package { import flash.display.MovieClip; import flash.display.SimpleButton; import flash.events.*; import flash.text.*; public class Main extends MovieClip { private var targetPoint:Number; private var key:Boolean=false; public function Main() { init(); } private function init():void { //按钮监听 title_btn1.addEventListener(MouseEvent.MOUSE_OVER,onOverHandler); title_btn2.addEventListener(MouseEvent.MOUSE_OVER,onOverHandler); title_btn3.addEventListener(MouseEvent.MOUSE_OVER,onOverHandler); title_btn4.addEventListener(MouseEvent.MOUSE_OVER,onOverHandler); addEventListener(Event.ENTER_FRAME,Run); } private function onOverHandler(event:MouseEvent):void { key=true; switch (event.currentTarget) { case title_btn1 : targetPoint=86; break; case title_btn2 : targetPoint=-28; break; case title_btn3 : targetPoint=-142; break; case title_btn4 : targetPoint=-256; break; } } private function Run(event:Event):void { if(key) photo.x+=(targetPoint-photo.x)*0.5; } } }

下面是文件和演示有兴趣可以看看。

转载于:https://www.cnblogs.com/guoyiqi/archive/2010/06/26/2069114.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
CSDN IT狂飙上传的代码均可运行,功能ok的情况下才上传的,直接替换数据即可使用,小白也能轻松上手 【资源说明】 基于MATLAB实现的有限差分法实验报告用MATLAB中的有限差分法计算槽内电位;对比解析法和数值法的异同点;选取一点,绘制收敛曲线;总的三维电位图+使用说明文档 1、代码压缩包内容 主函数:main.m; 调用函数:其他m文件;无需运行 运行结果效果图; 2、代码运行版本 Matlab 2020b;若运行有误,根据提示GPT修改;若不会,私信博主(问题描述要详细); 3、运行操作步骤 步骤一:将所有文件放到Matlab的当前文件夹中; 步骤二:双击打开main.m文件; 步骤三:点击运行,等程序运行完得到结果; 4、仿真咨询 如需其他服务,可后台私信博主; 4.1 期刊或参考文献复现 4.2 Matlab程序定制 4.3 科研合作 功率谱估计: 故障诊断分析: 雷达通信:雷达LFM、MIMO、成像、定位、干扰、检测、信号分析、脉冲压缩 滤波估计:SOC估计 目标定位:WSN定位、滤波跟踪、目标定位 生物电信号:肌电信号EMG、脑电信号EEG、心电信号ECG 通信系统:DOA估计、编码译码、变分模态分解、管道泄漏、滤波器、数字信号处理+传输+分析+去噪、数字信号调制、误码率、信号估计、DTMF、信号检测识别融合、LEACH协议、信号检测、水声通信 5、欢迎下载,沟通交流,互相学习,共同进步!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值