본문 바로가기

FLASH

중력가속도 구현해 보자 게임 포트리스에서 사용될 만한 예제입니다.중력가속도를 구현한 소스입니다. //중력가속도 적용해 봅시다.var dx:Number = 10; var dy:Number = -10; var gravity:Number = 0.98; addEventListener(Event.ENTER_FRAME, moveBall); function moveBall(e:Event):void{ dy += gravity; //가속 ball.x += dx; ball.y += dy if(ball.y > stage.stageHeight){ ball.x = 100; ball.y = 100; dy = -10; } } 더보기
마우스이벤트 종합 예제 다음 예제는 많이 사용되는 다양한 마우스 이벤트를 종합적으로 구현한 것입니다.좀비 사격하는 게임에 쓰면 유용하겠죠? //조준경 이동(주의 조준경 무비클립과 마우스포인트가 겹쳐서 막혀 있으면 마우스 포인트를 인식못함)import flash.events.MouseEvent;addEventListener('enterFrame',go) function go(e){ mc.x=mouseX mc.y=mouseY Mouse.hide() }// 다양한 마우스이벤트 등록tg.addEventListener('mouseOver',f1) tg.addEventListener('mouseOut',f2) tg.addEventListener('click',f3) tg.addEventListener('mouseDown',f4); tg... 더보기
등속운동 구현방법입니다. 게임에서 쓸려고 등속운동 코드 만들었습니다.이 모션도 그냥 잔머리로 구현하려고 했더니 어렵더군요. //등속운동 var angle:Number; var distance:Number; var posX:Number; var posY:Number;stage.addEventListener("click", setPos);function setPos(e){ posX = mouseX; posY = mouseY trace("posX:"+posX); trace("posY:"+posY); stage.addEventListener("enterFrame", onEnter); }function onEnter(e){ var tx; var ty; tx = posX - mc.x; ty = posY - mc.y; angle = Math.. 더보기
[AS3] 두 점간 거리 구하기 두 점간의 거리를 구하는 방법입니다. 다음과 같은 함수를 만들어서 사용할 수 있습니다. //(x1, y1)에서 (x2, y2)까지의 거리를 구해서 정수값을 반환하는 함수 function distance(x1, y1, x2, y2) { var dx:Number = x2-x1; var dy:Number = y2-y1; var d:Number = Math.sqrt(dx*dx + dy*dy); return int(d); } 더보기
단체로 브라운운동 + 방향전환 이것을 기반으로 바퀴벌레 잡기 게임을 만들었습니다.각각의 객체에 enterFrame이벤트가 먹히도록 해 주면 됩니다.불규칙적인 타이밍으로 타겟을 바꿔주고 그 타겟을 향해 부드러운 움직임을 줍니다. 소스코드 var speedRate:Number = 0.1;var mcCnt:int=10;//var tx:Number = Math.random()*stage.stageWidth;//var ty:Number = Math.random()*stage.stageHeight;var mc:MC_c;for(var i:int=0; i 더보기
마우스 트레일러 만들기 배열을 사용해야 이벤트함수내에서 특정무비클립에 접근할 수 있네요.왜 그래야만 하는지는 잘 모르겠지만 이렇게 해야 하는 것 같습니다.cnt갯수만 늘려주면 갯수만큼 꼬리가 늘어납니다. var cnt:Number = 5;var speedRate:Number = 0.3;var distance:Number = 5;var mc:MC;var mc_array:Array = []; for(var i:int=0; i 더보기
휠마우스로 원형메뉴 돌리기 전시간에는 삼각 함수로 도형을 그렸습니다.이번에는 만든 도형을 움직여 볼께요.꼭지점 부분에다가 메뉴가 될 무비클립을 붙여넣기 하고 각도 변위값을 휠마우스delta 값에 맞게 바꾸어 주면 원으로 돌리는 모션을 만들 수 있습니다.휠마우스 이벤트가 블로그에서 브라우저에도 먹히기 때문에 문서에는 embed하지 않고 첨부파일 열어서 테스트 해 주시기 바랍니다. 소스코드입니다.var n:Number = 8; //n각형을 그려볼까?var t:Number = 0; //파이값var tt:Number = 0; //n 각 하나에 해당하는 파이var cx:Number = 275; //중심점xvar cy:Number = 200; //중심점yvar rx:Number = 100; //타원가로반경var ry:Number = 100;.. 더보기
삼각함수로 다각형 그리기 삼각함수로 한 싸이클의 움직임을 하는데 2파이가 사용됩니다.5각형을 만들때는 한점당 1/5 *2파이 가 되는 것입니다.그것에 착안하여 다각형을 그릴 수 있습니다.예제를 보죠. var n:Number = 5; //5각형을 그려볼까?var t:Number = 0; //파이값var cx:Number = 275; //중심점xvar cy:Number = 200; //중심점yvar rx:Number = 100; //타원가로반경var ry:Number = 100; //타원세로반경 ==> 서로 같으니 원이 되겠죠.var posArrayX:Array = new Array(); var posArrayY:Array = new Array(); //꼭지점 생성해 주고for(var i:int=0; i 더보기
삼각함수를 이용한 단진동 삼각함수를 이용하면 다양한 것을 할 수 있습니다.삼각함수의 특징은 일정한 범위 안에서 결과값이 나오는 것입니다.그래서 사인 파형이라든가, 원운동등을 만들어 낼 수 있습니다.단진동이라는 것은 일정한 범위내에서 규칙적으로 움직이는 것입니다. 다음 공식으로 단진동을 만들어 낼 수 있습니다. cx를 중심으로 -r부터 r까지 단진동의 예를 들면cx + r * Math.cos(t) cx + r * Math.sin(t) 위의 방법으로 단진동을 구현할 수 있습니다. 예제를 볼께요. var t:Number = 0; var startPoint:Number = 200; //시작점var radius:Number = 100; //반지름 addEventListener(Event.ENTER_FRAME, moveMC)function.. 더보기
마우스 따라 회전하는 무비클립 마우스 따라 회전하는 무비클립 예제입니다. addEventListener('enterFrame', spin); function spin(e){var tx:Number = stage.mouseX;var ty:Number = stage.mouseY; mc.rotation = Math.atan2((ty-mc.y), (tx-mc.x))*180/Math.PI + 90;//왜 +90을 해 주어야 할까?} 더보기