最新下载
热门教程
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
拖动,缓动,加投影效果
时间:2008-03-14 编辑:简简单单 来源:一聚教程网
var filterropShadowFilter = new DropShadowFilter(10, 45, 0x666666, .6, 18, 18, 1, 3, false, false, false);
var filterArray:Array = new Array();
filterArray.push(filter);
var loop:Number;
var grav:Number;
function move() {
this._x += grav*(_root._xmouse-this._x)/loop;
this._y += grav*(_root._ymouse-this._y)/loop;
if (this._x+15 == _root._xmouse+15 || this._y+15 == _root._ymouse+15) {
//drag = false
group_mc.filters = null;
} else {
this.filters = filterArray;
}
//trace(grav)
//trace(loop)
}
var drag:Boolean = false;
group_mc.onPress = function() {
drag = true;
grav = .6;
loop = 1;
};
group_mc.onMouseMove = function() {
if (drag) {
grav = .1;
//loop = 10;
move.call(this);
}
};
group_mc.onRelease = group_mc.onReleaseOutside=function () {
drag = false;
//delete onEnterFrame;
};
group_mc.onEnterFrame = function() {
if (drag) {
move.call(this);
} else {
group_mc.filters = null;
}
};
filter.distance=(this._x-_root._xmouse)/5;
this.filters = filterArray;
用3.0写了一遍,3.0里没有 events as onReleaseOutside, onDragOut, onDragOver and so on.所以得自己写events类,呵呵~~下次研究一下,再一起讨论共享.
* ...
* @author lby
* @version 0.1
*/
package lbynet{
import flash.display.Sprite;
import flash.display.InteractiveObject;
import flash.events.MouseEvent;
import flash.events.Event;
import flash.filters.DropShadowFilter;
public class Drop {
private var loop:int;
private var grav:Number;
private var can:Boolean = false;
private var target:InteractiveObject;
private var stage:Sprite;
private var blurX:Number;
private var blurY:Number;
public function Drop(target:InteractiveObject,stage:Sprite) {
this.target = target;
this.stage = stage;
target.addEventListener(MouseEvent.MOUSE_DOWN,downHander);
target.addEventListener(MouseEvent.MOUSE_UP,upHander);
target.addEventListener(MouseEvent.MOUSE_MOVE,MoveHander);
//target.addEventListener(MouseEvent.MOUSE_OUT,OutHander);
target.addEventListener(Event.ENTER_FRAME,EnterFrameHander);
}
private function downHander(event:MouseEvent):void {
can = true;
grav = .6;
loop = 1;
trace("down");
}
private function upHander(event:MouseEvent):void {
can = false;
trace("UP");
}
private function MoveHander(event:MouseEvent):void {
if (can) {
grav = .1;
move();
}
}
private function OutHander(event:MouseEvent):void {
can = false;
}
private function EnterFrameHander(event:Event):void {
if (can) {
move();
} else {
target.filters = null;
}
}
private function move():void {
trace("move");
target.x += grav*(stage.mouseX - target.x)/loop;
target.y += grav*(stage.mouseY - target.y)/loop;
var filter:DropShadowFilter = new DropShadowFilter(10,45,0x666666,.6,blurX,blurY,1,3,false,false,false);
filter.blurX = filter.blurY = Math.abs((target.x-stage.mouseX)/3);
filter.distance = (target.x - stage.mouseX)/5;
target.filters = [filter];
}
}
}
-
上一个: 拍照效果
-
下一个: 巧妙去除Flash动画在线播放限制
相关文章
- FLASH软件帧编辑功能怎么使用 06-22
- FLASH软件常用上色工具怎么使用 06-19
- flash怎么制作遮罩图片切换动画 06-19
- FLASH制作春意盎然花园效果 06-18
- 利用ae制作碎片文字动画 06-15
- flash图片怎么替换 06-14