홈으로 홈으로 | 무료회원가입 | 아이디/비번찾기 | 즐겨찾기
추천음악방송메인홈1대1상담음악방송청취
okTrot(구독해주세요)
앵콜트로트(구독해주세요)
뽕짝아가씨(구독해주세요)
음악가사 검색
온라이브스토어(앱다운로드)
온라이브(방송등록및청취)
비디오 베스트 50
금영노래방
TJ노래방
유튜브 동영상 다운로드
POP Player
신나는 고스톱
컴퓨터 오목
작은 음악다방
운.영.자.1대1.상담
FAQ\지원.프로그램
Q&A\고.객.지.원

자동러시 웹플레이어신청

보안∵서버∵쿠키
윈도우∵프레임
이미지∵배경
시간∵달력∵계산
상태바∵타이틀바
음악∵영상
폼∵전송∵테이블
키보드∵마우스
효과∵링크∵메뉴
Script∵php
기타
PHP 강좌
윈도우관련팁
웹관련팁
홈페이지제작팁
기본강좌
레지스트리
윈도우서버
리눅스서버
Android
event - volume bar
6년 전
드래그를 이용한 또 다른 스크립트를 만들어봅시다.
볼륨바 같은건 어떨까요?

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

앞엣 글을 착실히 이해했다면 상당히 쉬운 문제입니다.
더더욱이 좌우로만 움직이는 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>

추천추천 : 386 추천 목록
번호 제목
3,012
 텍스트 줄바꿈, 글자자르기 CSS
3,011
 jQuery Mobile에서 유용한 코드 10가지.
3,010
 [PHP] dirname()함수와 $_SERVER 관련 상수들
3,009
 [PHP] 파일 크기, 사이즈 불러오는 함수, filesize()
3,008
 [jQuery] jQuery Quick API
3,007
 [ transition ] 링크 hover 색상 변화 속도 조절
3,006
 PHP 5.3.0 에서 사라진 함수들 대체
3,005
 어떤 파일들이 include 나 require 되었는지 확인하는 함수(get_included_files)
3,004
 PHP 날짜 형식 및 계산하기(날짜 더하고 빼기)
3,003
 jQuery Mobile에서 유용한 코드 10가지.
3,002
 값이 배열 안에 존재하는지 확인하는 in_array함수
3,001
 사용자가 웹브라우저에서 뒤로가기를 했을때 감지하는 방법
3,000
 [jQuery]버튼 활성화, 비활성화
2,999
 jQuery show() / hide() / toggle() 사용법
2,998
 jquery 여러가지 이벤트
2,997
 border-radius 속성
2,996
 네이버 오픈API 음성합성 API 사용하는 PHP 샘플코드
2,995
 UTF8 한글 자르기..
2,994
 iconv 에러 발생시 계속 처리하기 옵션
2,993
 [PHP] 현재 페이지의 도메인 , URL 정보 알아내기.
2,992
 [PHP] 막강 기능 배열..
2,991
 [CSS] - Input clear `X ` 버튼 제거 ( IE, Chrome, Firefox )
2,990
 [Mobile] - 모바일웹 Href 태그속성들
2,989
 [JqueryMobile] - 현재화면의 가로세로 사이즈 구하기
2,988
 [JqueryMobile] - 화면의 가로, 세로 사이즈 구하는 방법
2,987
 jquery로 가로 넓이(width), 세로 높이(height) 자동 조절
2,986
 iframe 높이 jquery로 자동조절하기
2,985
 jQuery 오른쪽 영역의 높이를 왼쪽 영역의 높이와 동일하게 하기
2,984
 jquery에서 테이블 짝수, 홀수 번째 TR 배경색 변경하기
2,983
 jquery에서 테이블에 마우스 오버시 해당 행의 배경색상 변경하기
2,982
 jquery 스크립트내 특정값 확인하기 (디버깅)
2,981
 jquery cookie (jquery.cookie.js)
2,980
 jquery div 기본 넓이, 높이 계산 및 padding, border 포함 하기
2,979
 jquery 다른버전 추가 사용시 충돌 방지 (카페24 스마트디자인 기본내장 jquery 1.4.4 버전과 충돌시 해결방법)
2,978
 특정 페이지 종료시 확인 경고창 출력
목록
추천음악방송
인기절정뽕짝파티
인기트로트모음
지루박디스코메들리
밤무대애창곡
전자올겐경음악
앵콜트로트
뽕짝아가씨
작은 음악다방
종합성인가요방
카바레 음악
트롯디스코팡팡
관광 메들리
트롯카페
가요감상실
추억의옛노래
스페셜가요광장
BillBoard Free
Dance&Remix
추천가요모음
경음악.전자올겐
스페셜음악여행
WOLRD POPs
K-POP\BillBoard
JP\CN
POP TOP BEST
K.R.노래방

추천가요\인기
F뮤직 인기\발라드
F뮤직 애창\트로트
트로트성인가요
인기가요
프리미엄 POP
경음악\기타
프리미엄 최신가요
프리미엄 성인가요
가요1번지(종합)
뮤직하우스
동요\연변\반주\기타
가요축제\트롯1번지
댄스\메들리\리믹스
카페\명상\경음악\기타
추천가요\POP\기타
최신가요\인기가요
뮤직트로트 부산광역시부산진구 가야동 ㅣ 개인정보취급방침
Copyright (C) musictrot All rights reserved.