首页  韩国资源  酷站加油  我的展厅  设计名站  古典元素  推荐下载  设计欣赏  每周专访  招募精英  人才专区  网页教程  平面设计  编程开发  设计竞赛
当前位置:首页 > 网页教程 > Flash教程 > 正文
Google
旋转特效
来源:闪吧论坛 作者:jisekai 2007年09月25日 15:45 网友评论:0条 点击:
效果:

/UploadTeach/200709/2007092112943617.swf

代码如下:
var pMaxSize:Number = 150;
var pCenterX:Number = 275;
var pCenterY:Number = 200;
var pNumTraces:Number = 20;
var pNumLayers:Number = 30;
var pCurrentLayer:Number = 0;
var pLineColour:Number;
var pPointDegree:Array = new Array();
var pPointDegreeChange:Array = new Array();
var pPointScale:Array = new Array();
var pPointScaleChange:Array = new Array();
var pPointX:Array = new Array();
var pPointY:Array = new Array();
var pBaseTimeline:MovieClip;
var pIntervalId:Number;
function init(baseTimeline:MovieClip):Void {
pBaseTimeline = baseTimeline;
pBaseTimeline.createEmptyMovieClip("holder", 0);
for (var j:Number = 0; j<pNumLayers; j++) {
  pBaseTimeline.createEmptyMovieClip("layer"+j, j+1);
  pBaseTimeline["layer"+j]._x = pCenterX;
  pBaseTimeline["layer"+j]._y = pCenterY;
}
initTraces();
pBaseTimeline.holder.onEnterFrame = function() {
  moveSpheres();
};
pIntervalId = setInterval(this, "updateSeeds", 2000);
}
function initTraces() {
for (var i:Number = 0; i<pNumTraces; i++) {
  pPointX = 0;
  pPointY = 0;
  pPointDegree = (6.28318530718/pNumTraces)*i;
  pPointScale = 50;
}
updateSeeds();
for (i=0; i<pNumTraces; i++) {
  plotLine(i);
}
}
function moveSpheres() {
for (var i:Number = 0; i<pNumTraces; i++) {
  pPointDegree += pPointDegreeChange;
  pPointScale += pPointScaleChange;
  plotLine(i, true);
}
pBaseTimeline["layer"+pCurrentLayer]._alpha = 100;
pCurrentLayer = (pCurrentLayer+1)%pNumLayers;
for (var j:Number = 0; j<pNumLayers; j++) {
  pBaseTimeline["layer"+((pCurrentLayer+j)%pNumLayers)]._alpha = (j/pNumLayers)*100;
}
pBaseTimeline["layer"+pCurrentLayer].clear();
}
function plotLine(i:Number, drawLine:Boolean) {
pBaseTimeline["layer"+pCurrentLayer].lineStyle(1, pLineColour, 100);
pBaseTimeline["layer"+pCurrentLayer].moveTo(pPointX, pPointY);
pPointX = (Math.cos(pPointDegree)*pPointScale);
pPointY = (Math.sin(pPointDegree)*pPointScale);
if (drawLine == true) {
  pBaseTimeline["layer"+pCurrentLayer].lineTo(pPointX, pPointY);
}
}
function updateSeeds() {
var deg:Number;
var scale:Number;
deg = randomRange(-100, 100)/2000;
if (pPointScale[0]>pMaxSize) {
  scale = randomRange(-10, 0)/2;
} else if (pPointScale[0]<-pMaxSize) {
  scale = randomRange(0, 10)/2;
} else {
  scale = randomRange(-10, 10)/2;
}
for (var i:Number = 0; i<pNumTraces; i++) {
  pPointDegreeChange = deg;
  pPointScaleChange = scale;
}
pLineColour = randomRange(0, 0xFFFFFF);
}
function randomRange(min:Number, max:Number):Number {
var randomNum:Number = Math.round(Math.random()*(max-min))+min;
return randomNum;
}
init(this);
上一篇:一个flash分身效果   下一篇:AS3生成单独“双击事件”
收藏此页】【打印】【关闭
 相关文章  我要点评

免责声明:本站刊载此文不代表同意其说法或描述,仅为提供更多信息,也不构成任何建议。对本文有任何异议,请联络:68design#163.com
转载要求:作者及来源信息必需保留。转载之图片、文件,链接请不要盗链到本站,且不准打上各自站点的水印。



关于我们 | 在线反馈 | 广告报价 | 友情链接 | 联系我们 | 免责声明 | 在线投稿 | 网站地图
Copyright © 2003-2007 68design.net, All Rights Reserve 【找网页设计师,当然上网页设计师联盟】