'움직이는 레이어 제어하기'에 해당되는 글 1건

  1. 2008.03.09 스크롤바에 따라 움직이는 레이어 제어하기

<HTML>
  <title>스크롤바에 따라 움직이는 레이어 제어하기</title>
  <head>
  <script>
  <!--
       var stmnLEFT = 500; // 스크롤메뉴의 좌측 위치. 필요 없을 경우 삭제
       var stmnGAP1 = 5; // 페이지 헤더부분의 여백 (이보다 위로는 올라가지 않음)
       var stmnGAP2 = 4; // 스크롤시 브라우저 상단과 약간 띄움. 필요없으면 0으로 세팅
       var stmnBASE = 30;
       // 스크롤메뉴 초기 시작위치 (아무렇게나 해도 상관은 없지만 stmnGAP1과 약간 차이를 주는게 보기 좋음)
       var stmnActivateSpeed = 200; // 움직임을 감지하는 속도 (숫자가 클수록 늦게 알아차림)
       var stmnScrollSpeed = 10; // 스크롤되는 속도 (클수록 늦게 움직임)

       var stmnTimer;

 // 쿠키 읽기
       function ReadCookie(name)
       {
           var label = name + "=";
           var labelLen = label.length;
           var cLen = document.cookie.length;
           var i = 0;

           while (i < cLen) {
               var j = i + labelLen;

               if (document.cookie.substring(i, j) == label) {
                   var cEnd = document.cookie.indexOf(";", j);
                        if (cEnd == -1) cEnd = document.cookie.length;

                         return unescape(document.cookie.substring(j, cEnd));
                   }

                    i++;
               }

               return "";
       }

       // 쿠키 저장
       function SaveCookie(name, value, expire)
       {
           var eDate = new Date();
           eDate.setDate(eDate.getDate() + expire);
           document.cookie = name + "=" + value + "; expires=" +  eDate.toGMTString()+ "; path=/";
       }

       // 스크롤 메뉴의 위치 갱신
       function RefreshStaticMenu()
       {
           var stmnStartPoint, stmnEndPoint, stmnRefreshTimer;

           stmnStartPoint = parseInt(STATICMENU.style.top, 10);
           stmnEndPoint = document.body.scrollTop + stmnGAP2;
           if (stmnEndPoint < stmnGAP1) stmnEndPoint = stmnGAP1;

           stmnRefreshTimer = stmnActivateSpeed;

           if ( stmnStartPoint != stmnEndPoint ) {
               stmnScrollAmount = Math.ceil( Math.abs( stmnEndPoint - stmnStartPoint ) / 15 );
               STATICMENU.style.top = parseInt(STATICMENU.style.top, 10) + ( ( stmnEndPoint<stmnStartPoint ) ? -stmnScrollAmount : stmnScrollAmount );
               stmnRefreshTimer = stmnScrollSpeed;
            }

           stmnTimer = setTimeout ("RefreshStaticMenu();", stmnRefreshTimer);
       }

       // 메뉴 ON/OFF 하기 & 레이어움직이기
       function ToggleAnimate()
       {
           if (document.all.ANIMATE.checked) { // 정지 버튼이 체크되었다면
           clearTimeout(stmnTimer); // 이동용 타이머 해제
           STATICMENU.style.top = stmnGAP1; // 메뉴의 위치를 상단으로 옮긴다.
           SaveCookie("ANIMATE", "false", 300); // 이동상태가 "OFF" 임        
           }
          else { // 아니라면... (이동하기 버튼이 체크되어 있지 않으면)
              RefreshStaticMenu(); // 메뉴위치를 다시 조정
              SaveCookie("ANIMATE", "true", 300); // 이동이 ON 상태라고 쿠키를 설정
           }
       }

       // 메뉴 초기화
       function InitializeStaticMenu()
       {
           if (ReadCookie("ANIMATE") == "false") { // 이동상태가 off 상태라면
           document.all.ANIMATE.checked = true; // 체크표시를 하고
           STATICMENU.style.top = document.body.scrollTop + stmnGAP1; // 맨 위에 들러 붙는다.
           }
           else { // 이동 on 상태라면
                       document.all.ANIMATE.checked = false; // 체크표시를지우고
                       STATICMENU.style.top = document.body.scrollTop + stmnBASE;
                       // 기본위치로 이동한다.
                       RefreshStaticMenu(); // 스크립트 가동
                 }
              STATICMENU.style.left = stmnLEFT; // 메뉴 왼쪽 위치 초기화. 필요없을 경우 삭제
       }

       //페이지 로드시
        function PageLoad()
       {
           document.all.ANIMATE.checked = false;
           ToggleAnimate();
       }

  -->
  </script>
  </head> 

  <body onLoad="PageLoad();">
  <!-- 스크롤메뉴를 위한 구성입니다. -->
  <div id="STATICMENU" style="position:absolute; z-index:100; left:500px;">

  <!-- 메뉴가 들어갈 부분... 본인의 홈페이지에 맞게 적당히 편집하세요. -->
  <table border="1" width=130 cellpadding="3" cellspacing="0" bordercolor="#A7A7A7" bordercolordark="white" bordercolorlight="#A7A7A7">


       <tr>
           <td bgcolor="#E5E5E5">
               <table border="0" cellpadding="2" cellspacing="0" width="100%">
                   <tr align=center>
                       <td bgcolor="#E5E5E5">
                           <center><b><font face=으뜸9> 제목 </b></center>
                            스크립트 메뉴<br></font>
                       </td>
                   </tr>
                   <tr>
                       <td bgcolor=#E5E5E5></td>
                   </tr>
               </table>
           </td>
       </tr>
  </table>
  <!-- 메뉴부분 끝 -->

  <!-- 애니메이션 유무를 체크하는 부분 -->
  <input id="ANIMATE" type="checkbox" onClick="ToggleAnimate();"><font color=305678 face=정9>정지
  <!-- 스크롤메뉴를 가동하는 자바스크립트 -->
  <script language="javascript">InitializeStaticMenu();</script>
  </div>
  <!-- 스크롤 메뉴 정의 끝 -->

  <table height="800">
  <tr><td></td></tr>
  </table>
  </BODY>
</HTML>




<결과보기>

Posted by 귀찮은 여니씨
,