회원가입아이디/비번찾기
실시간 TV
홈으로
레이어 4 - 뽀나쑤 하나
18년 전
레이어에 관한 소스, 이번엔 보너습니다.

레이어에 이미지 한장을 넣어줍니다.
그리고 그 이미지를 움직여보는 소스죠.
하나는 등속 운동, 하나는 가속운동, 하나는 공처럼 튀겨지는 운동입니다.

등속 운동은 시간당 일정한 상수만큼 레이어 위치를 변화 시켜주면 됩니다.
가속 운동은 시간당 일정한 비율로 변하는 변수만큼 변화 시켜주죠.
공 튀기는 운동은 좀 잔머리가 필요합니다.
처음 위치에서 얼마만큼 튀어오를 것인가를 결정하는 비율을 기억해줄
필요가 있습니다.
이 위치까지 공이 튀어오르면 이 위치가 새로운 기준이 되어서
다음 튀어오를땐 이 위치에 정해준 비율이 또 다른 새위치가 되는거죠.


<html>
<title>
레이어 이동
</title>
<head>
<script>

var vi = 1/2;                    //-- 튀어오르는 비율
var va = 500;                    //-- 최하점 y 좌표
temp = 100;                      //-- 튀어오를때의 y 좌표 상한점
ha = 1;                          //-- 가속도를 산출케 하는 변수. 하향땐 점점 커지고 상향땐 점점 작아짐
direc = 'down';                  //-- 방향을 잡아주는 변수
moving = false;                  //-- temp 변수를 설정하기 위한 변수
img_flag = false                 //-- 공의 회전 효과를 주기 위해 만든 변수인데 회전운동이 허접스러워 그만둠.
timmer = false;                  //-- setInterval() 함수를 쓰기 위한 타이머 변수

function move(flag)   {     //-- 호출 인자에 따라 실행 되는 함수가 틀림.
     _reset();
     if(flag == 0) timmer = setInterval('mov_down1()',50);
     else if(flag == 1) timmer = setInterval('down()',50);
     else if(flag == 2) timmer = setInterval('mov_down()',50);
   }
  
function down()   {      //-- 위아래 등속 움직이기
     y_top = parseInt(document.all.aaa.style.top);
     if(direc == 'down') {
            document.all.aaa.style.top = y_top + 20;
            if(y_top > va) direc = 'up';
            }
     else  {
            document.all.aaa.style.top = y_top - 20;
            if(y_top < 100) direc = 'down';
            }
    }

function mov_down()   {        //-- 위아래 가속 움직이기
   y_top = parseInt(document.all.aaa.style.top);
   if(direc == 'down')  {
      if(y_top < va)  {
             if(y_top + 3 * ha > va) document.all.aaa.style.top = va;
             else    document.all.aaa.style.top = y_top + 3 * ha;
             ha++;
             }
      else   direc = 'up';
      }
   else      {
      if(y_top > 100)  {
            document.all.aaa.style.top = y_top - 3 * ha;
            ha--;
            }
      else  { direc = 'down';ha = 1;}
      }
   }
  

function mov_down1()   {    //-- 위아래 가속 움직이기(공 튀기기)
   if(!moving)    temp = va - Math.floor((va - temp) * vi);
   y_top = parseInt(document.all.aaa.style.top);
   if(direc == 'down')  {
      if(y_top < va)  {
             if(y_top + 3 * ha > va) document.all.aaa.style.top = va;
             else    document.all.aaa.style.top = y_top + 3 * ha;
             moving = true;ha++;
             }
      else   direc = 'up';
      }
   else      {
      if(y_top > temp)  {
            document.all.aaa.style.top = y_top - 3 * ha;
            ha--;
            }
      else  { direc = 'down';moving = false;ha = 1;}
      }
   }
  
function _reset()   {       //-- 모든 변수를 초기화 하고 레이어 위치를 처음으로 돌려주며 타이머를 스톱 시켜주는 함수
   temp = 100;
   ha = 1;
   direc = 'down';
   moving = false;
   img_flag = false;
   document.all.aaa.style.top = 100;
   document.all.aaa.style.left = 100;
   clearTimeout(timmer);
   }
</script>

<body>
<button onclick='move(2)'>가속 움직이기</button>
<button onclick='move(1)'>등속 움직이기</button>
<button onclick='move(0)'>공 튀기기</button>
<div id=aaa style='position:absolute;left:100;top:100;visibility:visable;'>
<img src=http://allzza.net/ball.gif>
</div>
추천추천 : 281 추천 목록
번호 제목
2,880
 제이쿼리 랜덤으로 배경색 변경
2,879
 preg match에 관한 정규식
2,878
 Stream an audio file with MediaPlayer 오디오 파일 스트리밍 하기
2,877
 Audio Streaming PHP Code
2,876
 PHP $ SERVER 환경 변수 정리
2,875
 Vimeo (비메오) API 를 사용하여 플레이어 컨트롤하기
2,874
 iframe 사용시 하단에 발생하는 공백 제거방법
2,873
 아이프레임(iframe) 전체화면 가능하게 하기
2,872
 부트스트랩(bootstrapk)에서 사용하는 class명 정리
2,871
 부트스트랩 CSS
2,870
 크롬에서 마진 조절
2,869
 PHP 현재 페이지의 도메인명이나 url등의 정보 알아오기
2,868
 PHP preg match all()
2,867
 PHP 로 웹페이지 긁어오기 모든 방법 총정리!
2,866
 [PHP] 원격지 파일 주소 노출 안하고 curl로 다운로드 받기
2,865
 PHP 함수 정리
2,864
 아이프레임(iframe) 비율 유지하면서 크기 조절하는 방법
2,863
 PHP 배열에서 무작위로 하나 뽑아주는 array rand() 함수
2,862
 PHP 정규식 정리
2,861
 PHP 정규식을 활용한 태그 및 특정 문자열 제거 및 추출 방법
2,860
 php 크롤링 또는 파싱 함수, 정규식 모음
2,859
 제이쿼리 기본 명령어
2,858
 웹페이지 가로 모드세로 모드 인식하기
2,857
 모바일 웹 화면 강제 회전(가로모드 고정)
2,856
 [HTML5]에서 frameset 대체 방법과 iframe 속성
2,855
 HTML <Audio> 사용법
2,854
 윈도우10 시스템파일 손상 (초간단 오류 복구방법!!)
2,853
 PHP 파일 존재 여부 파악하기(로컬 파일 존재 및 원격지 파일 존재)
2,852
 [CSS] 박스 세로 가운데 중앙 정렬 6가지
2,851
 CSS Layout 수평 & 수직 정렬
목록
뮤직트로트 부산광역시 부산진구 가야동 ㅣ 개인정보취급방침
Copyright (C) musictrot All rights reserved.