회원가입아이디/비번찾기
실시간 TV
홈으로
event - volume bar
12년 전
드래그를 이용한 또 다른 스크립트를 만들어봅시다.
볼륨바 같은건 어떨까요?

마우스로 드래그 하면서 볼륨바를 이리 저리 움직이면 그 바의 위치에 따라서
뭔가 반응하는거죠.

앞엣 글을 착실히 이해했다면 상당히 쉬운 문제입니다.
더더욱이 좌우로만 움직이는 bar 이기 때문에 y 좌표는 고려할 필요가 없으니
소스는 더더욱 간단하겠지요.

그래서 몇가지 문제를 추가해보았습니다.
- 사실 추가적인 문제라기보다는 bar 가 제대로 구현 되기 위해 꼭 필요한 기능이죠.

우선은 드래그의 범위입니다.
드래그 한다고 해서 볼륨바가 범위 없이 드래그 된다면 좀 난감하겠지요.

또 하나는 현재 볼륨바의 위치를 텍스트에 써주는겁니다.

빈 레이어를 하나 적당한 위치에 적당한 크기로 넣어줍니다.
그리고 이 레이어안에서만 bar 가 움직이도록 할겁니다.
이 레이어의 크기는 가로로 200 정도로 하지요.

bar 로 쓸만한 좋은 이미지를 찾아보니http://tagmania.net/img/guide2.gif 가 적절할듯 합니다.
이 그림의 크기는 가로로 7 이고 세로로 9 이므로 위 레이어의 크기를 200 + 9 정도로 하면
레이어 안에서 그림이 최 우측에 위치할때의 x 좌표가 200 이니까 여러 계산에 좀 편리할겁니다.

우선 바탕이 되는 레이어를 html 로 작성해볼까요??


<div id="bg" style="position:absolute;left:100;top:100;width:207;height:10;background:#999999">
</div>
<img src="http://tagmania.net/img/guide2.gif" id="bar" style="position:absolute;left:100;top:105;cursor:pointer"
ondragstart="movStart()" ondrag="mov()" />

브라우저 기준으로 100, 100 위치에 크기 209, 10 으로 넣어주었습니다.
그리고 img 태그와 스타일로 이미지를 한장 넣어주었습니다.
물론 이벤트에 연결할 스크립트 함수를 작성해야 합니다.

드래그 할 대상은 물론 이 조그마한 이미지입니다.
그리고 드래그를 위한 자바스크립트를 만들어봅시다.


function movStart()  { mvX = parseInt(event.offsetX); }
function mov()  {
    nX = parseInt(event.x);
    posX = nX - mvX;
    Obj = document.getElementById("bar");
    Obj.style.left = posX;
    }


y 좌표는 고려하지 않아도 되므로 위 두 함수가 앞전 글보다 훨씬 간단해졌습니다.
하지만 이렇게 두 함수를 작성하면 드래그 된 bar 는 레이어 범위를 벗어나도 계속 드래그가 됩니다.
그러니까 posX 의 값을 판단해서 레이어 범위를 벗어나면 그 값을 적당한 값으로 바꿔줘야 합니다.
레이어 범위를 벗어나는 posX 의 값은 100 보다 작거나 혹은 300 보다 클때입니다.
100 은 레이어가 시작하는 x 좌표이고 300 은 레이어 시작점 100 에 레이어 가로크기 200 을 더해준값이죠.
가로크기가 207 이지만 그림 위치가 200 일때 레이어 맨 뒤에 그림이 위치하므로
레이어 가로크기는 200 으로 간주해도 됩니다.

답이 나왔으니 해결은 간단하죠.

if(posX < 0) posX = 0;
if(posX > 300) posX = 300;

그리고 나서 posX 를 그림의 x 위치로 정해주면 되는거죠.
이 두 줄을 함수에 추가하면 드래그 하다가 레이어 범위를 벗어나면 드래그 되지 않습니다.



한가지 더 추가 기능을 만들어봅시다.
레이어 옆에 input 태그로 텍스트를 하나 넣어줍니다.
그리고 이 텍스트에 그림이 레이어상의 상대적인 위치를 써줍시다.
가령 그림이 레이어의 가장 왼쪽에 왔으면 0 을 써주고 레이어의 가장 오른쪽에 왔으면 200 을 써주면 되죠.

이 써줄 값은 posX 에서 100 을 빼준 값이면 됩니다.
텍스트에 써줄 것이므로 추가 되는 텍스트 역시 식별자를 적어주면 편할겁니다.
또,
레이어 옆에 텍스트가 추가 될 것이므로 style 로서 위치를 잡아주면 보기도 좋겠지요.

아래는 그럭저럭 완성된 소스입니다.




<script language="javascript">
function movStart()  { mvX = parseInt(event.offsetX); }
function mov()  {
    nX = parseInt(event.x);
    posX = nX - mvX;
    if(posX > 300) posX = 300;
    if(posX < 100) posX = 100;
    Obj = document.getElementById("bar");
    Obj.style.left = posX;
    document.getElementById("posVal").value = posX - 100;
    }
</script>
<body>
<div id="bg" style="position:absolute;left:100;top:100;width:207;height:9;background:#999999"></div>
<img src="http://tagmania.net/img/guide2.gif" id="bar" style="position:absolute;left:100;top:105;cursor:pointer"
ondragstart="movStart()" ondrag="mov()" />
<input type=text size=3 id="posVal" value="0" style="position:absolute;left:320;top:100" />
</body>

추천추천 : 534 추천 목록
번호 제목
2,881
 sessionStorage.getItem 와 sessionStorage.setItem
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가지
목록
뮤직트로트 부산광역시 부산진구 가야동 ㅣ 개인정보취급방침
Copyright (C) musictrot All rights reserved.