미리보기 : http://www.x-wiz.com/example/gadgetry.html
이전에 올렸던 "지정된 영역에서 각 레이어 간의 이동 효과(구글,야후) "에 대한
1.0알파 버전입니다.(버전이라고 까지 굳이 할 필요는 없지만 , 차후에도 계속 업그레이드 하려하기 때문에 구분을 두기 위한 장치일 뿐입니다.)
기존에 올렸던 소스는 완성되지 않았던 관계로 알고리즘 및 기능 등 많은 부분이 보완되고, 수정 되었습니다. 또한 명칭도 구글에서 처음 힌트를 얻었기에 Gadgetry라고 명칭을 붙이게 되었습니다.
2개 이상의 영역에 대해서 드래그앤 드랍시 오류 수정, 리사이즈, 펼침 기능 추가 등 변화가 좀 많다면 많을 수도 있습니다. ^^;;
아래는 전체 내용에 대한 간략한 소개 입니다. 소스 및 예제는 링크된 페이지에서 확인 하실 수 있습니다.
/**
* xwzGadgetry : Javascript UI Library for the gadget(or the widget) <http://www.x-wiz.com/>
* 레이어의 위치 지정 또는 순서 출력을 사용자가 원하는 위치 또는 순서로 배열하도록 하는 함수.
* 쇼핑몰에서 상품 위치나, 디자인관리에서 디자인 레이어 위치 이동에 따른 배열,
* 여러 통계 수치나, 입력폼과 출력폼이 동일한 화면에서 출력 순서 변경을 위해 만듦
*
* Idea of "drag&drop swap" is from "google ig<http://www.google.co.kr/ig/>" - see dragDepart()
* Idea of "toggle swap" is from "yahoo.com<http://kr.yahoo.com/>"- see prevToggle()
* Idea of "the distance" is from "daum.net<http://www.daum.net/>" - see _swapAviate()
* Idea of "bindAsObject, bindAsEvent" is from "Prototype JavaScript Framework <http://www.prototypejs.org/>"
*
*@copyright x-wiz.com
*@license The LGPL License
*@author N.Thu Lee
*@version 1.0 Alpha
*@release 2006.11.07
*@updated 2007.05.28
*@changelog
*2006.11.22
*- 레이아웃 이동 간격 수식 변경(다음.넷 참조)
*
*2006.12.04
*- 드래그앤드랍 기능 추가
*
*2007.05.02
*- xwzGadgetry로 라이브러리 명칭 확정
*- 이벤트 핸들러 추가 및 해제 함수를 라이브러리 외부 함수로 분리
*- 2개 이상의 라이브러리 대상 객체에 대해서 드래그앤드랍시 레이어 위치 문제 수정
*- bindAsObject, bindAsEvent 외부 함수 추가
*
*2007.05.05
*- expand 기능 추가. 가젯의 document 영역에 대한 최소화, 최대화 기능 추가
*
*2007.05.28
*-resize 기능 추가
*
*+-------------------------------------+
*plan
*+-------------------------------------+
* - 레이어의 각 셀영역이 고정 그리드인 것을 틀에 제한없이 사용 가능하도록 추가
* - 2개 이상의 영역에 가젯이 이동가능하도록 추가
* - 각 특성별 분리 작업 -모듈화(?). drag & drop, toggle swapping, resize, ...
* - 여전히 알고리즘이나 소스에 대한 최적화 필요 쩝....
*
*@example
*-( new xwzGadgetry(프레임 객체 ID, [[Toggle Tag Name],[Columns : 가로 갯수],[Margin : 간격]]) ).load();
*
*+-------------------------------------+
*method
*+-------------------------------------+
*-loadSequel() : 가젯 위치값을 쿠키 정보에서 가져오는 함수
*-saveSequel() : 가제 위치를 쿠키로 저장한 후 onArrival 함수를 호출
*-onArrival(function object) : 가젯 위치 변경되어 완료되었을 때 호출하는 사용자용 함수
*-getIndex(object[or int, string]) : 고유 인덱스를 통해서 해당 가젯의 배열에서 위치를 찾는 함수
*-searchGadget(object[or int, string]) : 인덱스 또는 객체값, ID, Name을 통해서 가젯 인스턴스를 찾음
*-columns(int, bool) : 가젯의 가로 갯수 설정 또는 그 값 반환 함수 (Bool:값 설정 시 가젯이 위치를 찾아갈 때 효과 없이 이동할 것인지 여부)
*-strata(int) : 가젯이 해당 위치를 찾아 갈 때, _swapAviate 함수를 몇번 호출할 것인지 설정 또는 반환(가젯 위치 이동 속도에 관여함)
*-opacity(int) : 가젯이 이동할 때 투명도 설정 및 값 반환 함수(0~100)
*-motion(Bool) : 가젯 이동 시 이동 효과 없이 바로 적용할 지 설정/반환 함수
*-reset(Bool) : 가젯 위치 초기화 전역 함수
*-compose() : 각 가젯 배열 인덱스에 따른 위치를 초기화 하는 함수
*dragDepart(event object, target int) : 마우스다운 이벤트가 발생하였을 때 drag&drop 이벤트 발생
*-resetToggle(object, bool) : 위치 초기화 (Object:이벤트 발생 객체, Bool:모션 효과 여부)
*-prevToggle(object 이벤트 발생 객체,int[or object, string]) : 클릭 이벤트 발생 대상 가젯이 이전 순서로 이동하는 버튼(이미지) 설정
*-nextToggle(source object, target int[or object string]) : 클릭 이벤트 발생 시 대상 가젯이 다음 순서로 이동
*-firstToggle(source object, target int[or object string]) : 클릭 이벤트 발생 시 대상 가젯이 처음 순서로 이동
*-lastToggle(source object, target int[or object string]) : 클릭 이벤트 발생 시 대상 가젯이 마지막 순서로 이동
*-upToggle(source object, target int[or object string]) : 클릭 이벤트 발생 시 대상 가젯이 위로 이동
*-downToggle(source object, target int[or object string]) : 클릭 이벤트 발생 시 대상 가젯이 아래로 이동
*-leftToggle(source object, target int[or object string]) : 클릭 이벤트 발생 시 대상 가젯이 왼쪽으로 이동
*-rightToggle(source object, target int[or object string]) : 클릭 이벤트 발생 시 대상 가젯이 오른쪽으로 이동
*-expose(target int[or object string]) : 가젯 expand 명령 수행
*-expandAttrib(target int[or object], name string, value string [or function,string], function bind object) : expand 옵션 변경 함수.
* name [strata,min,max,animate], 함수 호출 bind object 생략 가능
*
*+-------------------------------------+
* memberof variable
*+-------------------------------------+
*-AvailableCookie : 쿠키 유지일
*-noResize : 리사이즈 변경 가능 여부 확인
*-borderColor : 영역 clone 객체 테두리 색상
*-grip : 리사이즈 grip 객체 속성 설정(color:색상,size:크기,minWidth:너비최소제한,minHeight:높이최소제한,maxWidth:너비최대제한,maxHeight:높이최대제한)
* grip={color:'red',size:8,minWidth:null,minHeight:null,maxWidth:null,maxHeight:null};
*
*3.Toggle List (Toggle TagName으로 지정된 Tag로 감싸 주어야 함.<span toggle="명령 옵션 지정"
*-reset:초기화
*-up, down, left, right:위, 아래, 왼쪽, 오른쪽으로 이동
*-first, last:처음, 끝으로 이동
*-next, prev:다음, 이전 순서로 이동
*-drag: 드래그 앤 드랍 영역
*-expand: document 영역에 대한
*-gadget: expand, resize 영역
*
*+-------------------------------------+
*expand option (<span toggle="expand" attr:옵션="값" ...>
*+-------------------------------------+
*- gadget toggle이 반드시 존재하여야 함.
*-'attr:strata' : Int 속도
*-'attr:state' : [max, min] 상태값
*-'attr:min' : 최소화되었을 때 실행할 함수 또는 JS code
*-'attr:max' : 최대화되었을 때 실행할 함수 또는 JS code
*-'attr:animate' : [Blind, Slide, [None or null]] : 각 상태값 변경 시 효과
*
*+-------------------------------------+
*onArrival return value
*+-------------------------------------+
*-index: 순서 값
*-top: style.top
*-left: style.left
*-width: style.width
*-height: style.height
*-expanded: expand 속성[Bool]
*/
미리보기 전체소스....
xwzGadgetry.js 파일은 첨부파일 다운...
<!--
/*****************************************************************************************************************
*
* Copyright(c) 2003. ezplus4u.com. all right reserved.
* Copyright(c) 2004. x-wiz.com. all right reserved.
* X-Wiz.com by Lee N.Thu
*****************************************************************************************************************/
-->
<!DOCTYPE HTML PUBLIC '-//W3C//DTD HTML 4.0 Transitional//EN'>
<html>
<head>
<title>뎁퍼-엑스위즈 :: JS - gadgetry, x-wiz.com</title>
<meta NAME="keywords" Content="javascript,php,programer,developer,xwiz,x-wiz,자바스크립트,프로그래머,개발자,엑스위즈">
<meta http-equiv='Content-Type' content='text/html; charset=UTF-8' />
<meta http-equiv='Cache-Control' content='No-Cache, must-reval!idate' />
<meta http-equiv='Pragma' content='No-Cache' />
<meta http-equiv='Expires' content='now' />
<meta http-equiv="imagetoolbar" CONTENT="no"/>
<meta name="robots" content="index, nofallow"/>
<meta name="REVISIT-AFTER" CONTENT="7 days"/>
<meta name="verify-v1" content="y2QWgtfH6RQYpXqaTsnMBN9ApdEEKmsqObAan/pQPlQ=" />
<style>
/**/
dl, dt, dd{margin:0px}
body, table, tr, td, select, textarea, input { font-family:'돋움'; font-size: 12px; line-height: 1.5em;color:#666666}
a, a:link,a:active, a:focus, a:visited {text-decoration: none;color:#666666;outline-style: none;outline-width:0px;outline-color: invert;}
a:hover{text-decoration: none; color: #FF3300}
dt,dd{float:left}
</style>
</head>
<body bgcolor="#FFFFFF">
<script language="JavaScript" src="xwzGadgetry.js" charset="UTF-8"></script>
<style type="text/css">
body{background-color:#ffffff; padding:0px; color:#333333;font-size:12px; font-family:굴림,Gulim,sans-serif; cursor:default;}
INPUT{font-size:11px;font-family:굴림,Gulim,sans-serif;}
TD{font-size:12px; font-family:굴림,Gulim,sans-serif; height:26px}
.frame {border:#CACACA 1px solid;margin:0px 0px 0px 0px;padding:15px 0 7px 0;background-color:#EEEEEE;clear:both}
.list{padding:0px 2px 0px 2px;margin:0px 0px 5px 0px;}
.list dd {margin:2px;padding:0px;color:#666666;width:260px;overflow:hidden;/*text-overflow:ellipsis;*/white-space:nowrap}
.img{display:inline;width:80px;height:60px;border:#D0D0D0 1px solid;margin:0 5px 0 5px;background-color:#FFFFFF;padding:3px}
.imgtext{display:inline;}
.block{width:300px;border:#CACACA 1px dotted;margin:5px 5px 5px 5px;}
#IDS_DIV_FRAME1{width:940px;border:#CACACA 2px solid;margin:5px;height:500px}
#IDS_DIV_FRAME1 .frame{width:300px;}
#IDS_DIV_FRAME2{width:940;border:#CACACA 2px solid;margin:5px;}
#IDS_DIV_FRAME2 .updown SPAN{text-indent:0px;width:30;text-align:center;height:12px;margin:0px 3px 0px 3px;border:#808080 1px solid;FILTER:progid:DXImageTransform.Microsoft.Gradient(GradientType=0, StartColorStr='#FFD58C', EndColorStr='#FF3300');}
.header {width:130px;padding:6px 0px 2px 0px;display:block;border:#D0D0D0 1px solid;text-align:center;font-weight:bold;color:#0066FF;background-color:#EEEEEE;}
.updown3{display:inline;width:300px;font-size:11px;text-align:right;}
.updown1 SPAN{text-indent:0px;width:30;text-align:center;height:12px;margin:3px 3px 0px 3px;border:#808080 1px solid;FILTER:progid:DXImageTransform.Microsoft.Gradient(GradientType=0, StartColorStr='#85B3E3', EndColorStr='#355FA8');}
.updown3 SPAN{text-indent:0px;width:30;text-align:center;height:12px;margin:0px 3px 0px 3px;border:#808080 1px solid;FILTER:progid:DXImageTransform.Microsoft.Gradient(GradientType=0, StartColorStr='#85B3E3', EndColorStr='#355FA8');}
</style>
<div id="IDS_DIV_FRAME1">
<!-- strart -->
<!-- strart -->
<!-- 11-->
<div class="block" style="height:150px">
<table width="300" cellspacing="0" cellpadding="0">
<tr>
<td width="120" style="border:#D0D0D0 1px solid;text-align:center;font-weight:bold;color:#0066FF;background-color:#EEEEEE;"><span toggle='drag'>Table 01</span></td>
<td align="right" style="padding-right:5px;font-size:11px" class="updown"><span title="이전" toggle="prev">prev</span>|<span title="다음" toggle="next">next</span>|<span title="처음" toggle="first">first</span>|<span title="마지막" toggle="last">last</span></td>
</tr>
</table>
<div class="frame">
<dl class="list">
<dd>ㆍThis Table 01 text 1</dd>
<dd>ㆍThis Table 01 text 2</dd>
</dl>
<table width="300" cellspacing="0" cellpadding="0" style="clear:both;">
<tr>
<td><img src="images/21.jpg" width="80" height="60" alt="x-wiz" /></td>
<td>This sample image 3</td>
</tr>
</table>
</div>
</div>
<!-- 12 -->
<div class="block">
<table width="300" cellspacing="0" cellpadding="0">
<tr>
<td width="120" style="border:#D0D0D0 1px solid;text-align:center;font-weight:bold;color:#0066FF;background-color:#EEEEEE;"><span toggle='drag'>Table 02</span></td>
<td align="right" style="padding-right:5px;font-size:11px" class="updown"><span title="이전" toggle="prev">prev</span>|<span title="다음" toggle="next">next</span>|<span title="처음" toggle="first">first</span>|<span title="마지막" toggle="last">last</span></td>
</tr>
</table>
<div class="frame">
<dl class="list">
<dd>ㆍThis Table 02 text 1</dd>
<dd>ㆍThis Table 02 text 2</dd>
</dl>
<div style="text-align:center;">
<div style="padding-top:10px;border-top:#CACACA 1px solid;width:96%;text-align:left;">
<div class="img"><img src="images/22.jpg" width="80" height="60" alt="x-wiz" /></div>
<div class="imgtext">This sample image 2</div>
</div>
</div>
</div>
</div>
<!-- 13-->
<div class="block">
<table width="300" cellspacing="0" cellpadding="0">
<tr>
<td width="120" style="border:#D0D0D0 1px solid;text-align:center;font-weight:bold;color:#0066FF;background-color:#EEEEEE;"><span toggle='drag'>Table 03</span></td>
<td align="right" style="padding-right:5px;font-size:11px" class="updown"><span title="이전" toggle="prev">prev</span>|<span title="다음" toggle="next">next</span>|<span title="처음" toggle="first">first</span>|<span title="마지막" toggle="last">last</span></td>
</tr>
</table>
<div class="frame">
<dl class="list">
<dd>ㆍThis Table 03 text 1</dd>
<dd>ㆍThis Table 03 text 2</dd>
</dl>
<div style="text-align:center">
<div style="padding-top:10px;border-top:#CACACA 1px solid;width:96%;text-align:left;">
<div class="img"><img src="images/23.jpg" width="80" height="60" alt="x-wiz" /></div>
<div class="imgtext">This sample image 3</div>
</div>
</div>
</div>
</div>
<!-- 11-->
<div class="block" style="height:165px">
<span toggle='drag'><table cellspacing="0" cellpadding="0" width="300">
<tr>
<td width="120" height="21" style="border:#D0D0D0 1px solid;text-align:center;font-weight:bold;color:#0066FF;background-color:#EEEEEE;"><b>Table 04</b></td>
<td> </td>
<td width="20" align="cneter"><span toggle='left' title="left"><img src="images/arrow_left1.gif" width="16" height="16" style="cursor:pointer"></span></td>
<td width="20" align="cneter"><span toggle='down' title="down"><img src="images/arrow_dn1.gif" width="16" height="16" style="cursor:pointer"></span></td>
<td width="20" align="cneter"><span toggle='up' title="up"><img src="images/arrow_up1.gif" width="16" height="16" style="cursor:pointer"></span></td>
<td width="20" align="cneter"><span toggle='right' title="right"><img src="images/arrow_right1.gif" width="16" height="16" style="cursor:pointer"></span></td>
<td width="20" align="cneter"><span toggle='expand' attr:min="opened(this)" attr:max="closed(this)" attr:animate='Blind' title="close" attr:strata="80"><input type=button value='닫기' style='border:none;background-color:white'></span></td>
</tr>
</table></span>
<span toggle='gadget'><div class="frame" style="clear:both;">
<dl class="list">
<dd>ㆍThis Table 04 text 1</dd>
<dd>ㆍThis Table 04 text 2</dd>
</dl>
<table width="300" cellspacing="0" cellpadding="0" style="clear:both;">
<tr>
<td><img src="images/23.jpg" width="80" height="60" alt="x-wiz" /></td>
<td>This sample image 4</td>
</tr>
</table>
</div></span>
</div>
<!-- 12 -->
<div class="block" style="height:165px">
<span toggle='drag'><table cellspacing="0" cellpadding="0" width="300">
<tr>
<td width="120" height="21" style="border:#D0D0D0 1px solid;text-align:center;font-weight:bold;color:#0066FF;background-color:#EEEEEE;"><b>Table 05</b></td>
<td> </td>
<td width="20" align="cneter"><span toggle='left' title="left"><img src="images/arrow_left1.gif" width="16" height="16" style="cursor:pointer"></span></td>
<td width="20" align="cneter"><span toggle='down' title="down"><img src="images/arrow_dn1.gif" width="16" height="16" style="cursor:pointer"></span></td>
<td width="20" align="cneter"><span toggle='up' title="up"><img src="images/arrow_up1.gif" width="16" height="16" style="cursor:pointer"></span></td>
<td width="20" align="cneter"><span toggle='right' title="right"><img src="images/arrow_right1.gif" width="16" height="16" style="cursor:pointer"></span></td>
<td width="20" align="cneter"><span toggle='expand' attr:min="this.getElementsByTagName('IMG')[0].src='images/sr/arrow_minus.gif';this.title='open' " attr:max="this.getElementsByTagName('IMG')[0].src='images/sr/arrow_plus.gif';this.title='close'" attr:animate='Slide' title="close" attr:strata="80"><img src="images/sr/arrow_plus.gif"></span></td>
</table></span>
<span toggle='gadget'>
<div class="frame">
<dl class="list">
<dd>ㆍThis Table 05 text 1</dd>
<dd>ㆍThis Table 05 text 2</dd>
</dl>
<div style="text-align:center;">
<div style="padding-top:10px;border-top:#CACACA 1px solid;width:96%;text-align:left;">
<div class="img"><img src="images/21.jpg" width="80" height="60" alt="x-wiz" /></div>
<div class="imgtext">This sample image 1</div>
</div>
</div>
</div></span>
</div>
<div class="block" style="height:165px">
<span toggle='drag'><table cellspacing="0" cellpadding="0" width="300">
<tr>
<td width="120" height="21" style="border:#D0D0D0 1px solid;text-align:center;font-weight:bold;color:#0066FF;background-color:#EEEEEE;"><b>Table 06</b></td>
<td> </td>
<td width="20" align="cneter"><span toggle='left' title="left"><img src="images/arrow_left1.gif" width="16" height="16" style="cursor:pointer"></span></td>
<td width="20" align="cneter"><span toggle='down' title="down"><img src="images/arrow_dn1.gif" width="16" height="16" style="cursor:pointer"></span></td>
<td width="20" align="cneter"><span toggle='up' title="up"><img src="images/arrow_up1.gif" width="16" height="16" style="cursor:pointer"></span></td>
<td width="20" align="cneter"><span toggle='right' title="right"><img src="images/arrow_right1.gif" width="16" height="16" style="cursor:pointer"></span></td>
<td width="20" align="cneter"><span toggle='expand' attr:min="opened(this)" attr:max="closed(this)" title="close">-</span></td>
</table></span>
<span toggle='gadget'><div class="frame">
<dl class="list">
<dd>ㆍThis Table 06 text 1</dd>
<dd>ㆍThis Table 06 text 2</dd>
</dl>
<div style="text-align:center;">
<div style="padding-top:10px;border-top:#CACACA 1px solid;width:96%;text-align:left;">
<div class="img"><img src="images/22.jpg" width="80" height="60" alt="x-wiz" /></div>
<div class="imgtext">This sample image 2</div>
</div>
</div>
</div></span>
</div>
<div class="block">
<table width="300" cellspacing="0" cellpadding="0">
<tr>
<td width="120" style="border:#D0D0D0 1px solid;text-align:center;font-weight:bold;color:#0066FF;background-color:#EEEEEE;"><span toggle='drag'>Table 07</span></td>
<td align="right" style="padding-right:5px;font-size:11px" class="updown"><span title="이전" toggle="prev">prev</span>|<span title="다음" toggle="next">next</span>|<span title="처음" toggle="first">first</span>|<span title="마지막" toggle="last">last</span></td>
</tr>
</table>
<div class="frame">
<dl class="list">
<dd>ㆍThis Table 07 text 1</dd>
<dd>ㆍThis Table 07 text 2</dd>
</dl>
<div style="text-align:center;">
<div style="padding-top:10px;border-top:#CACACA 1px solid;width:96%;text-align:left;">
<div class="img"><img src="images/23.jpg" width="80" height="60" alt="x-wiz" /></div>
<div class="imgtext">This sample image 3</div>
</div>
</div>
</div>
</div>
<!-- end -->
</div>
<form>
<input type='button' style="border:#CACACA 1px solid" value='리셋' id="ID_RESET">
<select name='count'><option value='1'>1</option><option value='2'>2</option><option value='3' selected>3</option><option value='4'>4</option></select>
<input type='button' style="border:#CACACA 1px solid" value='갯수변경' onClick="xts.columns(this.form.count.value)" >
<input type='button' style="border:#CACACA 1px solid" value='noResize' onClick="if(xts.noResize==true){xts.noResize=false;this.value='noResize';}else{xts.noResize=true;this.value='Resize';}">
</form>
<div id="IDS_DIV_" style="">
</div>
<div id="IDS_DIV_FRAME2">
<!-- strart -->
<!-- 11-->
<div class="block">
<table width="100%" cellspacing="0" cellpadding="0">
<tr>
<td width="120" style="border:#D0D0D0 1px solid;text-align:center;font-weight:bold;color:#0066FF;background-color:#EEEEEE;"><span toggle='drag'>Table 01</span></td>
<td align="right" style="padding-right:5px;font-size:11px" class="updown"><span title="이전" toggle="prev">prev</span>|<span title="다음" toggle="next">next</span>|<span title="처음" toggle="first">first</span>|<span title="마지막" toggle="last">last</span></td>
</tr>
</table>
<div class="frame">
<dl class="list">
<dd>ㆍThis Table 02 text 1</dd>
<dd>ㆍThis Table 02 text 2</dd>
</dl>
<div style="text-align:center;">
<div style="padding-top:10px;border-top:#CACACA 1px solid;width:96%;text-align:left;">
<div class="img"><img src="images/21.jpg" width="80" height="60" alt="x-wiz" /></div>
<div class="imgtext">This sample image A</div>
</div>
</div>
</div>
</div>
<!-- 22 -->
<div class="block">
<table width="100%" cellspacing="0" cellpadding="0">
<tr>
<td width="120" style="border:#D0D0D0 1px solid;text-align:center;font-weight:bold;color:#0066FF;background-color:#EEEEEE;"><span toggle='drag'>Table 02</span></td>
<td align="right" style="padding-right:5px;font-size:11px" class="updown"><span title="이전" toggle="prev">prev</span>|<span title="다음" toggle="next">next</span>|<span title="처음" toggle="first">first</span>|<span title="마지막" toggle="last">last</span></td>
</tr>
</table>
<div class="frame">
<dl class="list">
<dd>ㆍThis Table 02 text 1</dd>
<dd>ㆍThis Table 02 text 2</dd>
</dl>
<div style="text-align:center;">
<div style="padding-top:10px;border-top:#CACACA 1px solid;width:96%;text-align:left;">
<div class="img"><img src="images/24.jpg" width="80" height="60" alt="x-wiz" /></div>
<div class="imgtext">This sample image B</div>
</div>
</div>
</div>
</div>
<!-- 23-->
<div class="block">
<table width="100%" cellspacing="0" cellpadding="0">
<tr>
<td width="120" style="border:#D0D0D0 1px solid;text-align:center;font-weight:bold;color:#0066FF;background-color:#EEEEEE;"><span toggle='drag'>Table 03</span></td>
<td align="right" style="padding-right:5px;font-size:11px" class="updown"><span title="이전" toggle="prev">prev</span>|<span title="다음" toggle="next">next</span>|<span title="처음" toggle="first">first</span>|<span title="마지막" toggle="last">last</span></td>
</tr>
</table>
<span toggle='gadget'><div class="frame">
<dl class="list">
<dd>ㆍThis Table 03 text 1</dd>
<dd>ㆍThis Table 03 text 2</dd>
</dl>
<div style="text-align:center">
<div style="padding-top:10px;border-top:#CACACA 1px solid;width:96%;text-align:left;">
<div class="img"><img src="images/21.jpg" width="80" height="60" alt="x-wiz" /></div>
<div class="imgtext">This sample image C</div>
</div>
</div>
</div></span>
</div>
<!-- end -->
</div>
<script language="JavaScript">
var xts=new xwzGadgetry('IDS_DIV_FRAME1', 'SPAN',3);
var xts2=new xwzGadgetry('IDS_DIV_FRAME2');
xts.onArrival=function(a){
var div=document.getElementById('IDS_DIV_');
div.innerHTML='';
for(var i=0,len=a.length;i<len;i++){
div.innerHTML += i + ':' + a[i].index + ', top='+a[i].top +', left='+a[i].left +', width='+a[i].width +', Expand:' + (a[i].expanded==true?'Yes' : 'No') + '<br>';
}
}
window.onload=function(){
xts.load();
xts.resetToggle(document.getElementById('ID_RESET'), true);
//xts.motion(false)
xts2.load();
}
function opened(obj){
var a=obj.getElementsByTagName('INPUT');
if(a.length==0 && obj.innerHTML=='-'){
obj.innerHTML='+';
}else if(a[0].type=='button'){
a[0].value='열기';
}
obj.title='close';
}
function closed(obj){
var a=obj.getElementsByTagName('INPUT');
if(a.length==0 && obj.innerHTML=='+'){
obj.innerHTML='-';
}else if(a[0].type=='button'){
a[0].value='닫기';
}
obj.title='open';
}
</script>
<b>[<a href="xwzGadgetry.js">source file</a>]</b>
<div style="margin-top:10px;height:360px;width:955px;overflow:auto;background-color:#F2F2F2;border:#CACACA 2px solid"><xmp>
<b>
var xg=new xwzGadgetry('IDS_DIV_FRAME1', 'SPAN',3);
xg.load();
</b>
/*
Copyright (C) 2003-2007, x-wiz.com.
xwzGadgetry : Javascript UI Library for the gadget(or the widget)
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation; either
version 2.1 of the License, or (at your option) any later version.
This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Lesser General Public License for more details.
- http://www.gnu.org/licenses/lgpl.html
*/
/**
* xwzGadgetry : Javascript UI Library for the gadget(or the widget) <http://www.x-wiz.com/>
* 레이어의 위치 지정 또는 순서 출력을 사용자가 원하는 위치 또는 순서로 배열하도록 하는 함수.
* 쇼핑몰에서 상품 위치나, 디자인관리에서 디자인 레이어 위치 이동에 따른 배열,
* 여러 통계 수치나, 입력폼과 출력폼이 동일한 화면에서 출력 순서 변경을 위해 만듦
*
* Idea of "drag&drop swap" is from "google ig<http://www.google.co.kr/ig/>" - see dragDepart()
* Idea of "toggle swap" is from "yahoo.com<http://kr.yahoo.com/>"- see prevToggle()
* Idea of "the distance" is from "daum.net<http://www.daum.net/>" - see _swapAviate()
* Idea of "bindAsObject, bindAsEvent" is from "Prototype JavaScript Framework <http://www.prototypejs.org/>"
*
*@copyright x-wiz.com
*@license The LGPL License
*@author N.Thu Lee
*@version 1.0 Alpha
*@release 2006.11.07
*@updated 2007.05.28
*@changelog
*2006.11.22
*- 레이아웃 이동 간격 수식 변경(다음.넷 참조)
*
*2006.12.04
*- 드래그앤드랍 기능 추가
*
*2007.05.02
*- xwzGadgetry로 라이브러리 명칭 확정
*- 이벤트 핸들러 추가 및 해제 함수를 라이브러리 외부 함수로 분리
*- 2개 이상의 라이브러리 대상 객체에 대해서 드래그앤드랍시 레이어 위치 문제 수정
*- bindAsObject, bindAsEvent 외부 함수 추가
*
*2007.05.05
*- expand 기능 추가. 가젯의 document 영역에 대한 최소화, 최대화 기능 추가
*
*2007.05.28
*-resize 기능 추가
*
*2007.06.04
*-resize 이벤트 발생 시 크기 표시 WidthxHeight부분이 노출되지 않은 문제 수정
*
*+-------------------------------------+
*plan
*+-------------------------------------+
* - 레이어의 각 셀영역이 고정 그리드인 것을 틀에 제한없이 사용 가능하도록 추가
* - 2개 이상의 영역에 가젯이 이동가능하도록 추가
* - 각 특성별 분리 작업 -모듈화(?). drag & drop, toggle swapping, resize, ...
* - 여전히 알고리즘이나 소스에 대한 최적화 필요 쩝....
*
*@example
*-( new xwzGadgetry(프레임 객체 ID, [[Toggle Tag Name],[Columns : 가로 갯수],[Margin : 간격]]) ).load();
*
*+-------------------------------------+
*method
*+-------------------------------------+
*-loadSequel() : 가젯 위치값을 쿠키 정보에서 가져오는 함수
*-saveSequel() : 가제 위치를 쿠키로 저장한 후 onArrival 함수를 호출
*-onArrival(function object) : 가젯 위치 변경되어 완료되었을 때 호출하는 사용자용 함수
*-getIndex(object[or int, string]) : 고유 인덱스를 통해서 해당 가젯의 배열에서 위치를 찾는 함수
*-searchGadget(object[or int, string]) : 인덱스 또는 객체값, ID, Name을 통해서 가젯 인스턴스를 찾음
*-columns(int, bool) : 가젯의 가로 갯수 설정 또는 그 값 반환 함수 (Bool:값 설정 시 가젯이 위치를 찾아갈 때 효과 없이 이동할 것인지 여부)
*-strata(int) : 가젯이 해당 위치를 찾아 갈 때, _swapAviate 함수를 몇번 호출할 것인지 설정 또는 반환(가젯 위치 이동 속도에 관여함)
*-opacity(int) : 가젯이 이동할 때 투명도 설정 및 값 반환 함수(0~100)
*-motion(Bool) : 가젯 이동 시 이동 효과 없이 바로 적용할 지 설정/반환 함수
*-reset(Bool) : 가젯 위치 초기화 전역 함수
*-compose() : 각 가젯 배열 인덱스에 따른 위치를 초기화 하는 함수
*dragDepart(event object, target int) : 마우스다운 이벤트가 발생하였을 때 drag&drop 이벤트 발생
*-resetToggle(object, bool) : 위치 초기화 (Object:이벤트 발생 객체, Bool:모션 효과 여부)
*-prevToggle(object 이벤트 발생 객체,int[or object, string]) : 클릭 이벤트 발생 대상 가젯이 이전 순서로 이동하는 버튼(이미지) 설정
*-nextToggle(source object, target int[or object string]) : 클릭 이벤트 발생 시 대상 가젯이 다음 순서로 이동
*-firstToggle(source object, target int[or object string]) : 클릭 이벤트 발생 시 대상 가젯이 처음 순서로 이동
*-lastToggle(source object, target int[or object string]) : 클릭 이벤트 발생 시 대상 가젯이 마지막 순서로 이동
*-upToggle(source object, target int[or object string]) : 클릭 이벤트 발생 시 대상 가젯이 위로 이동
*-downToggle(source object, target int[or object string]) : 클릭 이벤트 발생 시 대상 가젯이 아래로 이동
*-leftToggle(source object, target int[or object string]) : 클릭 이벤트 발생 시 대상 가젯이 왼쪽으로 이동
*-rightToggle(source object, target int[or object string]) : 클릭 이벤트 발생 시 대상 가젯이 오른쪽으로 이동
*-expose(target int[or object string]) : 가젯 expand 명령 수행
*-expandAttrib(target int[or object], name string, value string [or function,string], function bind object) : expand 옵션 변경 함수.
* name [strata,min,max,animate], 함수 호출 bind object 생략 가능
*
*+-------------------------------------+
* memberof variable
*+-------------------------------------+
*-AvailableCookie : 쿠키 유지일
*-noResize : 리사이즈 변경 가능 여부 확인
*-borderColor : 영역 clone 객체 테두리 색상
*-grip : 리사이즈 grip 객체 속성 설정(color:색상,size:크기,minWidth:너비최소제한,minHeight:높이최소제한,maxWidth:너비최대제한,maxHeight:높이최대제한)
* grip={color:'red',size:8,minWidth:null,minHeight:null,maxWidth:null,maxHeight:null};
*
*3.Toggle List (Toggle TagName으로 지정된 Tag로 감싸 주어야 함.<span toggle="명령 옵션 지정"
*-reset:초기화
*-up, down, left, right:위, 아래, 왼쪽, 오른쪽으로 이동
*-first, last:처음, 끝으로 이동
*-next, prev:다음, 이전 순서로 이동
*-drag: 드래그 앤 드랍 영역
*-expand: document 영역에 대한
*-gadget: expand, resize 영역
*
*+-------------------------------------+
*expand option (<span toggle="expand" attr:옵션="값" ...>
*+-------------------------------------+
*- gadget toggle이 반드시 존재하여야 함.
*-'attr:strata' : Int 속도
*-'attr:state' : [max, min] 상태값
*-'attr:min' : 최소화되었을 때 실행할 함수 또는 JS code
*-'attr:max' : 최대화되었을 때 실행할 함수 또는 JS code
*-'attr:animate' : [Blind, Slide, [None or null]] : 각 상태값 변경 시 효과
*
*+-------------------------------------+
*onArrival return value
*+-------------------------------------+
*-index: 순서 값
*-top: style.top
*-left: style.left
*-width: style.width
*-height: style.height
*-expanded: expand 속성[Bool]
*/
/**
+---------------------------------------------------------------------------+
| 전역 함수 선언
+ --------------------------------------------------------------------------+
*/
/*
* 해당 메소드를 소유객체(Owner object)로 인스턴스를 미리 묶어서 반환하는 함수, 소유객체와 동일한 인자값을 갖는다.
*@param {Object, [Number, String, Object, ...], ...} 함수(메소드)를 소유하고 있는 객체, 전달 변수, ...
*@author N.Thu Lee
*@copyright x-wiz.com
*@version 0.1
*@release 2007.01.12
*/
Function.prototype.bindAsObject=function(){var _$=this,args=[],object=null;for(var i=0,len=arguments.length;i<len;i++)args[i]=arguments[i];object=args.shift();return function(){return _$.apply(object,args);}};
/*
* 해당 메소드를 소유객체(Owner object)로 인스턴스를 미리 묶어서 반환하는 함수, 이벤트 객체를 전달받으며, 소유객체와 동일한 인자값을 갖는다.
*@param {Object, [Number, String, Object, ...], ...} 함수(메소드)를 소유하고 있는 객체, 전달 변수, ...
*@author N.Thu Lee
*@copyright x-wiz.com
*@version 0.1
*@release 2007.01.12
*/
Function.prototype.bindAsEvent=function(){ var _$=this,args=[],object=null; for(var i=0,len=arguments.length;i<len;i++)args[i]=arguments[i];object=args.shift(); return function(e){ var body=document.body||document.documentElement,hEvent=(e||window.event),_o=hEvent['element']=hEvent.target||hEvent.srcElement; /*객체의 body에서의 Top,Left 위치*/ hEvent['offsetTop']=hEvent['offsetLeft']=0; while(_o.offsetParent){ hEvent['offsetLeft']+=_o.offsetLeft; hEvent['offsetTop']+=_o.offsetTop; _o=_o.offsetParent; }; /*이벤트 객체의 속성값 반환*/ hEvent['_x']=hEvent.pageX||(hEvent.clientX+(body.scrollLeft-body.clientLeft)); hEvent['_y']=hEvent.pageY||hEvent.clientY+body.scrollTop-body.clientTop; hEvent['_left']=(hEvent.which&&e.button==0)||!!(hEvent.button&1); hEvent['_middle']=(hEvent.which&&e.button==1)||!!(hEvent.button&4); hEvent['_right']=(hEvent.which&&e.button==2)||!!(hEvent.button&2); hEvent['_key']=(hEvent.keyCode||hEvent.which); return _$.apply(object,[hEvent].concat(args)); }; };
/*
* 특정 객체에 이벤트 핸들러 추가 함수
*@param {Object, String, Function, Bool} 대상 객체, 이벤트 명, 함수, capture
*@author N.Thu Lee
*@copyright x-wiz.com
*@version 0.1
*@release 2007.01.12
*/
addEventObserve=function(element,name,fpnotify,useCapture){if(element.addEventListener)element.addEventListener(name,fpnotify,useCapture||false);else if(element.attachEvent)element.attachEvent('on'+name,fpnotify);};
/*
* 특정 객체에 이벤트 핸들러 해제 함수
*@param {Object, String, Function, Bool} 대상 객체, 이벤트 명, 함수, capture
*@author N.Thu Lee
*@copyright x-wiz.com
*@version 0.1
*@release 2007.01.12
*/
freeEventObserve=function(element,name,fpnotify,useCapture){ if(element.removeEventListener)element.removeEventListener(name,fpnotify,useCapture||false);else if(element.detachEvent)element.detachEvent('on'+name,fpnotify);};/**
* Opacity style Apply
*@param {Object} element-style 요소를 갖는 객체
*@param {Number} nValue-투명도
*@author N.Thu Lee
*@copyright x-wiz.com
*@version 0.1
*@release 2007.01.12
*/
notifyOpacity=function(element, nValue){ try{ if(element.style.filter!=null){/*IE*/ element.style.filter=nValue==null?'':'alpha(opacity='+nValue+')'; if(!element.currentStyle||!element.currentStyle.hasLayout){element.style.zoom=1;} }else if(element.style.opacity!=null){/**/ element.style.opacity=nValue==null?null:nValue/100; }else if(element.style['-moz-opacity']!=null){/* Moz's*/ element.style['-moz-opacity']=nValue==null?null:nValue/100; }else if(element.style.MozOpacity!=null){/*FF*/ element.style.MozOpacity=nValue==null?null:nValue/100; }else if(element.style['-khtml-opacity']!=null){/*KDE*/ element.style['-khtml-opacity']=nValue==null?null:nValue/100; }else{ } }catch(e){}; };
/**
+---------------------------------------------------------------------------+
| xwzGadgetry
+ --------------------------------------------------------------------------+
*/
/**
* xwzGadgetry 생성.
*@param {String} byID 해당 객체를 포함하고있는 객체
*@param {Number} nColumns 각 Row로 분활될 Column갯수
*@param {Number} Distance 각 대상 객체 간의 간격
*@return {Object} Returns a new xwzGadgetry.
*@access public
*@constructor
*/
var xwzGadgetry=function(byID,tagName,Columns,Distance){ this.version='1.0alpha'; this.sName='__xwzSRW_'+byID; this.Gadgetry=document.getElementById(byID); if(this.Gadgetry==null)return null; this.initialize=false;/*초기화 여부*/ this.tagName=tagName||'SPAN'; this.nDistance=Distance||10;/*객체들간의 간격*/ this.nCells=Columns||1;/*Column 갯수*/ this.nOpacity=86;/*이동간의 투명도설정*/ this.nStrata=5;/*레이어 이동 단계 갯수*/ this.isMotion=true; this.zIndex=0;/*deep index*/ this.Nodes=[];/*객체 배열변수*/ this.Atlas=[];/*각 좌표값 배열변수*/ this.Queue=[];/*이동대상 배열변수*/ this.resTime=null;/*시간*/ this.Observers=[]; this.keelblocks=null;/**/ this.talebearing=''; /*드래그 앤 드랍,Resize 관련 변수*/ this._trace ={dX:0,dY:0,nTarget:null,nSource:null};/*마우스 이벤트 정보*/ this.grips ={lt:null,lm:null,lb:null,ct:null,cb:null,rt:null,rm:null,rb:null}; this.sizeinfo =null; };
/**
* 레이어 위치가 변경되어 완료되었을 때 지정된 함수를 호출
*@method onArrival
*@see #saveSequel()
*/
xwzGadgetry.prototype.onArrival=null;
/**
*@memberof xwzGadgetry
*@access public
*/
/*resize option*/ xwzGadgetry.prototype.noResize=false;
/*bordercolor*/ xwzGadgetry.prototype.borderColor='#808080';
/*resize grip*/ xwzGadgetry.prototype.grip={color:'red',size:8,minWidth:null,minHeight:null,maxWidth:null,maxHeight:null};
/*쿠키유지일*/ xwzGadgetry.prototype.AvailableCookie=7;
/**
* 각 객체들의 순서를 쿠키에서 가져오는 함수
*@method loadSequel
*@return {String} Return 쿠키값.
*@access public
*/
xwzGadgetry.prototype.loadSequel=function(){ var offsetMin=0,offsetMax=0; if(document.cookie!.length>0){/*쿠키가 존재하는 체크*/ offsetMin=document.cookie!.indexOf(this.sName+'=');/*해당한 이름을 갖는 쿠키 정보 시작 위치*/ if(offsetMin!==-1){ offsetMin+=this.sName.length+1;offsetMax=document.cookie!.indexOf(';',offsetMin); if(offsetMax===-1){offsetMax=document.cookie!.length;}; return (unescape(document.cookie!.substring(offsetMin,offsetMax))).toString().split(','); } } return false; }
/**
* 각 레이어들의 순서를 쿠키로 저장하는 함수, 외부호출함수가 있을 경우 해당 함수 호출
*@method saveSequel
*@see #onArrival()
*@access public
*/
xwzGadgetry.prototype.saveSequel=function(){ var dtExpire=null,sExpire='',S=[],domain=window.document.domain||window.location!.hostname; for(var i=0,len=this.Nodes.length;i<len;i++){S[i]=this.Nodes[i].getAttribute('_GadgetIndex');} if(this.AvailableCookie*24>0){dtExpire=new Date((new Date()).getTime()+(this.AvailableCookie*24)*3600000);sExpire='; expires='+dtExpire.toGMTString();} document.cookie!=(this.sName)+'='+escape(S.toString())+sExpire+'; path=/;'+(typeof(domain)=='string'&&domain!=''?'domain='+domain:'')+';'; var $A=[],nIndex; /** * 레이어 위치가 변경되어 완료되었을 때 지정된 함수를 호출 *@method onArrival *@see #saveSequel() */ if(typeof this.onArrival=='function'&&this.initialize==true){ for(var i=0,len=this.Nodes.length;i<len;i++){ nIndex=this.Nodes[i].getAttribute('_GadgetIndex'); $A[nIndex]={index:i, top:parseInt(this.Nodes[i].style.top),left:parseInt(this.Nodes[i].style.left),width:parseInt(this.Nodes[i].style.width),height:parseInt(this.Nodes[i].style.height), expanded:this.Nodes[i].gadget!=null?(this.Nodes[i].gadget.state=='collapse'?false:true):true }; } this.onArrival($A); } };
/**
* 각 객체들의 고유 인덱스를 통해서 해당 객체의 배열에서의 위치를 찾는 함수
*@method getIndex
*@param {Number} _index 객체의 인덱스값
*@return {Number} 대상 인덱스를 갖는 Nodes 배열 인덱스
*@access public
*/
xwzGadgetry.prototype.getIndex=function(_index){for(var i in this.Nodes){if(this.Nodes[i].getAttribute('_GadgetIndex')==_index)return(i*1);}};
/**
* 인덱스 또는 객체값을 통해 해당 객체의 배열 위치를 찾는 함수
*@method searchGadget
*@param {Object,Number,String} mixValue 특정 객체의 인덱스값, 또는 인스턴스 또는 ID, Name 속성 값
*@return {Number} 대상 객체의 배열 Nodes 인덱스
*@access public
*@changelog 2007.05.04 파라미터에 id, name속성값에 대해서도 처리할 수 있도록 getElementById, getElementByName 추가
*/
xwzGadgetry.prototype.searchGadget=function(mixValue){var o=null;if(typeof mixValue=='object'){for(var i in this.Nodes)if(this.Nodes[i]==mixValue)return(i*1);}else if(typeof mixValue=='number'){for(var i in this.Nodes)if(i==mixValue)return(i*1);}else if(typeof mixValue=='string'){o=document.getElementById(mixValue)||document.getElementsByName(mixValue)[0]||null;for(var i in this.Nodes)if(this.Nodes[i]==mixValue)return(i*1);};return false};
/**
* Column 갯수 변경 함수 또는 Column갯수 반환 함수
*@method columns
*@param {Number} nValue column 갯수
*@param {Bool} isDirectly 변경 시 즉각 반영여부(true : 즉각 반영하지 않음, false : 즉각 반영)
*@return {Number} Column 갯수
*@access public
*/
xwzGadgetry.prototype.columns=function(nValue,isDirectly){this.nCells=(typeof nValue=="number"||typeof nValue=="string")?nValue*1:this.nCells;this._swapDepart(isDirectly);return this.nCells;};
/**
* 레이어 이동 단계 갯수 변경 및 반환 함수
*@method strata
*@param {Number} nValue 변경하려는 값
*@return {Number} 레이어 이동 단계 갯수 싸이클
*@access public
*/
xwzGadgetry.prototype.strata=function(nValue){return this.nStrata=(typeof nValue=="number"||typeof nValue=="string")?nValue*1:this.nStrata;};
/**
* 이동시 투명도 설정함수
*@method opacity
*@param {Number} nValue 변경하려는 값
*@return {Number} 투명도 값
*@access public
*/
xwzGadgetry.prototype.opacity=function(nValue){return this.nOpacity=(typeof nValue=="number"||typeof nValue=="string")?nValue*1:this.nOpacity;};
/**
* 이동시 바로 적용할 지 여부
*@method motion
*@param {Bool} bValue 변경하려는 값
*@return {Bool} true, false
*@access public
*/
xwzGadgetry.prototype.motion=function(bValue){return this.isMotion=bValue;};
/**
* 각 레이어들의 순위를 초기화 하는 함수
*@method resetToggle
*@see #reset()
*@see addEventObserve()
*@param {Object} 이벤트 발생 객체
*@param {Bool} isDirectly 즉각 반영여부
*@access public
*/
xwzGadgetry.prototype.resetToggle=function(objSrc,isDirectly){addEventObserve(objSrc,'click',this.reset.bindAsObject(this,isDirectly))};
/**
* 이전 레이어와 위치 변경
*@method prevToggle
*@see #searchGadget()
*@see #_stack()
*@param {Object} 이벤트 발생 객체
*@param {Object,Number,String} mixValue 특정 객체의 인덱스값, 또는 인스턴스 또는 ID, Name 속성 값
*@access public
*/
xwzGadgetry.prototype.prevToggle=function(objSrc,mixValue){var _index=this.searchGadget(mixValue);if(_index!==false)addEventObserve(objSrc,'click',this._stack.bindAsObject(this,_index,-1));};
/**
* 다음 레이어와 위치 변경
*@method nextToggle
*@see #searchGadget()
*@see #_stack()
*@param {Object} 이벤트 발생 객체
*@param {Object,Number,String} [mixValue] 특정 객체의 인덱스값, 또는 인스턴스 또는 ID, Name 속성 값
*@access public
*/
xwzGadgetry.prototype.nextToggle=function(objSrc,mixValue){var _index=this.searchGadget(mixValue);if(_index!==false)addEventObserve(objSrc,'click',this._stack.bindAsObject(this,_index,1));};
/**
* 처음 위치로 이동
*@method firstToggle
*@see #searchGadget()
*@see #_above()
*@param {Object} 이벤트 발생 객체
*@param {Object,Number,String} [mixValue] 특정 객체의 인덱스값, 또는 인스턴스 또는 ID, Name 속성 값
*@access public
*/
xwzGadgetry.prototype.firstToggle=function(objSrc,mixValue){var _index=this.searchGadget(mixValue);if(_index!==false)addEventObserve(objSrc,'click',this._above.bindAsObject(this,_index));};
/**
* 마지막 위치로 이동
*@method lastToggle
*@see #searchGadget()
*@see #_below()
*@param {Object} 이벤트 발생 객체
*@param {Object,Number,String} [mixValue] 특정 객체의 인덱스값, 또는 인스턴스 또는 ID, Name 속성 값
*@access public
*/
xwzGadgetry.prototype.lastToggle=function(objSrc,mixValue){var _index=this.searchGadget(mixValue);if(_index!==false)addEventObserve(objSrc,'click',this._below.bindAsObject(this,_index));};
/**
* y 좌표 객체와 자리 변경(column 수 만큼 인덱스 감소)
*@method upToggle
*@see #searchGadget()
*@see #_cross()
*@param {Object} 이벤트 발생 객체
*@param {Object,Number,String} [mixValue] 특정 객체의 인덱스값, 또는 인스턴스 또는 ID, Name 속성 값
*@access public
*/
xwzGadgetry.prototype.upToggle=function(objSrc,mixValue){var _index=this.searchGadget(mixValue);if(_index!==false)addEventObserve(objSrc,'click',this._cross.bindAsObject(this,_index,'up'));};
/**
* y 좌표 객체와 자리 변경(column 수 만큼 인덱스 증가)
*@method downToggle
*@see #searchGadget()
*@see #_cross()
*@param {Object} 이벤트 발생 객체
*@param {Object,Number,String} [mixValue] 특정 객체의 인덱스값, 또는 인스턴스 또는 ID, Name 속성 값
*@access public
*/
xwzGadgetry.prototype.downToggle=function(objSrc,mixValue){var _index=this.searchGadget(mixValue);if(_index!==false)addEventObserve(objSrc,'click',this._cross.bindAsObject(this,_index,'down'));};
/**
* x 좌표 객체와 자리 변경(해당 가로 줄에서 첫번째로 이동)
*@method leftToggle
*@see #searchGadget()
*@see #_cross()
*@param {Object} 이벤트 발생 객체
*@param {Object,Number,String} [mixValue] 특정 객체의 인덱스값, 또는 인스턴스 또는 ID, Name 속성 값
*@access public
*/
xwzGadgetry.prototype.leftToggle=function(objSrc,mixValue){var _index=this.searchGadget(mixValue);if(_index!==false)addEventObserve(objSrc,'click',this._cross.bindAsObject(this,_index,'left'));};
/**
* x 좌표 객체와 자리 변경(해당 가로 줄에서 마지막으로 이동)
*@method rightToggle
*@see #searchGadget()
*@see #_cross()
*@param {Object} 이벤트 발생 객체
*@param {Object,Number,String} [mixValue] 특정 객체의 인덱스값, 또는 인스턴스 또는 ID, Name 속성 값
*@access public
*/
xwzGadgetry.prototype.rightToggle=function(objSrc,mixValue){var _index=this.searchGadget(mixValue);if(_index!==false)addEventObserve(objSrc,'click',this._cross.bindAsObject(this,_index,'right'));};
/**
* 환경값에 따라 초기화 하는 함수
*@method load
*@access public
*/
xwzGadgetry.prototype.load=function(){ if(this.initialize==true) return ; var nX=0,nY=0,v=[],h=[],nNodeIndex=0; var oNode=null,List=[],_t=[],_f=this.loadSequel(),a={},t=null; for(var i=0,iLen=this.Gadgetry.childNodes.length;i<iLen;i++){ oNode=this.Gadgetry.childNodes[i]; /*자식 객체가 주석,문자열 또는 object가 아닌 경우 */ if(oNode.nodeName.toLowerCase()=='#text'||oNode.nodeName.toLowerCase()=='#comment'||typeof(oNode)!='object')continue; oNode['gadget']={}; /*자식 객체에서 명령 기능을 갖는 SPAN 태그를 찾는다*/ oList=oNode.getElementsByTagName(this.tagName); for(var j=0,jLen=oList.length;j<jLen;j++){ if(oList[j].getAttribute('toggle')==null)continue; oList[j].style.cursor='pointer'; switch(oList[j].getAttribute('toggle').toLowerCase()){ case 'gadget': /*slide 효과를 주기위한 DIV 생성*/ t=document.createElement('DIV'); t.style.marginTop='-1px'; t.style.marginLeft='0px'; t.style.width=(parseInt(oList[j].style.width)||oList[j].offsetWidth)+'px'; t.style.height='1px'; t.style.overflow='hidden';/*IE Margin Bug -_-;;*/ oList[j].insertBefore(t,oList[j].childNodes[0]); oNode['gadget'].topgap=t.style.marginTop; /*영역 지정*/ oList[j].style.display='block'; oList[j].style.width=(parseInt(oList[j].style.width)||oList[j].offsetWidth)+'px'; oList[j].style.height=((parseInt(oList[j].style.height)||oList[j].offsetHeight)+1)+'px'; oList[j].style.overflow='hidden'; oList[j].style.visibility='visible'; oNode['gadget'].style=oList[j].style; oNode['gadget'].width=parseInt(oList[j].style.width); oNode['gadget'].height=parseInt(oList[j].style.height); break; case 'expand': oNode['gadget'].onMinimized=new Function(oList[j].getAttribute('attr:min')).bindAsObject(oList[j]);/*최소화일때 사용자 정의 함수 실행*/ oNode['gadget'].onMaximized=new Function(oList[j].getAttribute('attr:max')).bindAsObject(oList[j]);/*최대화일때 사용자 정의 함수 실행*/ oNode['gadget'].strata=oList[j].getAttribute('attr:strata')||this.nStrata; oNode['gadget'].state=oList[j].getAttribute('attr:state')||'expand'; oNode['gadget'].animate=(oList[j].getAttribute('attr:animate')||'none').toLowerCase(); addEventObserve(oList[j],'click',this.expose.bindAsObject(this,nNodeIndex)); break; case 'reset': addEventObserve(oList[j],'click',this.reset.bindAsObject(this)); break; case 'up': addEventObserve(oList[j],'click',this._cross.bindAsObject(this,nNodeIndex,'up')); break; case 'down': addEventObserve(oList[j],'click',this._cross.bindAsObject(this,nNodeIndex,'down')); break; case 'left': addEventObserve(oList[j],'click',this._cross.bindAsObject(this,nNodeIndex,'left')); break; case 'right': addEventObserve(oList[j],'click',this._cross.bindAsObject(this,nNodeIndex,'right')); break; case 'drag': addEventObserve(oList[j],'mousedown',this.dragDepart.bindAsEvent(this,nNodeIndex)); oList[j].style.cursor='move'; break; case 'first': addEventObserve(oList[j],'click',this._above.bindAsObject(this,nNodeIndex)); break; case 'last': addEventObserve(oList[j],'click',this._below.bindAsObject(this,nNodeIndex)); break; case 'next': addEventObserve(oList[j],'click',this._stack.bindAsObject(this,nNodeIndex,1)); break; case 'prev': addEventObserve(oList[j],'click',this._stack.bindAsObject(this,nNodeIndex,-1)); default:break; }; }; /*Resize*/ addEventObserve(oNode,'mousedown',this.resize.bindAsEvent(this,nNodeIndex)); /*하위 객체의 너비,높이*/ nX=oNode.offsetWidth>parseInt(oNode.style.width||0)?oNode.offsetWidth:parseInt(oNode.style.width);/*Node Width*/ nY=oNode.offsetHeight>parseInt(oNode.style.height||0)?oNode.offsetHeight:parseInt(oNode.style.height);/*Node Height*/ /*각 하위객체에 Index값 설정*/ oNode.setAttribute('_GadgetIndex',nNodeIndex); /*각 하위객체의 위치에 대한 값을 갖음*/ this.Atlas[nNodeIndex]={X:0,Y:0,cX:nX,cY:nY,dX:0,dY:0}; this.Nodes[nNodeIndex]=oNode; /*하위 객체의 스타일 속성 변경*/ oNode.style.position='absolute'; oNode.style.width=nX+'px';oNode.style.height=nY+'px'; oNode.style.margin='0px 0px 0px 0px'; oNode.style.display='block'; this.zIndex=this.zIndex+(this.Nodes.length*1000); nNodeIndex++; }; /*대상객체의 position값 변경*/ this.Gadgetry.style.position='relative'; if(_f!=false){/*sort*/ oList=this.Nodes;this.Nodes=[]; for(var i=0,len=oList.length;i<len;i++){if(oList[_f[i]]==null)continue;_t[_t.length]=_f[i];}; for(var i=0,len=_t.length;i<len;i++){j=_t[i]==null?i:_t[i];this.Nodes[i]=oList[j]}; oList=null;_f=null;_t=null; }; /*드래그앤드랍,리사이즈에 대한 이동객체의 복사본(크기만 갖음)*/ this.keelblocks=document.createElement('DIV'); with(this.keelblocks.style){border=this.borderColor+' 2px dashed';position='absolute';display='none';cursor='move';}; this.Gadgetry.appendChild(this.keelblocks); /*리사이즈*/ var cursors={lt:'se-resize',lm:'e-resize',lb:'ne-resize',ct:'s-resize',cb:'n-resize',rt:'sw-resize',rm:'w-resize',rb:'nw-resize'}; for(var nm in this.grips){ this.grips[nm]=document.createElement('DIV'); this.grips[nm].nm=nm; this.grips[nm].style.left ='0px';this.grips[nm].style.top='0px'; this.grips[nm].style.width=parseInt(this.grip.size)+'px';this.grips[nm].style.height=parseInt(this.grip.size)+'px'; this.grips[nm].style.margin='0px';this.grips[nm].style.padding='0px';this.grips[nm].style.border='none'; this.grips[nm].style.position='absolute'; this.grips[nm].style.display='block'; this.grips[nm].style.overflow='hidden'; this.grips[nm].style.visibility='hidden'; this.grips[nm].style.cursor=cursors[nm] ; this.grips[nm].style.zIndex=this.zIndex+100; this.grips[nm].style.backgroundColor=this.grip.color; addEventObserve(this.grips[nm],'mousedown',this._resizeDepart.bindAsEvent(this)); this.grips[nm].innerHTML="<img width='"+parseInt(this.grip.size)+"' height='"+parseInt(this.grip.size)+"' style='visibility:hidden;'>"; this.Gadgetry.appendChild(this.grips[nm]); } this.sizeinfo=document.createElement('DIV'); this.sizeinfo.style.fontSize='11px'; this.sizeinfo.style.fontFamily='Tahoma'; this.sizeinfo.style.color=this.grip.color; this.sizeinfo.style.position='absolute'; this.sizeinfo.style.visibility='hidden'; this.sizeinfo.style.cursor='default'; this.sizeinfo.style.left ='0px';this.sizeinfo.style.top='0px'; this.sizeinfo.style.margin='0px';this.sizeinfo.style.padding='0px'; this.sizeinfo.style.border='none';this.sizeinfo.style.zIndex=this.zIndex+1000; this.Gadgetry.appendChild(this.sizeinfo); this.compose(); this.initialize=true; };
/**
* 레이어 순서를 초기화 하는 함수
*@method reset
*@param {Bool} isDirectly 즉시 반영 여부
*@access public
*/
xwzGadgetry.prototype.reset=function(isDirectly){ var S=[],nIndex=0; for(var i=0,len=this.Nodes.length;i<len;i++){ nIndex=this.Nodes[i].getAttribute('_GadgetIndex')*1; S[nIndex]=this.Nodes[i]; }; this.Nodes=S; this._swapDepart(isDirectly); };
/**
* Nodes 배열 인덱스 값에 따라 레이어 위치를 초기화하는 함수
*@method compose
*@see #_mapping()
*@see #_molding()
*@acess public
*/
xwzGadgetry.prototype.compose=function(){ var Rect=this._mapping(this.Nodes,this.nCells,this.nDistance); for(var i=0,len=this.Nodes.length;i<len;i++){ this.Atlas[i].X=Rect[i].X;this.Atlas[i].Y=Rect[i].Y; this.Atlas[i].cX=Rect[i].cX;this.Atlas[i].cY=Rect[i].cY; this.Nodes[i].style.left=Rect[i].X+'px';this.Nodes[i].style.top=Rect[i].Y+'px'; this.Nodes[i].style.zIndex=this.zIndex+i; }; this._molding(); };
/**
* 마우스다운 이벤트가 발생하였을 때 drag&drop 이벤트 발생
*@method _dragDepart
*@param {Object} event 이벤트 핸들러
*@param {Number} _index 대상 객체의 인덱스
*@acess public
*/
xwzGadgetry.prototype.dragDepart=function(event,_index){ window.focus(); if(event._left!==true){this._dragArrival();return false;} /*Resize일때*/ if(this.talebearing=='resize')this._showGrips(); /*이벤트 상태값*/ this.talebearing='drag'; var s=this.getIndex(_index),z=0,node=this.Nodes[s];/*드래그앤드랍 대상 객체*/ this.Queue=[]; /*이동 객체에 투명도를 줌*/ notifyOpacity(node,60); /*인덱스 저장*/ this._trace.nTarget=this._trace.nSource=s; /*z-index save*/ z=node.style.zIndex; this.keelblocks.style.zIndex=node.style.zIndex; node.style.zIndex=this.zIndex+(this.Nodes.length*500); /*레이어가 이동할 동안 레이어가 위치할 자리에 대신 위치할 객체 이동*/ this.keelblocks.style.left=node.style.left; this.keelblocks.style.top=node.style.top; this.keelblocks.style.width=node.style.width; this.keelblocks.style.height=node.style.height; /*현재 포인트 기록*/ this._trace.dX=event._x;this._trace.dY=event._y; /*이벤트 등록 */ this.Observers['mousemove']=this._dragAviate.bindAsEvent(this,node); this.Observers['mouseup']=this._dragArrival.bindAsObject(this,node); addEventObserve(window.document,'mouseup',this.Observers['mouseup']); addEventObserve(window.document,'mousemove',this.Observers['mousemove']); window.document.onselectstart=new Function('return false'); window.document.ondragstart = new Function ("return false"); this.Queue=this.Nodes; };
/**
* 정해진 영역 펼침 또는 숨김 함수
*@method expose
*@acess Public
*/
xwzGadgetry.prototype.expose=function(_index){ /*이벤트 상태값*/ this.talebearing='expose'; var s=this.getIndex(_index),node=this.Nodes[s]; var dest=0; if(node.pixWidth==null)node.pixWidth=parseInt(node.style.width); if(node.pixHeight==null)node.pixHeight=parseInt(node.style.height); /*일반적인 숨김 또는 펼침 */ if(node.gadget.animate=='none'){this._expanded(node);return;} if(node.gadget.state=='collapse'){/*변경할 속성 값*/ dest=node.gadget.animate=='slide'?-1:node.gadget.height; node.gadget.style.visibility='visible'; }else{/*변경할 속성 값*/ dest=node.gadget.animate=='slide'?(node.gadget.height+1)*-1:1; } this._expanding(node,dest,0); };
/**
* expand 설정값 변경 함수
*@method expandAttrib
*@param {object,number} _gadget 인덱스 또는 객체인스턴스
*@param {string} _name 변경할 속성이름
*@param {function,string,number} _value 속성 값
*@param {object} _srcObj 최소, 최대화 함수의 참조 객체
*@acess Public
*/
xwzGadgetry.prototype.expandAttrib=function(_gadget,_name,_value,_srcObj){ var node=this.searchGadget(_gadget); if(node==null)return false; switch(_name){ /*최소화완료후실행할함수*/ case 'min':node.gadget.onMinimized=typeof _srcObj!='object'?new Function(_value||''):new Function(_value).bindAsObject(_srcObj);break; /*최대화완료후실행할함수*/case 'max':node.gadget.onMaximized=typeof _srcObj!='object'?new Function(_value||''):new Function(_value).bindAsObject(_srcObj); break; /*strata*/case 'strata':node.gadget.strata=parseInt(_value||node.gadget.strata);break; /*효과*/case 'animate':node.gadget.animate=parseInt(_value||node.gadget.animate);break; } return true; }
/**
* 리사이즈 함수
*@method resizeTo!
*@acess public
*/
xwzGadgetry.prototype.resize=function(event,_index){ if(this.noResize==true||event._left==false){return false;} var s=this.getIndex(_index); /*resize일때 중단*/ if((this.talebearing=='resize'&&s==this._trace.nSource)||(this.talebearing!='' &&this.talebearing!='resize')){ this.talebearing=this.talebearing!='resize'?this.talebearing:'';this._showGrips();return true; } this.talebearing='resize';/*이벤트 상태값 변경*/ this._trace.nSource=s; this._resizeArrange(this.Nodes[s]); this._showGrips(true); };
/**
* 선택된 레이어를 첫번째 배열요소로 이동
*@method _above
*@param {Number} _index 레이어 인덱스 번호
*@param {Bool} isDirectly 즉시 반영 여부
*@access private
*/
xwzGadgetry.prototype._above=function(_index){ var oList=[],s=this.getIndex(_index);if(s==0)return; oList[0]=this.Nodes[s]; for(var i=0,len=this.Nodes.length;i<len;i++){if(i!=s)oList[oList.length]=this.Nodes[i];}; this.Nodes=oList;this._swapDepart(); };
/**
* 선택된 레이어를 마지막번째 배열요소로 이동
*@method _below
*@param {Number} _index 레이어 인덱스 번호
*@access private
*/
xwzGadgetry.prototype._below=function(_index){ var oList=[],s=this.getIndex(_index);if(s==this.Nodes.length-1)return; for(var i=0,len=this.Nodes.length;i<len;i++){if(i!=s)oList[oList.length]=this.Nodes[i];}; oList[oList.length]=this.Nodes[s];this.Nodes=oList;this._swapDepart(); };
/**
* 선택된 레이어를 정해진 step만큼 이동시키는 함수
*@method _stack
*@param {Number}_index 레이어 인덱스 번호
*@param {Number} _step[:=decrease,increase]+1,-1,...
*@access private
*/
xwzGadgetry.prototype._stack=function(_index,_step){ var s=this.getIndex(_index),d=s+_step,dist=0,oNodtmp=this.Nodes[s]; d=d<0?this.Nodes.length-1:d>this.Nodes.length-1?0:d; if(d==this.Nodes.length-1&&s==0){/*prev*/ oNodtmp=this.Nodes.shift();this.Nodes.push(oNodtmp); }else if(d==0&&s==this.Nodes.length-1){/*next*/ oNodtmp=this.Nodes.pop();this.Nodes.unshift(oNodtmp); }else{ this.Nodes[s]=this.Nodes[d];this.Nodes[d]=oNodtmp; }; this._swapDepart(); };
/**
* 선택된 레이어를 정해진 Y,X 축으로 step만큼 이동시키는 함수
*@method _cross
*@param {Number} _index 레이어 인덱스 번호
*@param {String} _arrow[:=left,right,up,down] 이동 방향
*@access private
*/
xwzGadgetry.prototype._cross=function(_index,_arrow){ _arrow=(_arrow).toString().toLowerCase()||(this.nCells>0?'up':'left'); var s=this.getIndex(_index),d=s; var iX=Math.floor(s%this.nCells),iY=Math.floor(s/this.nCells),mX=Math.floor(this.Nodes.length-1%this.nCells),mY=Math.floor(this.Nodes.length-1/this.nCells); if(_arrow=='up')iY=iY>0?iY-1:iY; else if(_arrow=='down')iY=iY<mY?iY+1:iY; else if(_arrow=='left')iX=iX>0?iX-1:iX; else if(_arrow=='right')iX=iX<mX?iX+1:iX; d=(iY*this.nCells)+iX; if(d==s||d<0||d>this.Nodes.length-1)return false; var oNodtmp=this.Nodes[s]; this.Nodes[s]=this.Nodes[d]; this.Nodes[d]=oNodtmp; this._swapDepart(); };
/**
* Frame 객체의 너비와 높이 설정 함수
*@method _molding
*@see #_grid()
*@acess private
*/
xwzGadgetry.prototype._molding=function(){ this.talebearing=''; var d=this._grid(this.Nodes,this.nCells),nX=Math.floor(this.nDistance/2),nY=Math.floor(this.nDistance/2); for(var i=0,len=d.horizontal.length;i<len;i++){nX+=d.horizontal[i]+this.nDistance;}; for(var i=0,len=d.vertical.length;i<len;i++){nY+=d.vertical[i]+this.nDistance;} this.Gadgetry.style.width=nX+'px'; this.Gadgetry.style.height=nY+'px'; this._showGrips();this.saveSequel(); };
/**
* 각 레이어의 너비와 높이값을 배열화
*@method _grid
*@param {Object} Nodes 레이어 배열
*@param {Number} nColumns column 수
*@return {Object}
*@acess private
*/
xwzGadgetry.prototype._grid=function(Nodes,nColumns){ var iX=0,iY=0,nX=0,nY=0,h=[],v=[]; for(var i=0,len=Nodes.length;i<len;i++){ nX=parseInt(Nodes[i].style.width); nY=parseInt(Nodes[i].style.height); iX=Math.floor(i%nColumns);iY=Math.floor(i/nColumns); v[iY]=(v[iY]||0)>nY?v[iY]:nY;h[iX]=(h[iX]||0)>nX?h[iX]:nX; }; return{vertical:v,horizontal:h}; };
/**
* 레이어들에 대한 x,y, width, height 값 배열화 함수
*@method _mapping
*@see #_grid()
*@param {Object} Nodes 레이어 배열
*@param {Number} nColumns column 수
*@return {Array} Array(x, y, width, height )
*@acess private
*/
xwzGadgetry.prototype._mapping=function(Nodes,nColumns,Distance){ /*grid->_mapping->_molding*/ var iX=0,iY=0,nX=Math.abs(Distance/2),nY=Math.abs(Distance/2),Map=[],d=this._grid(Nodes,nColumns); for(var i=0,len=Nodes.length;i<len;i++){ iX=Math.floor(i%nColumns);iY=Math.floor(i/nColumns); if(iX==0){ nX=Math.abs(Distance/2);if(iY>0)nY+=(d.vertical[iY-1]+Distance);}; Map[i]={X:nX,Y:nY,cX:parseInt(Nodes[i].style.width),cY:parseInt(Nodes[i].style.height)}; nX+=(d.horizontal[iX]+Distance); }; return Map; };
/**
*변경된 배열의 인덱스에 따라 각 레이어가 이동할 위치 계산
*@method _swapDepart
*@see #_swapAviate()
*@acess private
*/
xwzGadgetry.prototype._swapDepart=function(isDirectly){ /*이벤트 상태값*/ this.talebearing='position'; this.Queue=[]; var d=0,dX=0,dY=0,Rect=this._mapping(this.Nodes,this.nCells,this.nDistance); for(var i=0,len=this.Nodes.length;i<len;i++){ /*레이어 현재 위치와 이동할 위치 차이 계산*/ dX=Rect[i].X-parseInt(this.Nodes[i].style.left),dY=Rect[i].Y-parseInt(this.Nodes[i].style.top); d=len-1-i; this.Nodes[d].style.zIndex=(this.zIndex+len)-i; if(dX==0&&dY==0)continue; this.Atlas[i]=Rect[i]; /*각 속성값 배열화*/ this.Queue[this.Queue.length]={ style:this.Nodes[i].style, distX:dX,distY:dY, posX:parseInt(this.Nodes[i].style.left),posY:parseInt(this.Nodes[i].style.top), mvX:Rect[i].X,mvY:Rect[i].Y, scX:dX!=0?0:this.nStrata,scY:dY!=0?0:this.nStrata }; /*투명도 설정*/ notifyOpacity(this.Nodes[i],this.nOpacity); }; (this.isMotion==true||isDirectly==true)?this._swapAviate():this.compose(); };
/**
* 레이어를 이동할 위치로 점차 이동시키는 함수
*@method _swapAviate
*@acess private 거리계산
*/
xwzGadgetry.prototype._swapAviate=function(){ clearTimeout(this.resTime);this.resTime=null; var o=null,Q=[]; var dY=0,dX=0; for(var i=0,len=this.Queue.length;i<len;i++){ o=this.Queue[i];/*이동 객체*/ if(o.scX<this.nStrata){/*x축 이동*/ dX=Math.round(Math.sin(o.scX/this.nStrata*Math.PI/2)*o.distX); o.style.left=(o.posX+dX)+'px'; o.scX++; } if(o.scY<this.nStrata){/*y축 이동*/ dY=Math.round(Math.sin(o.scY/this.nStrata*Math.PI/2)*o.distY); o.style.top=(o.posY+dY)+'px'; o.scY++; } /*이동완료*/ if(o.scX>=this.nStrata&&o.scY>=this.nStrata){ notifyOpacity(o);o.style.left=(o.mvX)+'px';o.style.top=(o.mvY)+'px'; }else{/*재 배열화*/ Q[Q.length]=o; } }; if(Q.length==0){ this.Queue=[];this._molding(); return false; } this.Queue=Q; this.resTime=setTimeout(this._swapAviate.bindAsObject(this),0); };
/**
* 마우스로 위치를 변경할 경우 입력된 객체의 위치를 마우스 포인터가 위치한 자리로 이동시킴
*@method _dragArrange
*@see #__dragAviate()
*@see #__dragArrival()
*@param {Object} element 대상 객체
*@return {Object} 이동 객체와 각 인덱스에 따른 레이어 위치 값
*@acess private
*/
xwzGadgetry.prototype._dragArrange=function(element){ var Queue=[],Rect=[]; /*마우스 이동 객체를 제외하고 재배열화*/ for(var i=0,len=this.Queue.length;i<len;i++){ if(i!=this._trace.nSource)Queue[Queue.length]=this.Queue[i]; }; /*대상객체와 객체가 이동할 위치에 있는 객체의 인덱스를 바꿔치기*/ Queue[Queue.length]=null; for(var i=Queue.length-1;i>this._trace.nTarget;i--)Queue[i]=Queue[i-1]; Queue[this._trace.nTarget]=this.Queue[this._trace.nSource]; /*레이어들에 대한 x,y,width,height 값 배열화*/ Rect=this._mapping(Queue,this.nCells,this.nDistance); for(var i=0,len=this.Queue.length;i<len;i++){ if(i!=this._trace.nTarget){ Queue[i].style.left=Rect[i].X+'px';Queue[i].style.top=Rect[i].Y+'px';Queue[i].style.zIndex=this.zIndex+i; }else if(element!=null){/*대상객체 위치 이동*/ element.style.left=Rect[i].X;element.style.top=Rect[i].Y;element.style.zIndex=this.zIndex+i; } }; return{Nodes:Queue,Rect:Rect}; };
/**
* drag&drop(마우스 이동)에 따른 처리함수
*@method _dragAviate
*@param {Object} event 이벤트 핸들러
*@acess private
*/
xwzGadgetry.prototype._dragAviate=function(event,node){ /*드래그앤드랍 대상이 없거나,왼쪽 마우스버튼을 누르지 않고 있는 경우 중단*/ if(node==null||event._left!==true){this._dragArrival(node);return false;} if(this.keelblocks.style.display!='block')this.keelblocks.style.display='block'; /*마우스 포인트 이동 값 측정*/ var dX=event._x-this._trace.dX,dY=event._y-this._trace.dY; /*마우스가 이동한 만큼 위치 이동*/ var x=parseInt(node.style.left)+dX,y=parseInt(node.style.top)+dY; node.style.left=x+'px';node.style.top=y+'px'; /*현재 마우스 포인터에 따른 전체 영역에서 위치 계산*/ var iY=Math.floor(this._trace.nSource/this.nCells),cY=Math.abs(this.Atlas[this._trace.nSource].Y-y); var iX=Math.floor(this._trace.nSource%this.nCells),cX=Math.abs(this.Atlas[this._trace.nSource].X-x); for(var i=0,len=this.Atlas.length;i<len;i+=this.nCells){if(cY>Math.abs(this.Atlas[i].Y-y)){cY=Math.abs(this.Atlas[i].Y-y);iY=Math.floor(i/this.nCells);}}; for(var i=0;i<this.nCells;i++){if(cX>Math.abs(this.Atlas[i].X-x)){cX=Math.abs(this.Atlas[i].X-x);iX=Math.floor(i%this.nCells);}}; this._trace.nTarget=(iY*this.nCells)+iX; this._trace.nTarget=(this._trace.nTarget>this.Queue.length-1)?this.Queue.length-1:this._trace.nTarget; /*클론 레이어 이동*/ this._dragArrange(this.keelblocks); /*현재 포인트 기록*/ this._trace.dX=event._x;this._trace.dY=event._y; };
/**
* drag&drop 완료에 따른 처리함수
*@method _dragArrival
*@acess private
*/
xwzGadgetry.prototype._dragArrival=function(node){ /*이벤트 해제*/ if(this.Observers['mouseup']!=null)freeEventObserve(window.document,'mouseup',this.Observers['mouseup']); if(this.Observers['mousemove']!=null)freeEventObserve(window.document,'mousemove',this.Observers['mousemove']); this.Observers['mouseup']=null;this.Observers['mousemove']=null; window.document.onselectstart=null;window.document.ondragstart = null; var oReturn=null,dX=dY=0; /**/ if(node!=null){ oReturn=this._dragArrange(); dX=this.Atlas[this._trace.nTarget].X-parseInt(node.style.left); dY=this.Atlas[this._trace.nTarget].Y-parseInt(node.style.top); this.Queue=[{style:node.style,distX:dX,distY:dY,posX:parseInt(node.style.left),posY:parseInt(node.style.top),mvX:this.Atlas[this._trace.nTarget].X,mvY:this.Atlas[this._trace.nTarget].Y,scX:0,scY:0}]; notifyOpacity(node,this.nOpacity); this.isMotion==true?this._swapAviate():this.compose(); this.Nodes=oReturn.Nodes; this.Atlas=oReturn.Rect; node.style.zIndex=this.keelblocks.style.zIndex; } this.keelblocks.style.zIndex=-1;this.keelblocks.style.display='none'; this._trace.dX=0;this._trace.dY=0;this._trace.nTarget=null;this._trace.nSource=null; this.Observers=[]; };
/**
* Slide, Bind 형태의 펼침 또는 숨김 모션 함수
*@method _expanding
*@param {Object} gadget 대상 영역을 감싸고 있는 객체
*@param {Number} n Count
*@acess private
*/
xwzGadgetry.prototype._expanding=function(node,dest,n){ var curr=parseInt(node.gadget.animate=='slide'?node.gadget.topgap:node.gadget.style.height);/*현재 속성*/ /*Time 인스턴스 제거*/ clearTimeout(this.resTime);this.resTime=null; if(dest-curr==0||n>node.gadget.strata){/*Count 완료*/ if(node.gadget.animate=='slide')node.gadget.topgap=dest+'px'; else node.gadget.style.height=dest+'px'; this._expanded(node); }else{/*ing*/ curr+=Math.round(Math.sin(n/node.gadget.strata*Math.PI/2)*(dest-curr)); if(node.gadget.animate=='slide'){/*slide인 경우 marginTop 속성을 변경,height으로 나머지 영역을 감춤*/ node.gadget.topgap=curr+'px'; node.gadget.style.height=(node.gadget.height+curr<=0?1:node.gadget.height+curr)+'px'; }else{/*slide가 아닌 경우 blind 로 처리하고 높이만 조정함*/ node.gadget.style.height=(curr<=0?1:curr)+'px'; } /*대상 가젯의 높이 재 조정*/ node.style.height=(node.pixHeight-node.gadget.height)+parseInt(node.gadget.style.height)+'px'; this.resTime=setTimeout(this._expanding.bindAsObject(this,node,dest,++n),1); } };
/**
* 펼침 또는 닫힘 완료 함수
*@method _expanded
*@acess private
*/
xwzGadgetry.prototype._expanded=function(node){ if(node.gadget.state=='expand'){/*펼침 상태에서 완료된 경우*/ node.gadget.style.visibility='hidden';/*가젯을 숨김*/ node.gadget.state='collapse';/*상태값 변경*/ node.gadget.style.height='1px'; node.style.height=(node.pixHeight-node.gadget.height)+'px'; node.gadget.onMinimized(); }else if(node.gadget.state=='collapse'){/*닫힘상태에서 완료된 경우*/ node.gadget.style.visibility='visible';/*가젯 보임*/ node.gadget.state='expand';/*상태값 변경*/ node.gadget.style.height=node.gadget.height+'px'; node.style.height=node.pixHeight+'px'; node.gadget.onMaximized(); } /*높이 변경에 따른 배열 위치 및 frame 높이 재 설정*/ this._swapDepart(); };
/**
* resize grip view 상태 변경 함수
*@method _showGrips
*@param {bool} bValue [true, false]
*@acess private
*/
xwzGadgetry.prototype._showGrips=function(bValue){for(var nm in this.grips)this.grips[nm].style.visibility=bValue==true?'visible':'hidden'; this.sizeinfo.style.visibility=bValue==true?'visible':'hidden';};
/**
* resize grip/ border div 위치 설정 함수
*@method _showGrips
*@param {int} x x좌표값
*@param {int} y y좌표값
*@param {int} w 너비
*@param {int} h 높이
*@acess private
*/
xwzGadgetry.prototype._resizeArrange=function(src){ var g=parseInt(this.grip.size); var x=parseInt(src.offsetLeft||src.style.left)+1,y=parseInt(src.offsetTop||src.style.top)+1; var w=parseInt(src.offsetWidth||src.style.width)-1,h=parseInt(src.offsetHeight||src.style.height)-1; /*각 grip 위치 설정*/ for(var nm in this.grips){ if(nm.charAt(0)=='l') this.grips[nm].style.left=x+'px'; else if(nm.charAt(0)=='c') this.grips[nm].style.left=(x+(w/2-g/2))+'px'; else if(nm.charAt(0)=='r') this.grips[nm].style.left=((x+w)-g)+'px'; if(nm.charAt(1)=='t') this.grips[nm].style.top=y+'px'; else if(nm.charAt(1)=='m') this.grips[nm].style.top=(y+(h/2-g/2))+'px'; else if(nm.charAt(1)=='b') this.grips[nm].style.top=((y+h)-g)+'px'; this.grips[nm].style.visibility='visible'; }; };
/**
* resize grip view 상태 변경 함수
*@method _resizeDepart
*@param {event object} event 마우스 이벤트
*@acess private
*/
xwzGadgetry.prototype._resizeDepart=function(event,node){ window.focus(); var node=this.Nodes[this._trace.nSource]; if(node==null||event._left!==true){this._resizeArrival();return false;} this.keelblocks.style.display='block'; /*레이어가 이동할 동안 레이어가 위치할 자리에 대신 위치할 객체 이동*/ this.keelblocks.style.left=node.style.left; this.keelblocks.style.top=node.style.top; this.keelblocks.style.width=node.style.width; this.keelblocks.style.height=node.style.height; /*z-index save*/ var z=node.style.zIndex; this.keelblocks.style.zIndex=this.zIndex+(this.Nodes.length*500); this._trace.dX=event._x;this._trace.dY=event._y; /*이벤트 등록 */ this.Observers['mousemove']=this._resizeAviate.bindAsEvent(this,node,event.element.nm); this.Observers['mouseup']=this._resizeArrival.bindAsObject(this,node,event.element.nm); addEventObserve(window.document,'mouseup',this.Observers['mouseup']); addEventObserve(window.document,'mousemove',this.Observers['mousemove']); window.document.onselectstart=new Function('return false'); window.document.ondragstart = new Function ("return false"); this.keelblocks.style.cursor=event.element.style.cursor; };
/**
* resizing 함수
*@method _resizeAviate
*@param {event object} event 마우스 이벤트
*@acess private
*/
xwzGadgetry.prototype._resizeAviate=function(event,node,nm){ /*드래그앤드랍 대상이 없거나,왼쪽 마우스버튼을 누르지 않고 있는 경우 중단*/ if(node==null||event._left!==true){this._dragArrival(node);return false;} /*마우스 포인트 이동 값 측정*/ var dx =event._x-this._trace.dX,dy=event._y-this._trace.dY,m1=0,m2=0,d=0,g=0; var fX=nm.charAt(0),fY=nm.charAt(1); var l=parseInt(this.keelblocks.style.left),t=parseInt(this.keelblocks.style.top),w=parseInt(this.keelblocks.style.width),h=parseInt(this.keelblocks.style.height); /*left, width 설정*/ if(fX!='c'){ m1=parseInt(this.grip.minWidth||this.grip.size*3);m2=parseInt(this.grip.maxWidth||w*2); d=w+(fX=='l'?(dx*-1):dx);/*left 이동에 처리*/ if(d>m1&&d<m2){if(l+dx>0&&fX=='l'){this.keelblocks.style.left=(l+dx)+'px';w=d;}else if(fX!='l'){w=d;}} this.keelblocks.style.width=w+'px'; } /*top, height 설정*/ if(fY!='m'){ m1=parseInt(this.grip.minHeight||this.grip.size*3);m2=parseInt(this.grip.maxHeight||h*2); d=h+(fY=='t'?(dy*-1):dy);/*top 이동에 처리*/ if(d>m1&&d<m2){if(t+dy>0&&fY=='t'){this.keelblocks.style.top=(t+dy)+'px';h=d;}else if(fY!='t'){h=d;}} this.keelblocks.style.height=h+'px'; } /*각 grip 위치 설정*/ this._resizeArrange(this.keelblocks); this.sizeinfo.innerText=parseInt(this.keelblocks.style.width)+'x'+parseInt(this.keelblocks.style.height); this.sizeinfo.style.left=(parseInt(this.grips.rb.style.left)-(this.sizeinfo.offsetWidth)+2)+'px';this.sizeinfo.style.top=(parseInt(this.grips.rb.style.top)-(this.sizeinfo.offsetHeight)+2)+'px'; /*현재 포인트 기록*/ this._trace.dX=event._x;this._trace.dY=event._y; };
/**
* resize 완료함수
*@method _resizeArrival
*@param {event object} event 마우스 이벤트
*@acess private
*/
xwzGadgetry.prototype._resizeArrival=function(node){ /*이벤트 해제*/ if(this.Observers['mouseup']!=null)freeEventObserve(window.document,'mouseup',this.Observers['mouseup']); if(this.Observers['mousemove']!=null)freeEventObserve(window.document,'mousemove',this.Observers['mousemove']); this.Observers['mouseup']=null;this.Observers['mousemove']=null; window.document.onselectstart=null;window.document.ondragstart = null; this._showGrips(); /*크기 재 설정*/ if(node!=null){ node.style.width=this.keelblocks.style.width;node.style.height=this.keelblocks.style.height;this._swapDepart();} this.keelblocks.style.cursor='auto';this.keelblocks.style.display='none'; this.sizeinfo.innerText=''; if(node.pixWidth!=null)node.pixWidth=parseInt(node.style.width);if(node.pixHeight!=null)node.pixHeight=parseInt(node.style.height);};</xmp>
</div>
<div style="text-align:center">
<div style="width:950px;margin:0px auto;margin-top:10px">
PHP 스쿨에 올린 자료 대충 메뉴로 묶었습니다 -_-; 여기에 소스는 사람이면 누구나 사용이 가능하며 배포하실 수 있습니다. 소스 수정은 들키지만 않으면 수정 가능합니다.<br>
<dl style="border:#CACACA 1px solid;height:40px;background-color:#F2F2F2;">
<dd style="margin:10px 4px 1px 4px;"><a href="/example/dtp2.html">달력-IE 전용</a></dd>
<dd style="margin:10px 4px 1px 4px;">|</dd>
<dd style="margin:10px 4px 1px 4px;"><a href="/example/roll.htm">레이어효과 1</a></dd>
<dd style="margin:10px 4px 1px 4px;">|</dd>
<dd style="margin:10px 4px 1px 4px;"><a href="/example/ajax.control.php">Multi Ajax Control </a></dd>
<dd style="margin:10px 4px 1px 4px;">|</dd>
<dd style="margin:10px 4px 1px 4px;"><a href="/example/gadgetry.html">Gadgetry-move, drag & drop</a></dd>
<dd style="margin:10px 4px 1px 4px;">|</dd>
<dd style="margin:10px 4px 1px 4px;"><a href="/example/scaledrop.html">drag & drop, resize</a></dd>
<dd style="margin:10px 4px 1px 4px;">|</dd>
<dd style="margin:10px 4px 1px 4px;"><a href="/example/vroll.html">Vertical Rolling</a></dd>
<dd style="margin:10px 4px 1px 4px;">|</dd>
<dd style="margin:10px 4px 1px 4px;"><a href="/example/verticalstrip.html">Vertical Strip</a></dd>
</dl>
<div style="margin:4px 10px 1px 4px;">
<div style="float:left"><a href="http://www.myhangeul.com/myad/?disp=2" target='_blank'><img src="http://myhangeul.com/myad/ucif/b/spolite_b6c1b594da5fe3c56a99b2fae9adaf75_BA.gif" width="367" height="32" border="0"></a></div>
<div style="float:right"><font color=#000000>Copyright(c) 2004. <strong>X-<font color="#FF6600">w<font color=#007bff>i</font>z</font><font color=#636363>.com</strong></font> All rights reserved.</font></div>
</div>
</div>
</div>
</body>
</html>
'인터넷정보' 카테고리의 다른 글
실시간검색어 예제 - 다음(daum) 스타일 (0) | 2007.10.13 |
---|---|
자바스크립트로 구현한 md4,md5,sha-1 (0) | 2007.10.13 |
자바스크립트로 구현한 md4,md5,sha-1 (0) | 2007.10.13 |
프레임 경계선을 넘나드는 createPopup() (0) | 2007.10.13 |
프레임 경계선을 넘나드는 createPopup() (0) | 2007.10.13 |
지정된 영역에서 각 레이어 간의 이동 효과(구글,야후) (0) | 2007.10.13 |
피부 미남 만들기 - "면도만 잘해도 완소남" (0) | 2007.10.13 |
피부 미남 만들기 - "면도만 잘해도 완소남" (0) | 2007.10.13 |
자바스크립트 에러 상태창에 표시 (0) | 2007.10.13 |
자바스크립트 에러 상태창에 표시 (0) | 2007.10.13 |